本文整理汇总了Java中org.testcontainers.containers.GenericContainer类的典型用法代码示例。如果您正苦于以下问题:Java GenericContainer类的具体用法?Java GenericContainer怎么用?Java GenericContainer使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
GenericContainer类属于org.testcontainers.containers包,在下文中一共展示了GenericContainer类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。
示例1: simpleRecursiveFileTest
import org.testcontainers.containers.GenericContainer; //导入依赖的package包/类
@Test
public void simpleRecursiveFileTest() throws TimeoutException {
WaitingConsumer wait = new WaitingConsumer();
final ToStringConsumer toString = new ToStringConsumer();
GenericContainer container = new GenericContainer(
new ImageFromDockerfile()
.withDockerfileFromBuilder(builder ->
builder.from("alpine:3.3")
.copy("/tmp/foo", "/foo")
.cmd("cat /foo/src/test/resources/test-recursive-file.txt")
.build()
).withFileFromFile("/tmp/foo", new File("."))) // '.' is expected to be the project base directory, so all source code/resources should be copied in
.withStartupCheckStrategy(new OneShotStartupCheckStrategy())
.withLogConsumer(wait.andThen(toString));
container.start();
wait.waitUntilEnd(60, TimeUnit.SECONDS);
final String results = toString.toUtf8String();
assertTrue("The container has a file that was copied in via a recursive copy", results.contains("Used for DirectoryTarResourceTest"));
}
示例2: whenDockerClientCantBeCreatedAnAssumptionExceptionIsThrown
import org.testcontainers.containers.GenericContainer; //导入依赖的package包/类
@Test
public void whenDockerClientCantBeCreatedAnAssumptionExceptionIsThrown() throws NoSuchMethodException, NoSuchFieldException, IllegalAccessException, InvocationTargetException {
destroyDockerClientFactoryInstance();
GenericContainerRule genericContainerRule = new GenericContainerRule(() -> new GenericContainer()).assumeDockerIsPresent();
boolean assumptionExceptionOccurred = false;
try {
genericContainerRule.apply(null,null).evaluate();
} catch (AssumptionViolatedException ave) {
assumptionExceptionOccurred = true;
} catch (Throwable throwable) {
throwable.printStackTrace();
} finally {
unDestroyDockerClientFactoryInstance();
}
assertThat(assumptionExceptionOccurred).isTrue().as("AssumptionException was thrown");
}
示例3: configureArquillianForRemoteWildfly
import org.testcontainers.containers.GenericContainer; //导入依赖的package包/类
private void configureArquillianForRemoteWildfly(GenericContainer dockerContainer, ContainerRegistry registry) {
Integer wildflyHttpPort = dockerContainer.getMappedPort(WILDFLY_HTTP_PORT);
Integer wildflyManagementPort = dockerContainer.getMappedPort(WILDFLY_MANAGEMENT_PORT);
String containerIpAddress = dockerContainer.getContainerIpAddress();
Container arquillianContainer = registry.getContainers().iterator().next();
ContainerDef containerConfiguration = arquillianContainer.getContainerConfiguration();
containerConfiguration.property(ContainerConfiguration.MANAGEMENT_ADDRESS_KEY, containerIpAddress);
containerConfiguration.property(ContainerConfiguration.MANAGEMENT_PORT_KEY,
String.valueOf(wildflyManagementPort));
containerConfiguration.property(ContainerConfiguration.USERNAME_KEY, "admin");
containerConfiguration.property(ContainerConfiguration.PASSWORD_KEY, "Admin#007");
ProtocolDef protocolConfiguration = arquillianContainer
.getProtocolConfiguration(new ProtocolDescription(ServletProtocolDefinition.NAME));
protocolConfiguration.property(ServletProtocolDefinition.HOST_KEY, containerIpAddress);
protocolConfiguration.property(ServletProtocolDefinition.PORT_KEY, String.valueOf(wildflyHttpPort));
}
示例4: compute
import org.testcontainers.containers.GenericContainer; //导入依赖的package包/类
@Override protected ElasticsearchHttpStorage compute() {
try {
container = new GenericContainer(image)
.withExposedPorts(9200)
.withEnv("ES_JAVA_OPTS", "-Dmapper.allow_dots_in_name=true -Xms512m -Xmx512m")
.waitingFor(new HttpWaitStrategy().forPath("/"));
container.start();
if (Boolean.valueOf(System.getenv("ES_DEBUG"))) {
container.followOutput(new Slf4jLogConsumer(LoggerFactory.getLogger(image)));
}
System.out.println("Starting docker image " + image);
} catch (RuntimeException e) {
// Ignore
}
ElasticsearchHttpStorage result = computeStorageBuilder().build();
CheckResult check = result.check();
if (check.ok()) {
return result;
} else {
throw new AssumptionViolatedException(check.error().getMessage(), check.error());
}
}
示例5: ParameterizedDockerfileContainerTest
import org.testcontainers.containers.GenericContainer; //导入依赖的package包/类
public ParameterizedDockerfileContainerTest(String baseImage, String expectedVersion) {
container = new GenericContainer(new ImageFromDockerfile().withDockerfileFromBuilder(builder -> {
builder
.from(baseImage)
// Could potentially customise the image here, e.g. adding files, running
// commands, etc.
.build();
})).withCommand("top");
this.expectedVersion = expectedVersion;
}
开发者ID:testcontainers,项目名称:testcontainers-java,代码行数:11,代码来源:ParameterizedDockerfileContainerTest.java
示例6: createContainerCmdHookTest
import org.testcontainers.containers.GenericContainer; //导入依赖的package包/类
@Test
public void createContainerCmdHookTest() {
// Use random name to avoid the conflicts between the tests
String randomName = Base58.randomString(5);
try(
GenericContainer container = new GenericContainer<>("redis:3.0.2")
.withCommand("redis-server", "--help")
.withCreateContainerCmdModifier(cmd -> cmd.withName("overrideMe"))
// Preserves the order
.withCreateContainerCmdModifier(cmd -> cmd.withName(randomName))
// Allows to override pre-configured values by GenericContainer
.withCreateContainerCmdModifier(cmd -> cmd.withCmd("redis-server", "--port", "6379"))
) {
container.start();
assertEquals("Name is configured", "/" + randomName, container.getContainerInfo().getName());
assertEquals("Command is configured", "[redis-server, --port, 6379]", Arrays.toString(container.getContainerInfo().getConfig().getCmd()));
}
}
示例7: copyToContainerTest
import org.testcontainers.containers.GenericContainer; //导入依赖的package包/类
@Test
public void copyToContainerTest() throws Exception {
final File tempResultFolder = Files.createTempDir();
try (final GenericContainer alpineCopyToContainer = new GenericContainer("alpine:3.2")
.withCommand("top")){
alpineCopyToContainer.start();
final MountableFile mountableFile = MountableFile.forClasspathResource("test_copy_to_container.txt");
alpineCopyToContainer.copyFileToContainer(mountableFile, "/home/");
alpineCopyToContainer.copyFileFromContainer("/home/test_copy_to_container.txt",
tempResultFolder.getAbsolutePath() + "/test_copy_to_container.txt");
File expectedFile = new File(mountableFile.getResolvedPath());
File actualFile = new File(tempResultFolder.getAbsolutePath() + "/test_copy_to_container.txt");
assertTrue("Files aren't same ", FileUtils.contentEquals(expectedFile,actualFile));
}
}
示例8: shouldCopyFileFromContainerTest
import org.testcontainers.containers.GenericContainer; //导入依赖的package包/类
@Test
public void shouldCopyFileFromContainerTest() throws IOException, InterruptedException {
final File tempResultFolder = Files.createTempDir();
try (final GenericContainer alpineCopyToContainer = new GenericContainer("alpine:3.2")
.withCommand("top")) {
alpineCopyToContainer.start();
final MountableFile mountableFile = MountableFile.forClasspathResource("test_copy_to_container.txt");
alpineCopyToContainer.copyFileToContainer(mountableFile, "/home/");
alpineCopyToContainer.copyFileFromContainer("/home/test_copy_to_container.txt",
tempResultFolder.getAbsolutePath() + "/test_copy_from_container.txt");
File expectedFile = new File(mountableFile.getResolvedPath());
File actualFile = new File(tempResultFolder.getAbsolutePath() + "/test_copy_from_container.txt");
assertTrue("Files aren't same ", FileUtils.contentEquals(expectedFile,actualFile));
}
}
示例9: testFixedHostPortMapping
import org.testcontainers.containers.GenericContainer; //导入依赖的package包/类
@Test
public void testFixedHostPortMapping() throws IOException {
// first find a free port on the docker host that will work for testing
GenericContainer portDiscoveryRedis = new GenericContainer("redis:3.0.2").withExposedPorts(REDIS_PORT);
portDiscoveryRedis.start();
Integer freePort = portDiscoveryRedis.getMappedPort(REDIS_PORT);
portDiscoveryRedis.stop();
// Set up a FixedHostPortGenericContainer as if this were a @Rule
FixedHostPortGenericContainer redis = new FixedHostPortGenericContainer("redis:3.0.2").withFixedExposedPort(freePort, REDIS_PORT);
redis.start();
// Config redisConfig = new Config();
// redisConfig.useSingleServer().setAddress(redis.getContainerIpAddress() + ":" + freePort);
// Redisson redisson = Redisson.create(redisConfig);
//
// redisson.getBucket("test").set("foo");
//
// assertEquals("The bucket content was successfully set", "foo", redisson.getBucket("test").get());
// assertEquals("The container returns the fixed port from getMappedPort(...)", freePort, redis.getMappedPort(REDIS_PORT));
}
示例10: redisContainer
import org.testcontainers.containers.GenericContainer; //导入依赖的package包/类
@Bean(initMethod = "start")
public GenericContainer redisContainer() {
return new GenericContainer(REDIS_DOCKER_IMAGE) {
@Override
public void close() {
super.close();
try {
this.dockerClient.close();
}
catch (IOException ignored) {
}
}
}.withExposedPorts(6379);
}
示例11: before
import org.testcontainers.containers.GenericContainer; //导入依赖的package包/类
@BeforeClass
void before() throws Exception {
String gitlabVersion = System.getenv("GITLAB_VERSION");
if (gitlabVersion == null)
gitlabVersion = "9.3.3-ce.0";
final int gitlabPort = 80;
gitlab = new GenericContainer<>("gitlab/gitlab-ce:" + gitlabVersion)
.withEnv("GITLAB_ROOT_PASSWORD", rootPassword)
.withExposedPorts(gitlabPort)
.waitingFor(Wait.forHttp("/users/sign_in")
.withStartupTimeout(Duration.of(10, ChronoUnit.MINUTES)));
gitlab.start();
gitlabUrl = "http://" + gitlab.getContainerIpAddress() + ":" + gitlab.getMappedPort(gitlabPort);
rootToken = createToken(root, rootPassword, true);
final GitlabAPI rootAPI = GitLabContext.connect(gitlabUrl, rootToken);
final GitlabUser gitlabUser = rootAPI.createUser("[email protected]", userPassword, user, user, null, null, null, null, null, null, null, null, false, null, true);
Assert.assertNotNull(gitlabUser);
final GitlabGroup group = rootAPI.createGroup("testGroup");
Assert.assertNotNull(group);
Assert.assertNotNull(rootAPI.addGroupMember(group.getId(), gitlabUser.getId(), GitlabAccessLevel.Developer));
gitlabProject = createGitlabProject(rootAPI, group, "test", false);
gitlabPublicProject = createGitlabProject(rootAPI, group, "publik", true);
}
示例12: startConsulTestContainer
import org.testcontainers.containers.GenericContainer; //导入依赖的package包/类
@BeforeClass
public static void startConsulTestContainer() {
consulContainer = new GenericContainer("quay.io/coreos/etcd:v3.2.4")
.withExposedPorts(2379)
.withCommand("etcd",
"--advertise-client-urls", "http://0.0.0.0:2379",
"--listen-client-urls", "http://0.0.0.0:2379"
);
consulContainer.start();
consulContainer.followOutput(new Slf4jLogConsumer(logger).withPrefix("etcd"));
}
示例13: readSecondSecretPathWithCli
import org.testcontainers.containers.GenericContainer; //导入依赖的package包/类
@Test
public void readSecondSecretPathWithCli() throws IOException, InterruptedException {
GenericContainer.ExecResult result = vaultContainer.execInContainer("vault",
"read", "secret/testing2");
String output = result.getStdout();
assertThat(output, containsString("password1"));
assertThat(output, containsString("password2"));
assertThat(output, containsString("password3"));
assertThat(output, containsString("password4"));
}
示例14: beforeClass
import org.testcontainers.containers.GenericContainer; //导入依赖的package包/类
@BeforeClass
public static void beforeClass() {
network = Network.newNetwork();
elasticsearch = new GenericContainer<>("docker.elastic.co/elasticsearch/elasticsearch:5.6.1")
.withNetwork(network)
.withNetworkAliases("elasticsearch")
.waitingFor(Wait.forHttp("/"))
.withExposedPorts(9200, 9300)
.withEnv("xpack.security.enabled", "false")
.withEnv("discovery.type", "single-node")
.withEnv("network.bind_host", "elasticsearch")
.withEnv("network.host", "_site_")
.withEnv("network.publish_host", "_local_");
elasticsearch.start();
jaegerCollector = new GenericContainer<>("jaegertracing/jaeger-collector:latest")
.withNetwork(network)
.withEnv("SPAN_STORAGE_TYPE", "elasticsearch")
.withEnv("ES_SERVER_URLS", "http://elasticsearch:9200")
.withEnv("COLLECTOR_ZIPKIN_HTTP_PORT", "9411")
.withEnv("COLLECTOR_QUEUE_SIZE", "100000")
.waitingFor(Wait.forHttp("/").forStatusCode(204))
// the first one is health check
.withExposedPorts(14269, 14268, 9411);
jaegerCollector.start();
jaegerQuery = new GenericContainer<>("jaegertracing/jaeger-query:latest")
.withEnv("SPAN_STORAGE_TYPE", "elasticsearch")
.withEnv("ES_SERVER_URLS", "http://elasticsearch:9200")
.withNetwork(network)
.waitingFor(Wait.forHttp("/").forStatusCode(204))
.withExposedPorts(16687, 16686);
jaegerQuery.start();
collectorUrl = String.format("http://%s:%d", jaegerCollector.getContainerIpAddress(), jaegerCollector.getMappedPort(14268));
zipkinCollectorUrl = String.format("http://%s:%d", jaegerCollector.getContainerIpAddress(), jaegerCollector.getMappedPort(9411));
queryUrl = String.format("http://%s:%d", jaegerQuery.getContainerIpAddress(), jaegerQuery.getMappedPort(16686));
}
示例15: afterClass
import org.testcontainers.containers.GenericContainer; //导入依赖的package包/类
@AfterClass
public static void afterClass() {
Optional.of(jaegerCollector).ifPresent(GenericContainer::close);
Optional.of(jaegerQuery).ifPresent(GenericContainer::close);
Optional.of(elasticsearch).ifPresent(GenericContainer::close);
Optional.of(network).ifPresent(Network::close);
}