使用 Testcontainers 执行运行集成测试的 Gitlab CI 管道作业时出现问题

Posted

技术标签:

【中文标题】使用 Testcontainers 执行运行集成测试的 Gitlab CI 管道作业时出现问题【英文标题】:Issue when executing Gitlab CI pipeline job running integration test with Testcontainers 【发布时间】:2019-09-05 12:57:18 【问题描述】:

我有一个 Spring Boot 应用程序测试,它使用 TestContainers (https://www.testcontainers.org) 对 KafkaContainer 运行一些集成测试。在本地运行时一切都很好,但是在 GitlabCI 管道中运行集成测试时,容器无法启动。这里是工作日志:

> org.testcontainers.containers.ContainerLaunchException: Container
> startup failed Caused by:
> org.rnorth.ducttape.RetryCountExceededException: Retry limit hit with
> exception Caused by:
> org.testcontainers.containers.ContainerLaunchException: Could not
> create/start container Caused by:
> org.testcontainers.containers.ContainerLaunchException: Timed out
> waiting for container port to open (docker ports: [32776, 32778]
> should be listening)

这里是 Gitlab CI conf:

image: docker:git
services:
  - docker:dind

stages:
  - test
  - push
  - deploy

variables:
  MAVEN_CLI_OPTS: "--batch-mode -Dmaven.repo.local=/.m2"
  DOCKER_HOST: "tcp://docker:2375"
  DOCKER_DRIVER: overlay2

.test_template: &java_test
  image: maven:3.5.3-jdk-8
  stage: test
  tags:
    - test

 myapp-api_test:
   <<: *java_test
   services:
     - docker:dind
   variables:
     DOCKER_HOST: "tcp://docker:2375"
     DOCKER_DRIVER: overlay2
   script:
    - cd myapp-api
    - mvn $MAVEN_CLI_OPTS package

在这里亚军会议:

executor = "docker"
  [runners.docker]
    tls_verify = false
    image = "alpine:latest"
    privileged = true
    disable_entrypoint_overwrite = false
    oom_kill_disable = false
    disable_cache = false
    volumes = ["/cache", "/.m2", 
         "/var/run/docker.sock:/var/run/docker.sock"]
    shm_size = 0
    output_limit = 8192

有什么帮助吗? 谢谢

【问题讨论】:

【参考方案1】:

我知道你现在可能已经想通了,但给你一个答案以供将来参考,以防其他人发现自己遇到同样的问题。

我遇到了类似的问题,并通过为我的容器添加自定义等待策略和/或自定义超时来修复它。在我的机器上本地它可以正常工作,但在较慢的 gitlab.com 共享运行器上它会超时

Wait.forHttp("/health").withStartupTimeout(Duration.ofMinutes(5L))

【讨论】:

以上是关于使用 Testcontainers 执行运行集成测试的 Gitlab CI 管道作业时出现问题的主要内容,如果未能解决你的问题,请参考以下文章

java单元/集成测试中使用Testcontainers

使用 Testcontainers 进行 Dropwizard 集成测试

SpringBoot 集成测试 Sybase 和 Testcontainers

如何使用 TestContainers 创建 apache spark 独立集群以进行集成测试?

在 SpringBoot 中使用 Testcontainers 进行 Spring Data Elasticsearch 集成测试

使用 Testcontainers + Quarkus + MongoDB 进行集成测试