在 gitlab CI 中运行 plotly dash selenium 测试
2021-04-23
1024
因此,我尝试在 GitLab ci 管道中实现 selenium 测试。目前,我已经在本地系统上运行了这些测试,以镜像管道内将要发生的测试方法,即,我在本地系统上构建了测试,然后尝试连接到 selenium/standalone-chrome 实例以使用此命令运行测试
python3 -m pytest --junitxml=report.xml --log-cli-level DEBUG --webdriver Chrome --headless --remote-url http://localhost:4444/wd/hub testing/
这在我的本地机器上正常运行。当尝试使用 gitlab-ci.yml
stages:
- test
image: "python"
services:
- selenium/standalone-chrome
test:
stage: test
tags:
- docker
services:
- selenium/standalone-chrome:latest
script:
# Set environmental variables
- DEV_DASHBOARD_CFG='./app/config.json'
- apt-get update -qy
- apt-get install -y xvfb zip wget ca-certificates
- apt-get install -y libnss3-dev libasound2 libxss1 libappindicator3-1 libindicator7 gconf-service libgconf-2-4 libpango1.0-0 xdg-utils fonts-liberation libgbm1
# Setup the application to run
- apt-get install -y python-dev python-pip
- pip install -r requirements.txt
- cd app/
- pwd
- python3 -m pytest --junitxml=report.xml --log-cli-level DEBUG --webdriver Chrome -headless --remote-url http://selenium__standalone-chrome:4444/wd/hub testing/
artifacts:
when: always
reports:
junit: report.xml
我面临的这个问题是,似乎 chromium web 驱动程序存在错误。
---------------------------- Captured stdout call -----------------------------
Dash is running on http://127.0.0.1:8050/
Dash is running on http://127.0.0.1:8050/
Dash is running on http://127.0.0.1:8050/
Dash is running on http://127.0.0.1:8050/
Dash is running on http://127.0.0.1:8050/
Dash is running on http://127.0.0.1:8050/
2021-04-23 14:27:21,034 | dash - INFO: Dash is running on http://127.0.0.1:8050/
* Serving Flask app "app.app" (lazy loading)
* Environment: production
WARNING: This is a development server. Do not use it in a production deployment.
Use a production WSGI server instead.
* Debug mode: off
2021-04-23 14:27:21,051 | _internal - INFO: * Running on http://127.0.0.1:8050/ (Press CTRL+C to quit)
2021-04-23 14:27:21,164 | dashboard - INFO: Serving layout...
2021-04-23 14:27:21,166 | app_cache - DEBUG: retrieving from cache: select distinct country from results
2021-04-23 14:27:21,183 | _internal - INFO: 127.0.0.1 - - [23/Apr/2021 14:27:21] "GET / HTTP/1.1" 200 -
------------------------------ Captured log call -------------------------------
INFO app.app:dash.py:1714 Dash is running on http://127.0.0.1:8050/
INFO werkzeug:_internal.py:113 * Running on http://127.0.0.1:8050/ (Press CTRL+C to quit)
INFO werkzeug:_internal.py:113 127.0.0.1 - - [23/Apr/2021 14:27:21] "GET / HTTP/1.1" 200 -
--------------------------- Captured stdout teardown ---------------------------
2021-04-23 14:27:23,110 | _internal - INFO: 127.0.0.1 - - [23/Apr/2021 14:27:23] "GET /_stop-adc0916c7cdb4b169e4eeb4c3f3f532e HTTP/1.1" 200 -
---------------------------- Captured log teardown -----------------------------
INFO werkzeug:_internal.py:113 127.0.0.1 - - [23/Apr/2021 14:27:23] "GET /_stop-adc0916c7cdb4b169e4eeb4c3f3f532e HTTP/1.1" 200 -
_______________________________ test_tab_styles ________________________________
dash_duo = <dash.testing.composite.DashComposite object at 0x7f14d260f610>
def test_tab_styles(dash_duo):
> dash_duo.start_server(app)
testing/test_db_tabs.py:28:
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _
/usr/local/lib/python3.9/site-packages/dash/testing/composite.py:16: in start_server
self.server_url = self.server.url
/usr/local/lib/python3.9/site-packages/dash/testing/browser.py:601: in server_url
self.wait_for_page()
/usr/local/lib/python3.9/site-packages/dash/testing/browser.py:341: in wait_for_page
self.driver.get(self.server_url if url is None else url)
/usr/local/lib/python3.9/site-packages/selenium/webdriver/remote/webdriver.py:333: in get
self.execute(Command.GET, {'url': url})
/usr/local/lib/python3.9/site-packages/selenium/webdriver/remote/webdriver.py:321: in execute
self.error_handler.check_response(response)
_ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _ _
self = <selenium.webdriver.remote.errorhandler.ErrorHandler object at 0x7f14d260fdc0>
response = {'status': 500, 'value': '{"value":{"error":"unknown error","message":"unknown error: net::ERR_CONNECTION_REFUSED\\n (Session info: chrome=90.0.4430.85)","stacktrace":"#0 0x563f07a8ee89 \\u003Cunknown>\\n"}}'}
2个回答
在尝试在 gitlab CI 中实现一些 plotly dash 测试时,我遇到了与上述完全相同的问题和错误消息。最后终于让它工作了,与 OP 的主要区别是在这些容器中使用 docker compose,而不是直接在 gitlab.ci.yml 中编写脚本:
-
dash-test 容器,带有
entrypoint: pytest -v --remote --log-cli-level DEBUG
,以及network_mode: host
-
selenium-grid 容器,带有
image: selenium/standalone-chrome
和network_mode: host
在上述设置之前,我创建了一个 docker 网络,并在 dash-test 容器上公开了端口 8050,在 selenium-grid 容器上公开了端口 4444。那时我收到了
ERR_CONNECTION_REFUSED
错误。我怀疑此设置的问题(也可能是 gitlab ci 中发生的问题)是这样的:
-
dash-test 容器可以使用
--remote-url http://selenium-grid:4444/wd/hub
访问 selenium-grid,因此 selenium 测试开始运行 -
但是,dash 测试库已硬编码
http://localhost:8050/
(p.s. dash 维护者,这绝对应该更改并使其可配置),当测试运行时,selenium-grid 容器无法访问它。修改 docker-compose 文件以使用network_mode: host
后,由于容器现在正在使用主机的网络,因此可以访问它。
docker-compose.yaml:
version: '3.7'
services:
dash-test:
image: "dash-test"
build:
context: ..
dockerfile: docker/Dockerfile
target: test
entrypoint: pytest -v --remote --log-cli-level DEBUG -k bsly001
network_mode: host
depends_on:
selenium-grid:
condition: service_healthy
mem_limit: 4096m
volumes:
- ../config:/app/config
- ../dash_playground:/app/dash_playground
- ../qa_reports:/app/qa_reports
selenium-grid:
image: selenium/standalone-chrome
shm_size: 2gb
network_mode: host
healthcheck:
test: /opt/bin/check-grid.sh --host 0.0.0.0 --port 4444
interval: 5s
timeout: 30s
retries: 30
K Chen
2022-04-25
您的 Gitlab 运行器应该可以访问您尝试从 Gitlab CI 运行的应用程序。根据错误,很明显 Gitlab 运行器无法连接到应用程序 URL。
因此,请检查并确认 Gitlab 运行器是否可以访问主机。
Arjun
2021-04-27