Мы пытаемся запустить testcafe сквозные тесты на BrowserStack , инициированные заданием CI gitlab. Однако мы видим ошибку:
Error: spawn /home/user/.browserstack/BrowserStackLocal ENOENT
Мы следуем Вариант 1 - использовать TestCafe Docker Image https://devexpress.github.io/testcafe/documentation/continuous-integration/gitlab.html, который добавляет сквозное тестовое задание в наш файл .gitlab-ci.yml
. Мы создали базу данных .base_e2e
, которая используется в работе e2e_dev
(см. Ниже)
Мы также используем testcafe-browser-provider-browserstack
npm , которая позволяет выполнять наши конечные тесты testcafe в BrowserStack, как упомянуто здесь https://devexpress.github.io/testcafe/documentation/using-testcafe/common-concepts/browsers/browser-support.html#browsers-in-cloud-testing-services
Это копия ошибки задания CI gitlab:
Running with gitlab-runner 11.7.0 (8bb608ff)
on ec2-docker-runner 1c5ac6dc
Using Docker executor with image testcafe/testcafe ...
Pulling docker image testcafe/testcafe ...
Using docker image sha256:f4d0d6abb93c9 for testcafe/testcafe ...
Running on runner-1c5ac6dc-project-7261073-concurrent-0 via ip-10-250-5-194...
Fetching changes...
Removing build/
Removing coverage/
Removing node_modules/
Removing stats.json
HEAD is now at 8574401 Add space before script property
Checking out 8574401c as feature/e2e-on-pipeline...
Skipping Git submodules setup
Downloading artifacts for install_dependencies (150115951)...
Downloading artifacts from coordinator... ok id=150115951 responseStatus=200 OK token=yMPpwZa1
Downloading artifacts for test (150115953)...
Downloading artifacts from coordinator... ok id=150115953 responseStatus=200 OK token=pjsisESV
Downloading artifacts for build_dev (150115954)...
Downloading artifacts from coordinator... ok id=150115954 responseStatus=200 OK token=6hsG8sxx
$ /opt/testcafe/docker/testcafe-docker.sh "browserstack:Chrome@53.0:Windows 10" tests/e2e
Using locally installed version of TestCafe.
Error while trying to execute binary { Error: spawn /home/user/.browserstack/BrowserStackLocal ENOENT
at Process.ChildProcess._handle.onexit (internal/child_process.js:232:19)
at onErrorNT (internal/child_process.js:407:16)
at process._tickCallback (internal/process/next_tick.js:63:19)
errno: 'ENOENT',
code: 'ENOENT',
syscall: 'spawn /home/user/.browserstack/BrowserStackLocal',
path: '/home/user/.browserstack/BrowserStackLocal',
spawnargs:
[ '--daemon',
'start',
'--log-file',
'/dev/null',
'--key',
'nyyp6nnWiL2S6Y7HkvrH',
'--local-identifier',
1548265103368,
'--enable-logging-for-api' ],
cmd:
'/home/user/.browserstack/BrowserStackLocal --daemon start --log-file /dev/null --key nyyp6nnWiL2S6Y7HkvrH --local-identifier 1548265103368 --enable-logging-for-api' }
Полный .gitlab-ci.yml
Файл
image: node:8-alpine
stages:
- e2e
#############
# Job Bases #
#############
.base_e2e:
stage: e2e
image:
name: testcafe/testcafe
entrypoint: ["/bin/sh", "-c"]
script:
- /opt/testcafe/docker/testcafe-docker.sh "browserstack:Chrome@53.0:Windows 10" tests/e2e
#############
# Jobs #
#############
e2e_dev:
extends: .base_e2e
variables:
ENVIRONMENT: dev
TEST_E2E_APP_URL: https://$ENVIRONMENT.example.com
only:
- /^feature/.*$/
- /^fix/.*$/
- /^bug/.*$/
when: manual
Дополнительная информация
Когда мы запускаем следующую команду yarn, т. Е. yarn test:e2e_pipeline
, выполняется сквозной тест и без проблем записывается видеозапись автоматизации, загруженной в BrowserStack.
"scripts": {
"test:e2e_all": "testcafe 'chrome,firefox' tests/e2e",
"test:e2e_pipeline": "testcafe 'browserstack:Chrome@53.0:Windows 10' tests/e2e"
},
У нас есть следующие devDependencies внутри нашего package.json
"devDependencies": {
"testcafe": "^0.23.3",
"testcafe-browser-provider-browserstack": "^1.7.0",
}