Execution Model
gitStream is triggered on new pull requests (PRs) for repositories that have gitStream installed. Upon triggering, gitStream collects context variables and evaluates the automation rules to determine which ones are relevant.
Organization-level rules and repository rules
When a central cm
repository is set with the CI/CD runner, the events for PRs from all installed repositories shall be evaluated in the cm
repository pipeline, taking into account the organization-level rules and the PR repository rules.
Triggering events
Implicit triggers
By default, gitStream evaluates any new commit pushed to the PR, triggering automation evaluation.
Additionally, if any of the automation rules reference the following pr
context variables: pr.comments
, pr.title
, pr.description
, or pr.labels
, gitStream shall trigger and will initiate automation rules evaluation where there are changes to the PR comments, title, description, or labels respectfully.
This allows for greater flexibility in the automation process, ensuring that the relevant automation rules are evaluated and triggered when necessary. The execution model ensures the automation process is streamlined, efficient, and effective.
Explicit triggers
gitstream supports an explicit triggering mechanism. When using explicit triggers, the automations will run only according to the defined triggers, which means the Implicit triggers will not work. Automations triggered by explicit triggers will also be invoked on draft
PRs
Explicit triggers syntax
Use explicit triggers to enhance the control and customization of automations in gitStream, allowing users to define precisely when and how automations should be triggered based on various events and actions within pull requests.
Add the on
keyword to the file and/or to a specific automation to define explicit triggers. gitStream supports the following explicit triggers:
Triggering event | Explicit Trigger | Default (implicit triggers) |
---|---|---|
Creating a PR | pr_created | on |
Commit | commit | on |
Adding label | label_added | when pr.label in .cm |
Removing label | label_removed | when pr.label in .cm |
Merging the PR | merge | off |
Adding new comment | comment_added | when pr.comment in .cm |
Editing an existing comment | - | when pr.comment in .cm |
Title change | - | when pr.title in .cm |
Description change | - | when pr.description in .cm |
Transition from draft to ready for review | pr_ready_for_review | off |
transition from any state to closed | pr_closed | off |
transition from closed to open | pr_reopened | off |
Explicit triggers are set independently per each automation block and can be configured at the file level, specific to each automation separately or in a combination of the two. If triggers are listed at the file level and specific automation, the automation will be triggered according to both triggers. If an automation block does not have explicit triggers configured, it will be triggered according to the default (implicit) triggers.
Examples
-
assign code expert reviewer when the PR is created and after each commit
-
Explain code experts only if the label “suggest-reviewer” exists. The automation will be triggered after each commit and after each label addition. If the label “suggest-reviewer” exists, it will trigger the
explain-code-experts
automation