Run a dev server in CI pipleine(在配置项管道中运行开发服务器)
本文介绍了在配置项管道中运行开发服务器的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我有一个使用Github操作/工作流的CI管道设置,我想在其中运行Cypress Automated测试,但是我在如何运行我的开发服务器方面遇到了一些逻辑问题。让我带您看看我的管道
name: Nuxt CI Pipeline
on:
push:
branches: [ CI-pipeline ]
# pull_request:
# branches: [ master ]
jobs:
build:
runs-on: ubuntu-latest
strategy:
matrix:
node-version: [ 14.x ]
# See supported Node.js release schedule at https://nodejs.org/en/about/releases/
steps:
- uses: actions/checkout@v2
- name: Use Node.js ${{ matrix.node-version }}
uses: actions/setup-node@v2
with:
node-version: ${{ matrix.node-version }}
cache: 'npm'
- name: Make envfile
uses: SpicyPizza/create-envfile@v1
with:
envkey_ENV: staging
file_name: .env
- run: npm ci
- run: npm run dev
- run: |
cd e2e
ls -l
npm ci
npx cypress run
现在,我想启动devserver并在该端口(通常为3000)上运行测试,但是问题是,当执行命令npm run dev
时,管道一直在那里等待,没有向前移动,这是有意义的,因为devserver不像其他命令那样返回响应,所以它有点停留在那里。我对devops的了解非常有限,有人能指出我遗漏了什么吗?
推荐答案
我觉得执行的方式不太理想,特别是这样节点服务器最后也没有被正确杀死。使用像start-server-and-test这样的帮助器包应该可以帮您做到这一点:
npm install --save-dev start-server-and-test
虽然我不确定package.json
中脚本背后的确切内容,但最终可能如下所示:
"scripts": {
"start:ci": "<<start your dev server>>",
"cy:run": "cypress run --browser chrome --headless",
"cy:ci": "start-server-and-test start:ci http://localhost:3000 cy:run"
},
然后,您只需使用npm run cy:ci
在您的管道中将其作为单个命令运行即可。该脚本将负责启动开发服务器,等待URL可用,然后执行测试,并在所有测试完成后关闭服务器。
这篇关于在配置项管道中运行开发服务器的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:在配置项管道中运行开发服务器
基础教程推荐
猜你喜欢
- 响应更改 div 大小保持纵横比 2022-01-01
- 当用户滚动离开时如何暂停 youtube 嵌入 2022-01-01
- 角度Apollo设置WatchQuery结果为可用变量 2022-01-01
- 动态更新多个选择框 2022-01-01
- 在for循环中使用setTimeout 2022-01-01
- 悬停时滑动输入并停留几秒钟 2022-01-01
- 我什么时候应该在导入时使用方括号 2022-01-01
- 有没有办法使用OpenLayers更改OpenStreetMap中某些要素 2022-09-06
- Karma-Jasmine:如何正确监视 Modal? 2022-01-01
- 在 JS 中获取客户端时区(不是 GMT 偏移量) 2022-01-01