testcontainers-node 无法在 Gitlab CI 上启动 ryuk

Posted

技术标签:

【中文标题】testcontainers-node 无法在 Gitlab CI 上启动 ryuk【英文标题】:testcontainers-node cannot start ruyk on GitlabCI 【发布时间】:2021-10-13 11:08:26 【问题描述】:

在 gitlab ci 上使用 testcontainers-node 通过 jest 运行 e2e 测试时遇到问题。

default:
  image: personal-registy/node:14-alpine3.12

services:
  - name: personal-registy/docker:19.03-dind
    alias: docker-dind
    entrypoint: ['dockerd']
    command: ['--host=tcp://0.0.0.0:2375']

variables:
  IMAGE: $REGISTRY_IMAGE:$CI_COMMIT_REF_NAME
  DOCKER_HOST: tcp://docker-dind:2375
  DOCKER_DRIVER: overlay2
  RYUK_CONTAINER_IMAGE: personal-regist/ruyk:0.3.2

stages:
  - Prepare
  - Tests

modules:
  stage: Prepare
  script:
    - npm ci --no-audit
  artifacts:
    paths:
      - node_modules/
    expire_in: 1 hour

test-e2e:
  stage: Tests
  before_script:
    - mkdir $HOME/.docker
    - echo $DOCKER_AUTH_CONFIG > $HOME/.docker/config.json
  after_script:
    - rm -rf $home/.docker
  dependencies:
    - modules
  script:
    - npm run test:e2e
  artifacts:
    expire_in: 1 day

第一步构建和准备用于测试的打字稿代码没有问题。但是在通过 npm 命令运行 C​​I 时,我在日志消息中得到了下一个堆栈跟踪:

Error: (HTTP code 409) container stopped/paused - Container d26dbb007bd42c3eb129e83db6253f3056fcc37294c84c4f00d13637bd451d6b is not running 
    at /builds/raif-capital/rcap-core-services/rc-operation-core/node_modules/docker-modem/lib/modem.js:315:17
    at getCause (/builds/raif-capital/rcap-core-services/rc-operation-core/node_modules/docker-modem/lib/modem.js:345:7)
    at Modem.buildPayload (/builds/raif-capital/rcap-core-services/rc-operation-core/node_modules/docker-modem/lib/modem.js:314:5)
    at IncomingMessage.<anonymous> (/builds/raif-capital/rcap-core-services/rc-operation-core/node_modules/docker-modem/lib/modem.js:286:14)
    at IncomingMessage.emit (events.js:327:22)
    at endReadableNT (internal/streams/readable.js:1327:12)
    at processTicksAndRejections (internal/process/task_queues.js:80:21) 
  reason: 'container stopped/paused',
  statusCode: 409,
  json: 
    message: 'Container d26dbb007bd42c3eb129e83db6253f3056fcc37294c84c4f00d13637bd451d6b is not running'
  

如果我通过 npm 在本地机器上开始测试,我运行测试没有问题。

【问题讨论】:

【参考方案1】:

我找到了解决办法。

由于访问 Docker 套接字时出现问题,Ryuk 无法启动。 我刚刚通过 env 在 CI 上禁用了 Ryuk:

variables:
   TESTCONTAINERS_RYUK_DISABLED: 'true'

在此之后我的测试成功完成。

【讨论】:

以上是关于testcontainers-node 无法在 Gitlab CI 上启动 ryuk的主要内容,如果未能解决你的问题,请参考以下文章

g ++错误无法识别的命令行选项

g++:错误:无法识别的命令行选项“-mt”

G++ 编译,可执行文件无法运行

g++: as 无法确定运行哪个汇编程序

无法在ubuntu 14.04.4 LTS上安装g ++(我试过命令和软件中心)

无法在 ubuntu 20.04 中安装 g++ 和 build-essentials