From 92f7c51979a446219a9c984f352772202568c35e Mon Sep 17 00:00:00 2001 From: Nathaniel Bauernfeind Date: Tue, 6 Sep 2022 19:07:31 -0600 Subject: [PATCH] Use unit test execution context for java-client unit tests --- .../engine/context/QueryLibrary.java | 4 ++ .../python/server/EmbeddedServer.java | 2 + .../server/jetty/JettyServerComponent.java | 2 + .../server/netty/NettyServerComponent.java | 2 + .../console/NoConsoleSessionModule.java | 27 +++++++++++ .../SessionToExecutionStateModule.java | 14 ++++++ .../server/runner/DeephavenApiServer.java | 8 +++- ...avenApiServerInProcessGroovyComponent.java | 4 +- ...avenApiServerInProcessPythonComponent.java | 4 +- .../server/session/SessionState.java | 4 +- .../ApplicationServiceGrpcImplTest.java | 3 +- .../runner/DeephavenApiServerTestBase.java | 47 +++++++++++++++++-- .../server/session/SessionServiceTest.java | 3 +- .../server/session/SessionStateTest.java | 5 +- .../table/ExportTableUpdateListenerTest.java | 3 +- 15 files changed, 119 insertions(+), 13 deletions(-) create mode 100644 server/src/main/java/io/deephaven/server/console/NoConsoleSessionModule.java create mode 100644 server/src/main/java/io/deephaven/server/console/SessionToExecutionStateModule.java diff --git a/engine/context/src/main/java/io/deephaven/engine/context/QueryLibrary.java b/engine/context/src/main/java/io/deephaven/engine/context/QueryLibrary.java index 724cd0011e0..3bb72dd7660 100644 --- a/engine/context/src/main/java/io/deephaven/engine/context/QueryLibrary.java +++ b/engine/context/src/main/java/io/deephaven/engine/context/QueryLibrary.java @@ -108,4 +108,8 @@ public Collection getImportStrings() { public void updateVersionString() { versionString = UuidCreator.toString(UuidCreator.getRandomBased()); } + + public void updateVersionString(String version) { + versionString = version; + } } diff --git a/py/embedded-server/java-runtime/src/main/java/io/deephaven/python/server/EmbeddedServer.java b/py/embedded-server/java-runtime/src/main/java/io/deephaven/python/server/EmbeddedServer.java index a45d98be2c5..0f62b6e71ef 100644 --- a/py/embedded-server/java-runtime/src/main/java/io/deephaven/python/server/EmbeddedServer.java +++ b/py/embedded-server/java-runtime/src/main/java/io/deephaven/python/server/EmbeddedServer.java @@ -11,6 +11,7 @@ import io.deephaven.io.log.LogLevel; import io.deephaven.io.logger.LogBuffer; import io.deephaven.io.logger.LogBufferOutputStream; +import io.deephaven.server.console.SessionToExecutionStateModule; import io.deephaven.server.console.groovy.GroovyConsoleSessionModule; import io.deephaven.server.console.python.PythonConsoleSessionModule; import io.deephaven.server.console.python.PythonGlobalScopeModule; @@ -48,6 +49,7 @@ public class EmbeddedServer { JettyServerModule.class, PythonConsoleSessionModule.class, GroovyConsoleSessionModule.class, + SessionToExecutionStateModule.class, }) public interface PythonServerComponent extends DeephavenApiServerComponent { @Component.Builder diff --git a/server/jetty/src/main/java/io/deephaven/server/jetty/JettyServerComponent.java b/server/jetty/src/main/java/io/deephaven/server/jetty/JettyServerComponent.java index 3c052082e45..e5dc662be55 100644 --- a/server/jetty/src/main/java/io/deephaven/server/jetty/JettyServerComponent.java +++ b/server/jetty/src/main/java/io/deephaven/server/jetty/JettyServerComponent.java @@ -5,6 +5,7 @@ import dagger.BindsInstance; import dagger.Component; +import io.deephaven.server.console.SessionToExecutionStateModule; import io.deephaven.server.console.groovy.GroovyConsoleSessionModule; import io.deephaven.server.console.python.PythonConsoleSessionModule; import io.deephaven.server.console.python.PythonGlobalScopeCopyModule; @@ -28,6 +29,7 @@ JettyServerModule.class, PythonConsoleSessionModule.class, GroovyConsoleSessionModule.class, + SessionToExecutionStateModule.class, }) public interface JettyServerComponent extends DeephavenApiServerComponent { @Component.Builder diff --git a/server/netty/src/main/java/io/deephaven/server/netty/NettyServerComponent.java b/server/netty/src/main/java/io/deephaven/server/netty/NettyServerComponent.java index 3469794ac2b..d50256c9519 100644 --- a/server/netty/src/main/java/io/deephaven/server/netty/NettyServerComponent.java +++ b/server/netty/src/main/java/io/deephaven/server/netty/NettyServerComponent.java @@ -5,6 +5,7 @@ import dagger.BindsInstance; import dagger.Component; +import io.deephaven.server.console.SessionToExecutionStateModule; import io.deephaven.server.console.groovy.GroovyConsoleSessionModule; import io.deephaven.server.console.python.PythonConsoleSessionModule; import io.deephaven.server.console.python.PythonGlobalScopeCopyModule; @@ -28,6 +29,7 @@ NettyServerModule.class, PythonConsoleSessionModule.class, GroovyConsoleSessionModule.class, + SessionToExecutionStateModule.class, }) public interface NettyServerComponent extends DeephavenApiServerComponent { @Component.Builder diff --git a/server/src/main/java/io/deephaven/server/console/NoConsoleSessionModule.java b/server/src/main/java/io/deephaven/server/console/NoConsoleSessionModule.java new file mode 100644 index 00000000000..f2eb1a65213 --- /dev/null +++ b/server/src/main/java/io/deephaven/server/console/NoConsoleSessionModule.java @@ -0,0 +1,27 @@ +/** + * Copyright (c) 2016-2022 Deephaven Data Labs and Patent Pending + */ +package io.deephaven.server.console; + +import dagger.Module; +import dagger.Provides; +import dagger.multibindings.IntoMap; +import dagger.multibindings.StringKey; +import io.deephaven.engine.util.NoLanguageDeephavenSession; +import io.deephaven.engine.util.ScriptSession; +import io.deephaven.server.console.groovy.InitScriptsModule; + +@Module(includes = InitScriptsModule.ServiceLoader.class) +public class NoConsoleSessionModule { + @Provides + @IntoMap + @StringKey("none") + ScriptSession bindScriptSession(NoLanguageDeephavenSession noLanguageSession) { + return noLanguageSession; + } + + @Provides + NoLanguageDeephavenSession bindNoLanguageSession() { + return new NoLanguageDeephavenSession(); + } +} diff --git a/server/src/main/java/io/deephaven/server/console/SessionToExecutionStateModule.java b/server/src/main/java/io/deephaven/server/console/SessionToExecutionStateModule.java new file mode 100644 index 00000000000..6eecb5fc743 --- /dev/null +++ b/server/src/main/java/io/deephaven/server/console/SessionToExecutionStateModule.java @@ -0,0 +1,14 @@ +package io.deephaven.server.console; + +import dagger.Module; +import dagger.Provides; +import io.deephaven.engine.context.ExecutionContext; +import io.deephaven.engine.util.ScriptSession; + +@Module +public class SessionToExecutionStateModule { + @Provides + ExecutionContext bindExecutionContext(ScriptSession session) { + return session.getExecutionContext(); + } +} diff --git a/server/src/main/java/io/deephaven/server/runner/DeephavenApiServer.java b/server/src/main/java/io/deephaven/server/runner/DeephavenApiServer.java index 5b2eb27594a..5f47aa89fbc 100644 --- a/server/src/main/java/io/deephaven/server/runner/DeephavenApiServer.java +++ b/server/src/main/java/io/deephaven/server/runner/DeephavenApiServer.java @@ -5,6 +5,7 @@ import io.deephaven.auth.AuthenticationRequestHandler; import io.deephaven.configuration.Configuration; +import io.deephaven.engine.context.ExecutionContext; import io.deephaven.engine.table.impl.perf.QueryPerformanceRecorder; import io.deephaven.engine.table.impl.perf.UpdatePerformanceTracker; import io.deephaven.engine.table.impl.util.MemoryTableLoggers; @@ -51,6 +52,7 @@ public class DeephavenApiServer { private final UriResolvers uriResolvers; private final SessionService sessionService; private final Map authenticationHandlers; + private final Provider executionContextProvider; @Inject public DeephavenApiServer( @@ -62,7 +64,8 @@ public DeephavenApiServer( final ApplicationInjector applicationInjector, final UriResolvers uriResolvers, final SessionService sessionService, - final Map authenticationHandlers) { + final Map authenticationHandlers, + final Provider executionContextProvider) { this.server = server; this.ugp = ugp; this.logInit = logInit; @@ -72,6 +75,7 @@ public DeephavenApiServer( this.uriResolvers = uriResolvers; this.sessionService = sessionService; this.authenticationHandlers = authenticationHandlers; + this.executionContextProvider = executionContextProvider; } @VisibleForTesting @@ -162,6 +166,8 @@ public void join() throws InterruptedException { void startForUnitTests() throws Exception { pluginRegistration.registerAll(); applicationInjector.run(); + executionContextProvider.get().getQueryLibrary().updateVersionString("DEFAULT"); + log.info().append("Starting server...").endl(); server.start(); } diff --git a/server/src/main/java/io/deephaven/server/runner/DeephavenApiServerInProcessGroovyComponent.java b/server/src/main/java/io/deephaven/server/runner/DeephavenApiServerInProcessGroovyComponent.java index 4d61c51b3cf..346d4e59bb0 100644 --- a/server/src/main/java/io/deephaven/server/runner/DeephavenApiServerInProcessGroovyComponent.java +++ b/server/src/main/java/io/deephaven/server/runner/DeephavenApiServerInProcessGroovyComponent.java @@ -5,6 +5,7 @@ import dagger.BindsInstance; import dagger.Component; +import io.deephaven.server.console.SessionToExecutionStateModule; import io.deephaven.server.console.groovy.GroovyConsoleSessionModule; import io.deephaven.server.log.LogModule; import io.grpc.ManagedChannelBuilder; @@ -18,7 +19,8 @@ DeephavenApiServerModule.class, LogModule.class, GroovyConsoleSessionModule.class, - ServerBuilderInProcessModule.class + ServerBuilderInProcessModule.class, + SessionToExecutionStateModule.class, }) public interface DeephavenApiServerInProcessGroovyComponent { diff --git a/server/src/main/java/io/deephaven/server/runner/DeephavenApiServerInProcessPythonComponent.java b/server/src/main/java/io/deephaven/server/runner/DeephavenApiServerInProcessPythonComponent.java index 2cd576e51fe..83c84b4eb0c 100644 --- a/server/src/main/java/io/deephaven/server/runner/DeephavenApiServerInProcessPythonComponent.java +++ b/server/src/main/java/io/deephaven/server/runner/DeephavenApiServerInProcessPythonComponent.java @@ -5,6 +5,7 @@ import dagger.BindsInstance; import dagger.Component; +import io.deephaven.server.console.SessionToExecutionStateModule; import io.deephaven.server.console.python.PythonConsoleSessionModule; import io.deephaven.server.console.python.PythonGlobalScopeCopyModule; import io.deephaven.server.log.LogModule; @@ -20,7 +21,8 @@ LogModule.class, PythonConsoleSessionModule.class, PythonGlobalScopeCopyModule.class, - ServerBuilderInProcessModule.class + ServerBuilderInProcessModule.class, + SessionToExecutionStateModule.class, }) public interface DeephavenApiServerInProcessPythonComponent { diff --git a/server/src/main/java/io/deephaven/server/session/SessionState.java b/server/src/main/java/io/deephaven/server/session/SessionState.java index 22967b0c391..d2b4bf01b73 100644 --- a/server/src/main/java/io/deephaven/server/session/SessionState.java +++ b/server/src/main/java/io/deephaven/server/session/SessionState.java @@ -136,13 +136,13 @@ public static ExportObject wrapAsExport(final T export) { @AssistedInject public SessionState(final Scheduler scheduler, - final Provider scriptSessionProvider, + final Provider executionContextProvider, @Assisted final AuthContext authContext) { this.sessionId = UuidCreator.toString(UuidCreator.getRandomBased()); this.logPrefix = "SessionState{" + sessionId + "}: "; this.scheduler = scheduler; this.authContext = authContext; - this.executionContext = scriptSessionProvider.get().getExecutionContext(); + this.executionContext = executionContextProvider.get(); log.info().append(logPrefix).append("session initialized").endl(); } diff --git a/server/src/test/java/io/deephaven/server/appmode/ApplicationServiceGrpcImplTest.java b/server/src/test/java/io/deephaven/server/appmode/ApplicationServiceGrpcImplTest.java index 9174541b82d..ecd8a8072a4 100644 --- a/server/src/test/java/io/deephaven/server/appmode/ApplicationServiceGrpcImplTest.java +++ b/server/src/test/java/io/deephaven/server/appmode/ApplicationServiceGrpcImplTest.java @@ -3,6 +3,7 @@ */ package io.deephaven.server.appmode; +import io.deephaven.engine.context.ExecutionContext; import io.deephaven.engine.liveness.LivenessScopeStack; import io.deephaven.engine.util.NoLanguageDeephavenSession; import io.deephaven.engine.util.ScriptSession; @@ -42,7 +43,7 @@ public void setup() { livenessScope = LivenessScopeStack.open(); scheduler = new TestControlledScheduler(); sessionService = new SessionService(scheduler, - authContext -> new SessionState(scheduler, NoLanguageDeephavenSession::new, authContext), + authContext -> new SessionState(scheduler, ExecutionContext::createForUnitTests, authContext), TOKEN_EXPIRE_MS, Optional.empty(), Collections.emptyMap()); applicationServiceGrpcImpl = new ApplicationServiceGrpcImpl(scheduler, sessionService, new TypeLookup(ObjectTypeLookup.NoOp.INSTANCE)); diff --git a/server/src/test/java/io/deephaven/server/runner/DeephavenApiServerTestBase.java b/server/src/test/java/io/deephaven/server/runner/DeephavenApiServerTestBase.java index 427e4c7418d..b5591cffd2d 100644 --- a/server/src/test/java/io/deephaven/server/runner/DeephavenApiServerTestBase.java +++ b/server/src/test/java/io/deephaven/server/runner/DeephavenApiServerTestBase.java @@ -3,12 +3,17 @@ */ package io.deephaven.server.runner; +import dagger.BindsInstance; +import dagger.Component; +import io.deephaven.engine.context.ExecutionContext; import io.deephaven.engine.updategraph.UpdateGraphProcessor; import io.deephaven.engine.liveness.LivenessScope; import io.deephaven.engine.liveness.LivenessScopeStack; import io.deephaven.io.logger.LogBuffer; import io.deephaven.io.logger.LogBufferGlobal; import io.deephaven.proto.DeephavenChannel; +import io.deephaven.server.console.NoConsoleSessionModule; +import io.deephaven.server.log.LogModule; import io.deephaven.util.SafeCloseable; import io.grpc.ManagedChannel; import io.grpc.ManagedChannelBuilder; @@ -17,17 +22,53 @@ import org.junit.Before; import org.junit.Rule; +import javax.inject.Named; +import javax.inject.Singleton; +import java.io.PrintStream; import java.util.concurrent.TimeUnit; /** * Manages a single instance of {@link DeephavenApiServer}. */ public abstract class DeephavenApiServerTestBase { + @Singleton + @Component(modules = { + DeephavenApiServerModule.class, + NoConsoleSessionModule.class, + ServerBuilderInProcessModule.class + }) + public interface TestComponent { + + DeephavenApiServer getServer(); + + ManagedChannelBuilder channelBuilder(); + + @Component.Builder + interface Builder { + + @BindsInstance + Builder withSchedulerPoolSize(@Named("scheduler.poolSize") int numThreads); + + @BindsInstance + Builder withSessionTokenExpireTmMs(@Named("session.tokenExpireMs") long tokenExpireMs); + + @BindsInstance + Builder withOut(@Named("out") PrintStream out); + + @BindsInstance + Builder withErr(@Named("err") PrintStream err); + + @BindsInstance + Builder withExecutionContext(ExecutionContext context); + + TestComponent build(); + } + } @Rule public final GrpcCleanupRule grpcCleanup = new GrpcCleanupRule(); - private DeephavenApiServerInProcessGroovyComponent serverComponent; + private TestComponent serverComponent; private LogBuffer logBuffer; private DeephavenApiServer server; private SafeCloseable scopeCloseable; @@ -40,8 +81,8 @@ public void setUp() throws Exception { logBuffer = new LogBuffer(128); LogBufferGlobal.setInstance(logBuffer); - serverComponent = DaggerDeephavenApiServerInProcessGroovyComponent - .builder() + serverComponent = DaggerDeephavenApiServerTestBase_TestComponent.builder() + .withExecutionContext(ExecutionContext.createForUnitTests()) .withSchedulerPoolSize(4) .withSessionTokenExpireTmMs(sessionTokenExpireTmMs()) .withOut(System.out) diff --git a/server/src/test/java/io/deephaven/server/session/SessionServiceTest.java b/server/src/test/java/io/deephaven/server/session/SessionServiceTest.java index 1c66173a101..8253f5527d6 100644 --- a/server/src/test/java/io/deephaven/server/session/SessionServiceTest.java +++ b/server/src/test/java/io/deephaven/server/session/SessionServiceTest.java @@ -4,6 +4,7 @@ package io.deephaven.server.session; import io.deephaven.base.verify.Assert; +import io.deephaven.engine.context.ExecutionContext; import io.deephaven.engine.liveness.LivenessScopeStack; import io.deephaven.engine.util.NoLanguageDeephavenSession; import io.deephaven.server.util.TestControlledScheduler; @@ -30,7 +31,7 @@ public void setup() { livenessScope = LivenessScopeStack.open(); scheduler = new TestControlledScheduler(); sessionService = new SessionService(scheduler, - authContext -> new SessionState(scheduler, NoLanguageDeephavenSession::new, authContext), + authContext -> new SessionState(scheduler, ExecutionContext::createForUnitTests, authContext), TOKEN_EXPIRE_MS, Optional.empty(), Collections.emptyMap()); } diff --git a/server/src/test/java/io/deephaven/server/session/SessionStateTest.java b/server/src/test/java/io/deephaven/server/session/SessionStateTest.java index 79eec750bd8..b576b5da6bf 100644 --- a/server/src/test/java/io/deephaven/server/session/SessionStateTest.java +++ b/server/src/test/java/io/deephaven/server/session/SessionStateTest.java @@ -5,6 +5,7 @@ import io.deephaven.base.verify.Assert; import io.deephaven.base.verify.AssertionFailure; +import io.deephaven.engine.context.ExecutionContext; import io.deephaven.engine.util.NoLanguageDeephavenSession; import io.deephaven.proto.util.ExportTicketHelper; import io.deephaven.server.table.ExportTableUpdateListenerTest; @@ -61,7 +62,7 @@ public void setup() { livenessScope = new LivenessScope(); LivenessScopeStack.push(livenessScope); scheduler = new TestControlledScheduler(); - session = new SessionState(scheduler, NoLanguageDeephavenSession::new, AUTH_CONTEXT); + session = new SessionState(scheduler, ExecutionContext::createForUnitTests, AUTH_CONTEXT); session.initializeExpiration(new SessionService.TokenExpiration(UUID.randomUUID(), DateTimeUtils.nanosToTime(Long.MAX_VALUE), session)); nextExportId = 1; @@ -637,7 +638,7 @@ public void testCannotOutOfOrderServerExports() { @Test public void testVerifyExpirationSession() { - final SessionState session = new SessionState(scheduler, NoLanguageDeephavenSession::new, AUTH_CONTEXT); + final SessionState session = new SessionState(scheduler, ExecutionContext::createForUnitTests, AUTH_CONTEXT); final SessionService.TokenExpiration expiration = new SessionService.TokenExpiration(UUID.randomUUID(), DateTimeUtils.nanosToTime(Long.MAX_VALUE), session); diff --git a/server/src/test/java/io/deephaven/server/table/ExportTableUpdateListenerTest.java b/server/src/test/java/io/deephaven/server/table/ExportTableUpdateListenerTest.java index cebddeded14..9a858f6cc0b 100644 --- a/server/src/test/java/io/deephaven/server/table/ExportTableUpdateListenerTest.java +++ b/server/src/test/java/io/deephaven/server/table/ExportTableUpdateListenerTest.java @@ -4,6 +4,7 @@ package io.deephaven.server.table; import io.deephaven.base.verify.Assert; +import io.deephaven.engine.context.ExecutionContext; import io.deephaven.engine.table.impl.TableUpdateImpl; import io.deephaven.engine.updategraph.UpdateGraphProcessor; import io.deephaven.engine.util.NoLanguageDeephavenSession; @@ -340,7 +341,7 @@ private void expectNoMessage() { public class TestSessionState extends SessionState { public TestSessionState() { - super(scheduler, NoLanguageDeephavenSession::new, AUTH_CONTEXT); + super(scheduler, ExecutionContext::createForUnitTests, AUTH_CONTEXT); initializeExpiration(new SessionService.TokenExpiration(UUID.randomUUID(), DateTimeUtils.nanosToTime(Long.MAX_VALUE), this)); }