在配置项管道中运行开发服务器

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可用,然后执行测试,并在所有测试完成后关闭服务器。

这篇关于在配置项管道中运行开发服务器的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本文标题为:在配置项管道中运行开发服务器