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可用,然后执行测试,并在所有测试完成后关闭服务器。
这篇关于在配置项管道中运行开发服务器的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:在配置项管道中运行开发服务器
猜你喜欢
- 如何调试 CSS/Javascript 悬停问题 2022-01-01
- 我不能使用 json 使用 react 向我的 web api 发出 Post 请求 2022-01-01
- 在不使用循环的情况下查找数字数组中的一项 2022-01-01
- 从原点悬停时触发 translateY() 2022-01-01
- 为什么我的页面无法在 Github 上加载? 2022-01-01
- 如何向 ipc 渲染器发送添加回调 2022-01-01
- 使用 iframe URL 的 jQuery UI 对话框 2022-01-01
- 如何显示带有换行符的文本标签? 2022-01-01
- 是否可以将标志传递给 Gulp 以使其以不同的方式 2022-01-01
- 为什么悬停在委托事件处理程序中不起作用? 2022-01-01