Package io.ebean.test.containers
Class LocalDynamoDBContainer
java.lang.Object
io.ebean.test.containers.LocalDynamoDBContainer
- All Implemented Interfaces:
Container<LocalDynamoDBContainer>
Container using amazon/dynamodb-local.
LocalDynamoDBContainer container = LocalDynamoDBContainer.builder"1.13.2")
//.port(8001)
//.containerName("ut_dynamodb")
//.image("amazon/dynamodb-local:1.13.2")
.build();
// start the container (if not already started)
container.start();
// obtain the AWS DynamoDB client
AmazonDynamoDB amazonDynamoDB = container.dynamoDB();
createTableIfNeeded(amazonDynamoDB);
// container will be shutdown and removed via shutdown hook
// local devs touch ~/.ebean/ignore-docker-shutdown
// to keep the container running for faster testing etc
Shutdown
By default, the container will be shutdown and removed via shutdown hook
Local development
For local development we typically want to keep the container running such that tests are fast to run. To do this:
touch ~/.ebean/ignore-docker-shutdown
-
Nested Class Summary
Nested Classes -
Field Summary
Fields -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionCreate a builder for LocalDynamoDBContainer given the localstack image version.booleanconfig()Returns the container configuration.protected ProcessBuildercreateProcessBuilder(List<String> args) com.amazonaws.services.dynamodbv2.AmazonDynamoDBdynamoDB()Return the AmazonDynamoDB that can be used for this container.Return the endpoint URL that can be used to connect to this container.booleanReturn true if the container is running.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 returning true if successful.voidStart the container or throw a IllegalStateException.protected booleanvoidstop()Stop using the configured stopMode of 'stop' or 'remove'.voidStop and remove the container effectively deleting the container.
-
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
-
-
Constructor Details
-
LocalDynamoDBContainer
-
-
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 LocalDynamoDBContainer given the localstack image version. -
endpointUrl
Return the endpoint URL that can be used to connect to this container. -
dynamoDB
public com.amazonaws.services.dynamodbv2.AmazonDynamoDB dynamoDB()Return the AmazonDynamoDB that can be used for this container.This should be used AFTER the container is started.
-
checkConnectivity
public boolean checkConnectivity() -
runProcess
Return the ProcessBuilder used to execute the container run command. -
config
Description copied from interface:ContainerReturns the container configuration. -
startMaybe
public boolean startMaybe()Description copied from interface:ContainerStart the container returning true if successful.- Specified by:
startMaybein interfaceContainer<C extends Container<C>>
-
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
-