注:GitHub Enterprise Server 2.22 上的 GitHub Actions 支持是有限的公测版。 测试已结束。 GitHub Actions 现在一般可用于 GitHub Enterprise Server 3.0 或更新版本。 更多信息请参阅 GitHub Enterprise Server 3.0 发行说明。
- 有关升级到 GitHub Enterprise Server 3.0 或更新版本的更多信息,请参阅“升级 GitHub Enterprise Server”。
- 有关在升级后配置 GitHub Actions 的更多信息,请参阅 GitHub Enterprise Server 3.0 的文档。
注: GitHub 托管的运行器目前在 GitHub Enterprise Server 上不受支持。 您可以在 GitHub 公共路线图 上查看有关未来支持计划的更多信息。
关于工作流程构件
构件允许您在作业完成后保留数据,并与同一工作流程中的另一个作业共享该数据。 构件是指在工作流程运行过程中产生的文件或文件集。 例如,在工作流程运行结束后,您可以使用构件保存您的构建和测试输出。
GitHub Enterprise Server 存储 90 天的完整构建日志和构件。 每当有人向拉取请求推送新提交时,拉取请求的保留期将重新开始。
以下是您可以上传的一些常见构件:
- 日志文件和核心转储文件
- 测试结果、失败和屏幕截图
- 二进制或压缩文件
- 压力测试性能输出和代码覆盖结果
项目会占用外部 Blob 存储上的存储空间,该存储为 您的 GitHub Enterprise Server 实例 上的 GitHub Actions 配置。
构件会在工作流程运行过程中上传,您可以在 UI 中查看构件的名称和大小。 当构件使用 GitHub Enterprise Server UI 下载时, 作为构件一部分单独上传的所有文件都会压缩到一个 zip 文件中。 这意味着计费是根据上传的构件大小而不是 zip 文件的大小计算的。
GitHub Enterprise Server 提供两项可用于上传和下载构建构件的操作。 更多信息请参阅 您的 GitHub Enterprise Server 实例 上的 actions/upload-artifact
和 download-artifact
操作。
要在作业之间共享数据:
- 上传文件:为上传的文件提供名称并在作业结束前上传数据。
- 下载文件:您只能下载在同一工作流程运行过程中上传的构件。 下载文件时,您可以通过名称引用该文件。
作业步骤共享运行器机器的相同环境,但在其各自的进程中运行。 要在作业的步骤之间传递数据,您可以使用输入和输出。 有关输入和输出的更多信息,请参阅“GitHub Actions 的元数据语法”。
上传构建和测试构件
您可以创建持续集成 (CI) 工作流程来构建和测试您的代码。 关于使用 GitHub Actions 执行 CI 的更多信息,请参阅“关于持续集成”。
构建和测试代码的输出通常会生成可用于调试测试失败的文件和可部署的生产代码。 您可以配置一个工作流程来构建和测试推送到仓库中的代码,并报告成功或失败状态。 您可以上传构建和测试输出,以用于部署、调试失败的测试或崩溃以及查看测试套件范围。
您可以使用 upload-artifact
操作上传构件。 上传构件时,您可以指定单个文件或目录,或多个文件或目录。 您还可以排除某些文件或目录,以及使用通配符模式。 我们建议您为构件提供名称,但如果未提供名称,则会使用 artifact
作为默认名称。 有关语法的更多信息,请参阅 actions/upload-artifact
操作。
示例
例如,您的仓库或 Web 应用程序可能包含必须转换为 CSS 和 JavaScript 的 SASS 和 TypeScript 文件。 假设您的构建配置输出 dist
目录中已编译的文件,如果所有测试均已成功完成,则可将 dist
目录中的文件部署到您的 Web 应用程序服务器。
|-- hello-world (repository)
| └── dist
| └── tests
| └── src
| └── sass/app.scss
| └── app.ts
| └── output
| └── test
|
本例向您展示如何创建 Node.js 项目的工作流程,该项目在 src 目录中 builds
代码,并在 tests
目录中运行测试。 您可以假设运行 npm test
会产生名为 code-coverage.html
、存储在 output/test/
目录中的代码覆盖报告。
工作流程上传 dist
目录中的生产构件,但不包括任何 markdown 文件。 它还会上传 code-coverage.html
报告作为另一个构件。
name: Node CI
on: [push]
jobs:
build_and_test:
runs-on: ubuntu-latest
steps:
- name: Checkout repository
uses: actions/checkout@v2
- name: npm install, build, and test
run: |
npm install
npm run build --if-present
npm test
- name: Archive production artifacts
uses: actions/upload-artifact@v2
with:
name: dist-without-markdown
path: |
dist
!dist/**/*.md
- name: Archive code coverage results
uses: actions/upload-artifact@v2
with:
name: code-coverage-report
path: output/test/code-coverage.html
下载或删除构件
During a workflow run, you can use the download-artifact
action to download artifacts that were previously uploaded in the same workflow run.
工作流程运行完成后,您可以在 GitHub 上或使用 REST API 下载或删除构件。 更多信息请参阅“下载工作流程构件”、“删除工作流程构件”和“构件 REST API”。
在工作流程运行期间下载构件
actions/download-artifact
操作可用于下载工作流程运行期间之前上传的构件。
注:您只能下载在同一工作流程运行过程中上传的构件。
指定构件的名称以下载单个构件。 如果在未指定名称的情况下上传构件目,则使用默认名称 artifact
。
- name: Download a single artifact
uses: actions/download-artifact@v2
with:
name: my-artifact
您还可以不指定名称而下载工作流程运行中的所有构件。 如果您在处理大量构件,此功能非常有用。
- name: Download all workflow run artifacts
uses: actions/download-artifact@v2
如果下载所有工作流程运行的构件,则每个构件使用其名称目创建目录。
有关语法的更多信息,请参阅 您的 GitHub Enterprise Server 实例 上的 actions/download-artifact
操作。
在工作流程中作业之间传递数据
您可以使用 upload-artifact
和 download-artifact
操作在工作流程中的作业之间共享数据。 此示例工作流程说明如何在相同工作流程中的任务之间传递数据。 更多信息请参阅 您的 GitHub Enterprise Server 实例 上的 actions/upload-artifact
和 download-artifact
操作。
依赖于以前作业构件的作业必须等待依赖项成功完成。 此工作流程使用 needs
关键词确保 job_1
、 job_2
和 job_3
按顺序运行。 例如, job_2
需要 job_1
使用 needs: job_1
语法。
作业1执行以下步骤:
- 执行数学计算并将结果保存到名为
math-home-work.txt
的文本文件。 - 使用
upload-artifact
操作上传构件名称为homework
的math-homework.txt
文件。
作业 2 使用上一个作业的结果:
- 下载上一个作业中上传的
homework
构件。 默认情况下,download-artifact
操作会将构件下载到该步骤执行的工作区目录中。 您可以使用path
输入参数指定不同的下载目录。 - 读取
math-homework.txt
文件中的值,进行数学计算,并将结果再次保存到math-homework.txt
,覆盖其内容。 - 更新
math-homework.txt
文件。 此上传会覆盖之前上传的构件,因为它们共用同一名称。
作业 3 显示上一个作业中上传的结果:
- 下载
homework
构件。 - 将数学方程式的结果打印到日志中。
此工作流程示例中执行的完整数学运算为 (3 + 7) x 9 = 90
。
name: Share data between jobs
on: [push]
jobs:
job_1:
name: Add 3 and 7
runs-on: ubuntu-latest
steps:
- shell: bash
run: |
expr 3 + 7 > math-homework.txt
- name: Upload math result for job 1
uses: actions/upload-artifact@v2
with:
name: homework
path: math-homework.txt
job_2:
name: Multiply by 9
needs: job_1
runs-on: windows-latest
steps:
- name: Download math result for job 1
uses: actions/download-artifact@v2
with:
name: homework
- shell: bash
run: |
value=`cat math-homework.txt`
expr $value \* 9 > math-homework.txt
- name: Upload math result for job 2
uses: actions/upload-artifact@v2
with:
name: homework
path: math-homework.txt
job_3:
name: Display results
needs: job_2
runs-on: macOS-latest
steps:
- name: Download math result for job 2
uses: actions/download-artifact@v2
with:
name: homework
- name: Print the final result
shell: bash
run: |
value=`cat math-homework.txt`
echo The result is $value
工作流程运行运行将会存档它生成的任何构件。 有关下载存档的构件的更多信息,请参阅“下载工作流程构件”。