与GitHub Actions的对比

尽管Gitea Actions旨在与GitHub Actions兼容,但它们之间存在一些差异。

额外功能

Action URL绝对路径

Gitea Actions支持通过URL绝对路径定义actions,这意味着您可以使用来自任何Git存储库的Actions。 例如,uses: https://github.com/actions/checkout@v3uses: http://your_gitea.com/owner/repo@branch

使用Go编写Actions

Gitea Actions支持使用Go编写Actions。 请参阅创建Go Actions

不支持的工作流语法

concurrency

这是用于一次运行一个Job。 请参阅使用并发

Gitea Actions目前不支持此功能。

run-name

这是工作流生成的工作流运行的名称。 请参阅GitHub Actions 的工作流语法

Gitea Actions目前不支持此功能。

permissionsjobs.<job_id>.permissions

请参阅GitHub Actions的工作流语法

Gitea Actions目前不支持此功能。

jobs.<job_id>.timeout-minutes

请参阅GitHub Actions的工作流语法

Gitea Actions目前不支持此功能。

jobs.<job_id>.continue-on-error

请参阅GitHub Actions的工作流语法

Gitea Actions目前不支持此功能。

jobs.<job_id>.environment

请参阅GitHub Actions的工作流语法

Gitea Actions 目前不支持此功能。

复杂的runs-on

请参阅GitHub Actions的工作流语法

Gitea Actions目前只支持runs-on: xyzruns-on: [xyz]

workflow_dispatch

请参阅GitHub Actions的工作流语法

Gitea Actions目前不支持此功能。

hashFiles表达式

请参阅表达式

Gitea Actions目前不支持此功能,如果使用它,结果将始终为空字符串。

作为解决方法,您可以使用go-hashfiles

缺失的功能

变量

请参阅变量

目前变量功能正在开发中。

问题匹配器

问题匹配器是一种扫描Actions输出以查找指定正则表达式模式并在用户界面中突出显示该信息的方法。 请参阅问题匹配器

Gitea Actions目前不支持此功能。

为错误创建注释

请参阅为错误创建注释

Gitea Actions目前不支持此功能。

缺失的UI功能

预处理和后处理步骤

预处理和后处理步骤在Job日志用户界面中没有自己的用户界面。

不一样的行为

下载Actions

Gitea Actions默认不从GitHub下载Actions。 “默认” 意味着您在uses 字段中不指定主机,如uses: actions/checkout@v3。 相反,uses: https://github.com/actions/checkout@v3是有指定主机的。

如果您不进行配置,缺失的主机将填充为https://gitea.com。 这意味着uses: actions/checkout@v3将从gitea.com/actions/checkout下载该Action,而不是github.com/actions/checkout

正如前面提到的,这是可配置的。 如果您希望您的运行程序默认从GitHub或您自己的Gitea实例下载动作,您可以通过设置[actions].DEFAULT_ACTIONS_URL进行配置。请参阅配置备忘单

上下文可用性

不检查上下文可用性,因此您可以在更多地方使用env上下文。 请参阅上下文可用性

已知问题

docker/build-push-action@v4

请参阅act_runner#119

ACTIONS_RUNTIME_TOKEN在Gitea Actions中是一个随机字符串,而不是JWT。 但是`DOCKER/BUILD-PUSH-ACTION@V4尝试将令牌解析为JWT,并且不处理错误,因此Job失败。

有两种解决方法:

手动将ACTIONS_RUNTIME_TOKEN设置为空字符串,例如:

  1. - name: Build and push
  2. uses: docker/build-push-action@v4
  3. env:
  4. ACTIONS_RUNTIME_TOKEN: ''
  5. with:
  6. ...

该问题已在较新的提交中修复,但尚未发布。因此,您可以通过指定分支名称来使用最新版本,例如:

  1. - name: Build and push
  2. uses: docker/build-push-action@master
  3. with:
  4. ...