Gitlab CI - 服务器在赛普拉斯测试运行之前被“杀死”

red*_* 87 5 javascript node.js gitlab cypress

我正在 Gitlab 中运行 CI 管道,它在测试阶段运行一些 Cypress 集成测试。这些测试在我的本地机器上运行得非常好,但是当我尝试在 Gitlab CI 中运行它们时,Gitlab 运行程序似乎在我可以针对它运行 Cypress 测试之前杀死了我的本地服务器。这是我的 Gitlab 配置:

variables:
  API_BASE_URL: https://t.local.um.io/api
  CYPRESS_API_BASE_URL: https://t.local.um.io/api
  npm_config_cache: '$CI_PROJECT_DIR/.npm'
  CYPRESS_CACHE_FOLDER: '$CI_PROJECT_DIR/cache/Cypress'

cache:
  paths:
    - node_modules/
    - cache/Cypress

stages:
  - install
  - build
  - tests

install:
  image: cypress/browsers:node14.15.0-chrome86-ff82
  stage: install
  cache:
    key: 'e2eDeps'
    paths:
      - node_modules/
      - cache/Cypress/
  script:
    - npm ci

build:
  stage: build
  dependencies:
    - install
  script:
    - npm run build
  artifacts:
    expire_in: 1 days
    when: on_success

tests:
  image: cypress/browsers:node14.15.0-chrome86-ff82
  stage: tests
  script:
    - npm ci
    - npm run test:ci
Run Code Online (Sandbox Code Playgroud)

以下是package.json上述配置在 CI 中运行的相关脚本:

  "scripts": {
    "build": "webpack --config webpack.prod.js",
    "dev": "webpack serve --config webpack.dev.js",
    "start:ci": "export NODE_OPTIONS=--max_old_space_size=4096 serve dist --no-clipboard --listen ${PORT:-3000}",
    "test": "cross-env NODE_ENV=test && npm run test:cypress && npm run test:jest",
    "test:ci": "cross-env NODE_ENV=test && start-server-and-test start:ci http-get://localhost:3000 test",
    "test:cypress": "cypress run --headless --browser chrome",
    "test:jest": "jest",
  },
Run Code Online (Sandbox Code Playgroud)

tests这是目前失败的最后阶段。这是 Gitlab 运行程序的控制台输出,您可以看到它在哪里显示“killed”,然后显示“err no 137”,它似乎只是停止了start:ci运行我的本地服务器的进程,以便可以针对它们运行集成测试。

在此输入图像描述

最后这是我的测试的一小段,我使用的命令在cy.visit服务器被终止时永远不会响应:

describe('Code entry page - API responses are managed correctly', () => {
  beforeEach(() => {
    cy.visit(routes.APP.HOME); // this just times out
  });
...
Run Code Online (Sandbox Code Playgroud)

编辑 我尝试在本地使用()的完全相同的docker容器cypress/browsers:node14.15.0-chrome86-ff82(不在gitlabci中)中运行test:ci脚本,并且它工作没有问题。问题肯定出在Gitlab上吧?

Pat*_*ick 1

错误 137 通常意味着您的 Docker 容器由于没有足够的资源而被终止。正如我在评论中提到的,您当前的容器正在使用 4GB 内存运行。由于您没有tag在 CI/CD 中定义密钥,因此您可能在 GitLab 的Linux 运行器云上运行,该云使用n1-standard-1GCP 上的实例运行,该实例的 RAM 限制为 3.75 GB。本质上,一旦您的测试容器启动,它就会立即消耗运行器上的所有可用内存,并且您的容器将被终止。

要解决内存限制,您必须运行自己的 gitlab-runner。无法在共享运行器云上使用更多内存来运行。您可以通过在本地计算机上启动 gitlab-runner 来相当轻松地进行测试(请参阅此处有关安装 gitlab 运行程序的说明)。安装运行程序后,将运行程序注册到标签high-memory,然后在最后一个作业中使用以下语法更新 CI/CD 以使用该标签:

tests:
  image: cypress/browsers:node14.15.0-chrome86-ff82
  stage: tests
  tags:
    - high-memory
  script:
    - npm ci
    - npm run test:ci
Run Code Online (Sandbox Code Playgroud)

您的作业可以使用与运行程序分配的内存一样多的内存。如果您的机器有 8Gb 内存,则作业将被允许使用最多 8Gb 内存。

如果您的计算机本身没有足够的内存,您始终可以临时启动具有足够内存的云实例。例如,您可以尝试使用 16GB 内存的数字海洋水滴,费用为 0.11c/小时。这将允许您运行一个实例几个小时来测试解决方案,然后再确定什么是长期可行的。