搜索

首页  >  问答  >  正文

传递环境变量的脚本命令技巧

<p>我在<code>package.json</code>中有以下的cypress nodeJS脚本命令:</p> <pre class="brush:php;toolbar:false;">"scripts": { "cy:run": "npx cypress run --browser chrome", "cy:parallel" : "cypress-parallel -s cy:run -t 4 -d cypress/e2e/features/ -m false -a '\"--env ENV=${ENVI}\"'" }</pre> <p><code>-a</code>是一个动态的参数,我想在运行测试时传递,比如<code>ENVI=QA</code>或<code>ENVI=LIVE</code></p> <p>我尝试了以下几种方法,但对我来说都不起作用:</p> <pre class="brush:php;toolbar:false;">SET ENVI=QA npm run cy:parallel</pre> <p><code>ENVI=QA npm run cy:parallel</code></p> <p><code>$ENVI=QA npm run cy:parallel</code></p> <p>请告诉我正确的从命令行传递参数的方式。</p>
P粉295616170P粉295616170447 天前460

全部回复(2)我来回复

  • P粉465675962

    P粉4656759622023-09-03 10:10:57

    一种方法是使用CYPRESS_前缀。

    为了使事情更简单(独立于操作系统),使用包cross-env

    安装

    npm install --save-dev cross-env
    

    package.json

    "scripts": {
      "cy:run": "cross-env CYPRESS_ENVI=QA cypress run",
      ...
    }
    

    使用简单的测试进行测试:

    it('检查cross-env是否已设置CYPRESS_ENVI', () => {
      expect(Cypress.env('ENVI')).to.eq('QA')                // 通过
    })
    

    回复
    0
  • P粉384679266

    P粉3846792662023-09-03 00:10:34

    使用以下命令对我有效:

    设置环境变量的值如下:

    $env:ENVI=QA(在Windows上)

    并将脚本命令更改如下:

    使用ENV=%ENVI%替代ENV=${ENVI}

    "cy:parallel" : "cypress-parallel -s cy:run -t 4 -d cypress/e2e/features/ -m false -a '\"--env ENV=%ENVI%\"'"

    回复
    0
  • 取消回复