TeamCity On-Premises 2024.12 Help

GitHub Checks Webhook Trigger

Common Information

The GitHub Checks Webhook Trigger runs a TeamCity build whenever a new change is pushed to a remote GitHub repository. In addition, this trigger posts detailed build result info to GitHub.

Build summary info on GitHub

If a processed changeset is a part of a Pull Request, this request shows the same build result info on its "Checks" tab.

Build report in the Checks tab

If you do not wish to expose your build server address, tick the Disable TeamCity links in GitHub check run output option in trigger settings. In this case build status messages will not publish links to TeamCity builds and build logs.

The trigger leverages GitHub Checks API and can be used as the only commit verification mechanism, or compliment native GitHub Actions workflows.

TC builds with GH actions

Limitations and Requirements

  • The GitHub Checks Webhook Trigger is compatible only with those build configurations that have VCS roots that utilize refreshable tokens to access a version control system. These tokens are issued via GitHub App connections.

    The connection must have its Support Webhooks option enabled. In addition, the trigger requires the related GitHub App to have the Checks: Read and write permission and handle the Check run and Check suite webhook events. In case you configure a new GitHub App TeamCity connection in "Automatic" mode, all required permissions and webhook event handlers will already be enabled. Otherwise, if you configure a new connection in "Manual" mode or wish to update connections created prior to version 2024.07, modify your App settings on the GitHub side accordingly. You will also need to re-acquire an auth token for the updated permissions to take effect.

  • If a related VCS root has the Use tags as branches option enabled, the GitHub Checks Webhook Trigger does not automatically start new builds when a new tagged release is created.

  • Using the GitHub Checks and standard VCS triggers together in one build configuration may cause duplicate builds triggered for the same push. Consider using only one trigger to avoid excessive builds. For more details, see this YouTrack ticket: TW-88928.

Comparing Checks and VCS Triggers

In a "classic" TeamCity setup, the automatic changes building is configured as follows:

  1. TeamCity collects new changes from a remote repository. This can happen during an automatic polling or, if the configuration was created via an existing GitHub App connection, when GitHub sends a post-commit webhook to TeamCity.

  2. A VCS trigger checks pending changes according to its own schedule, and produces a new build if one or multiple new commits are available. The trigger schedule protects TeamCity from spawning an excessive number of builds, which may happen in case of very high frequency commits. Instead, it provides a balanced approach where builds can process new commits in batches. For example, all commits that were pushed in the last five minutes will result a single TeamCity build.

  3. If a Commit Status Publisher feature is configured, the build status is communicated back to GitHub.

Compared to this setup, the Checks trigger showcases the following major differences:

  • It has no internal schedule and guarantees that each new push results in a new TeamCity build. This mechanism is preferable for cases when you need to spawn a build for all pushes, no matter how frequently they occur.

  • It does not require a Commit Status Publisher to publish Markdown-formatted status updates.

Last modified: 18 September 2024