https://lab.github.com/githubtraining/github-actions
学会如何在 workflow 中使用 GitHub Action
GitHub Action 是什么?
GitHub Actions 是用来自动化任务的,比如:
自动使用 issues, @, labels 等响应 workflow triggers
这些任务都是代码,可以复用和分享。
Actions and Workflows
每个 action 负责不同的事情,一个 workflow 里面可以有多个 action。
一个 action 可能会包含多个文件,一般每个 action 都有自己的文件夹,里面放着相关文件。
action 分两种:
docker container action 将 action 代码和环境一起打包,只能在 GitHub-Hosted Linux 环境下运行。
JavaScript actions 将 action 代码和环境分开,执行速度更快,但是依赖管理的责任更重。
第一步:新建 Dockerfile
Dockerfile 文件定义了 action 的 metadata。
新建 action-name/Dockerfile 文件:
上一步的 Dockerfile 文件中,最后一句指定了入口脚本文件,/entrypoint.sh 文件用来定义这个 action 具体要做的事情,它会在 Docker 中执行。
所以我们要来定义这个入口文件,新建一个 action-name/entrypoint.sh 文件:
每个 action 都有一个 metadata 文件,使用 YAML 语法书写,文件定义了 action 的 输入、输出 和 入口文件。
新建一个 action-name/action.yml 文件:
第四步:定义 workflow 文件
workflow 文件定义在 .github/workflows 文件夹下。
我们可以自定义 workflow 执行的时机,比如 push 事件。
workflow 触发时机可以是:
新建 .github/workflows/main.yml 文件:
第五步:在 workflow 文件中执行 action
workflow 由 job 组成,job 由 step 组成,一个 step 可以是一个 action,也可以是一个 bash 命令。
job 可以执行 action,我们可以执行定义在同一个仓库下的 action,也可以是其他仓库的 action,或者是发布在社区的 action。
修改 .github/workflows/main.yml 文件:
现在我们往仓库里提交新代码时,push 事件触发,action-a 就会执行,可以在 GitHub 的 Actions tab 看到详细情况。