Package io.ebean.test.containers
Class SqlServerContainer
java.lang.Object
io.ebean.test.containers.SqlServerContainer
- All Implemented Interfaces:
Container<SqlServerContainer>
Commands for controlling a SqlServer docker container.
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic classBuilder for SqlServerContainer. -
Field Summary
Fields -
Method Summary
Modifier and TypeMethodDescriptionstatic SqlServerContainer.BuilderCreate a builder for SqlServerContainer.protected booleanconfig()Returns the container configuration.Create a connection to this database container.protected ProcessBuildercreateProcessBuilder(List<String> args) protected voidexecuteSqlFile(String dbUser, String dbName, String containerFilePath) protected booleanIf we are using FastStartMode just check is the DB exists and if so assume it is all created correctly.protected booleanReturn true when the database is ready to take admin commands.protected booleanReturn true when the database is ready to take commands.protected booleanbooleanReturn true if the container is running.jdbcUrl()Return the JDBC url to connect to this container.static SqlServerContainer.BuildernewBuilder(String version) Deprecated.intport()Return the port this container is using.protected StringreadUrlContent(String url) Return http GET content given the url.voidRegister a JVM Shutdown hook to stop the container with the given mode.protected ProcessBuilderReturn the ProcessBuilder used to execute the container run command.protected voidSet a default container name if not using random port.protected booleanshutdownHook(boolean started) start()Start and return the container.booleanStart the container only without creating database, user, extensions etc.protected booleanStart with a mode of 'create', 'dropCreate' or 'container'.booleanStart the container returning true if successful.voidStart the container or throw a IllegalStateException.protected booleanbooleanStart the DB container ensuring the DB and user exist creating them if necessary.booleanStart the DB container ensuring the DB and user are dropped and then created.voidstop()Stop using the configured stopMode of 'stop' or 'remove'.voidStop and remove the container effectively deleting the container.booleanReturn true when the DB is ready for taking commands (like create database, user etc).
-
Field Details
-
buildConfig
protected final io.ebean.test.containers.BaseBuilder<?,?> buildConfig -
config
protected io.ebean.test.containers.InternalConfig config -
commands
-
waitForConnectivityAttempts
protected int waitForConnectivityAttempts -
shutdownMode
-
usingContainerId
protected boolean usingContainerId -
usingRandomPort
protected boolean usingRandomPort -
removeOnExit
protected boolean removeOnExit
-
-
Method Details
-
start
Description copied from interface:ContainerStart and return the container.Throws an IllegalStateException if the container can not be started.
-
builder
Create a builder for SqlServerContainer. -
newBuilder
Deprecated.Deprecated - migrate to builder(). -
runProcess
Return the ProcessBuilder used to execute the container run command. -
startWithCreate
public boolean startWithCreate()Start the DB container ensuring the DB and user exist creating them if necessary. -
startWithDropCreate
public boolean startWithDropCreate()Start the DB container ensuring the DB and user are dropped and then created. -
checkAlreadyRunning
protected boolean checkAlreadyRunning() -
waitForDatabaseReady
public boolean waitForDatabaseReady()Return true when the DB is ready for taking commands (like create database, user etc). -
isDatabaseReady
protected boolean isDatabaseReady()Return true when the database is ready to take commands. -
isDatabaseAdminReady
protected boolean isDatabaseAdminReady()Return true when the database is ready to take admin commands. -
jdbcUrl
Return the JDBC url to connect to this container. -
createConnection
Create a connection to this database container.- Throws:
SQLException
-
startMaybe
public boolean startMaybe()Description copied from interface:ContainerStart the container returning true if successful.- Specified by:
startMaybein interfaceContainer<C extends io.ebean.test.containers.DbContainer<C>>
-
startForMode
protected boolean startForMode()Start with a mode of 'create', 'dropCreate' or 'container'.Expected that mode create will be best most of the time.
-
startContainerOnly
public boolean startContainerOnly()Start the container only without creating database, user, extensions etc. -
fastStart
protected boolean fastStart()If we are using FastStartMode just check is the DB exists and if so assume it is all created correctly.This should only be used with Mode.Create and when the container is already running.
-
isFastStartDatabaseExists
protected boolean isFastStartDatabaseExists() -
executeSqlFile
-
config
Description copied from interface:ContainerReturns the container configuration. -
startOrThrow
public void startOrThrow()Description copied from interface:ContainerStart the container or throw a IllegalStateException.- Specified by:
startOrThrowin interfaceContainer<C extends Container<C>>
-
port
public int port()Description copied from interface:ContainerReturn the port this container is using.This is typically useful if the container was started with a random port and, we need to know what that port was.
-
setDefaultContainerName
protected void setDefaultContainerName()Set a default container name if not using random port. -
isRunning
public boolean isRunning()Description copied from interface:ContainerReturn true if the container is running. -
registerShutdownHook
public void registerShutdownHook()Register a JVM Shutdown hook to stop the container with the given mode. -
shutdownHook
protected boolean shutdownHook(boolean started) -
startWithConnectivity
protected boolean startWithConnectivity() -
stop
public void stop()Stop using the configured stopMode of 'stop' or 'remove'.Remove additionally removes the container (expected use in build agents).
-
stopRemove
public void stopRemove()Stop and remove the container effectively deleting the container.- Specified by:
stopRemovein interfaceContainer<C extends Container<C>>
-
createProcessBuilder
-
dockerRun
-
readUrlContent
Return http GET content given the url.- Throws:
IOException
-