“跑|”的区别 并在 github 操作中多次运行

Kha*_*anh 25 github-actions

有什么区别

steps:
  - name: npm install, build, and test
    run: |
      npm ci
      npm run build --if-present
      npm test

Run Code Online (Sandbox Code Playgroud)

steps:
  - name: npm install, build, and test
  - run: npm ci
  - run: npm run build --if-present
  - run: npm test
Run Code Online (Sandbox Code Playgroud)

在 github 操作中?我试图阅读有关步骤的文档,但它没有提到类似的内容

Sam*_*ira 27

不同之处在于,第一个示例作为具有三个命令的单个脚本执行,第二个示例作为三个不同的单行脚本执行(旁注:第二个示例无效,因为您使用 step with namewithout run,我将忽略该行)。


让我们假设npm在运行时不创建任何输出的一秒钟。在第一个示例中,如果其中一个命令失败,则确定哪个命令可能会出现问题 - 您只有一个步骤标记为失败。在第二个示例中,您将确切地知道问题出在哪里,因为每个命令都是它自己的步骤。


让我们假设npm需要在特定子目录中运行的一秒钟。我们需要记住,每一步总是从工作空间目录/repo的根目录开始,所以我们需要先进入我们的东西所在的目录。

- run: |
       cd my/directory
       npm ci
       npm run build --if-present
       npm test
Run Code Online (Sandbox Code Playgroud)
- run: npm ci
  working-directory: my/directory
- run: npm run build --if-present
  working-directory: my/directory
- run: npm test
  working-directory: my/directory
Run Code Online (Sandbox Code Playgroud)

或者

- run: cd my/directory && npm ci
- run: cd my/directory && npm run build --if-present
- run: cd my/directory && npm test
Run Code Online (Sandbox Code Playgroud)

让我们假设一秒钟只npm test需要在push事件上运行,但工作流配置为运行on: [push, pull_request]

- run:   |
         npm ci
         npm run build --if-present
         if [ "${{ github.event_name }}" == "push" ]; then
            npm test
         fi
  shell: bash
Run Code Online (Sandbox Code Playgroud)
- run: npm ci
- run: npm run build --if-present
- run: npm test
  if:  github.event_name == 'push'
Run Code Online (Sandbox Code Playgroud)

操作选项卡下,处理pull_request事件时,第二个示例将显示为...

- Run npm ci
- Run npm run build...
- Run npm test <-- this one will be grayed out
Run Code Online (Sandbox Code Playgroud)

...您只需快速查看即可看到该npm test步骤已被跳过。在第一个示例中,您必须首先展开 step 并检查日志以注意任何差异。


依此类推,当使用多合一步骤更容易/更好时,有许多场景,以及当逐个命令步骤是可行的方法时,也有许多场景;由您决定哪一种最适合您。

毕竟,在一天结束时,两个示例都做完全相同的事情。但是,如果在此过程中出现任何问题,选择一种方式在另一种方式上运行命令(这也会改变它们的显示方式)可能会影响准备修复所需的时间。