首頁  >  問答  >  主體

傳遞環境變數的腳本命令技巧

<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粉295616170413 天前427

全部回覆(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
  • 取消回覆