uses: ExpediaGroup/github-helpers@v1
with:
    helper: <HELPER NAME>The helper input is required for all helpers, and the github_token input defaults to the included workflow token ${{ github.token }}. Additional inputs vary by helper. Each helper file in src/helpers contains an interface that defines which additional inputs are required or optional. If a required input is ommitted, the helper will throw a descriptive error.
Input interface in src/helpers/set-commit-status.ts:
export class SetCommitStatus {
    sha = ''; // required
    context = ''; // required
    state = ''; // required
    description?: string; // optional
    target_url?: string; // optional
}Github Actions workflow invocation:
uses: ExpediaGroup/github-helpers@v1
with:
    helper: set-commit-status
    sha: ${{ github.event.pull_request.head.sha }}
    context: My Context
    state: success
    description: My DescriptionEach of the following helpers are defined in a file of the same name in src/helpers:
- Generates a combined description for multiple commits in a push event
- Retrieves a user's github email with optional regex verification
- Returns the current position of a given PR in the GitHub merge queue
- Returns true if all teams specified are requested for review on a pull request
- Adds one or more labels to a PR
- Adds a LATE REVIEWlabel to all PRs that are open and waiting for review for over a certain number of days
- Upon PR review, adds a CORE APPROVEDlabel if the reviewer is a part of the provided Github team, otherwise adds thePEER APPROVEDlabel
- Returns trueif the PR has been approved by the specified GitHub team(s) or user(s) andfalseotherwise
- If GitHub teams are omitted, uses CODEOWNERSto determine teams and/or users to use.
- The parameter codeowners_overridescan be used to override entries fromCODEOWNERS. It is a string formatted as comma-separated list of lines in theCODEOWNERSsyntax. Exact pattern matches in CODEOWNERS will be replaced. Unmatched patterns will be appended.- example: /path/foo @user1 @user2,/path/bar @user3
 
- example: 
- Note: If you are providing teams in input, full team name is NOT needed. i.e. team-nameworks andorg/team-nameis NOT needed
- Approves a PR
- Randomly assigns members of the specified GitHub team(s) to review a PR.
- If GitHub teams are omitted, uses CODEOWNERS.mdto determine teams to use
- If loginis provided, it does nothing if that user is already part of the team
- You can also pass a slack_webhook_urlto notify the assignees that they are assigned to the PR!
- Checks if a PR branch needs to update with the default branch prior to merging (great for monorepos!)
- If this check succeeds for a PR, the PR is safe to merge right away!
- If this check fails for a PR, the PR must either merge in the default branch or rebase onto the default branch.
"Merge safety" is defined as a PR's branch being up to date with all files that could impact the validity of the PR checks that run. This merge safety check is designed to be a smarter alternative to GitHub's "require branches to be up to date before merging" branch protection rule.
The below table (taken from the above link) outlines the current branch protection rule settings GitHub provides:
| Type of required status check | Setting | Merge requirements | Considerations | 
|---|---|---|---|
| Strict | The Require branches to be up to date before merging checkbox is checked. | The branch must be up to date with the base branch before merging. | This is the default behavior for required status checks. More builds may be required, as you'll need to bring the head branch up to date after other collaborators merge pull requests to the protected base branch. | 
| Loose | The Require branches to be up to date before merging checkbox is not checked. | The branch does not have to be up to date with the base branch before merging. | You'll have fewer required builds, as you won't need to bring the head branch up to date after other collaborators merge pull requests. Status checks may fail after you merge your branch if there are incompatible changes with the base branch. | 
The "Strict" option is too strict! It opens the door to needless additional PR check runs when a PR is updated with commits that changes files completely unrelated to the scope of the PR's change.
The "Loose" option is too loose! There are times when a commit is made to the default branch that renders PR checks stale (specifically when files are changed that could impact the result of builds or tests).
The check-merge-safety helper offers a middle-ground between the "Strict" and "Loose" options, giving us the best of
both worlds! Using this helper allows us to uncheck the "Require branches to be up to date before merging" checkbox
while forcing PRs to incorporate the latest relevant changes into the CI process. This way, we can ensure that
only the necessary iterations of PR check runs occur, allowing contributors touching unrelated parts of the codebase
to ship code in quick succession!
This workflow should be run on both pull_request and push events:
- On pull_requestevents, this serves as a PR check
- On pushevents, this effectively re-runs this PR check for all open PRs and sets a commit status according to the result
The following parameters can be used for additional control over when it is safe to merge a PR:
- paths: These are the file paths to all of a repo's projects (usually paths to standalone packages)- This is useful for monorepos with multiple projects which are decoupled from each other but are affected by global dependencies.
 
- ignore_globs: These are glob patterns that, if out of date on a PR, will not prevent merge- example: ignore_globs: **.md
 
- example: 
- override_filter_paths: These are the file paths that, if out of date on a PR, will prevent merge no matter what files the PR is changing- example: override_filter_paths: package.json,package-lock.json
 
- example: 
- override_filter_globs: These are glob patterns for- override_filter_paths
- Closes a pull request in your current repo or in another repo.
- Opens a pull request.
- Can create a new branch and commit changes
| Parameter | Description | Default value | Required | 
|---|---|---|---|
| title | An issue title | N/A | ✔️ | 
| body | Description of the PR | N/A | ✔️ | 
| base | Base ref to initiate pull request onto | N/A | ❌ | 
| branch_name | Name of the branch to be created. Use this parameter if you want the helper to create a new branch for you. | N/A | ❌ | 
| commit_message | Text used when creating a commit if branch_name is given. Similar to git commit -m "<commit_message>" | Automated PR creation | ❌ | 
| head | Head ref to initiate pull request from. If branch_name is provided it'll be the value of head | N/A | ❌ | 
| return_full_payload | Return full payload from GitHub rather than a trimmed-down version of the response | N/A | ❌ | 
- Checks whether PR title matches a certain regular expression
- Comments on a pull request or other issue in your current repo or in another repo
- Deletes all of a repository's unprotected branches not associated with an open PR and which have been inactive for a certain number of days
- Deletes a Github deployment and environment
- Returns trueif specified file paths have changed for a PR, andfalseotherwise
- Returns a job matrix JSON for dynamically running workflows
- Returns a job matrix JSON for dynamically running workflows only for changed file paths
- Can be used to parallelize similar jobs, which can be useful in a monorepo environment. More information on matrix strategies can be found here
- In this example, a multi-package repo splits its builds dynamically based on which packages are modified in the pull request. These builds run in parallel, and the final build-statusjob is used to determine the overall success/failure result, contingent on all of the individualbuildjobs passing. The helper returns a JSON object of this format:
{
    "include": [{ "path": "package-name" }]
}Additionally, the following parameters can be used for additional control over the resulting matrix:
- override_filter_pathsdefines paths that, if modified, will override the filter and return a matrix including all packages- example: override_filter_paths: package.json,package-lock.json
 
- example: 
- paths_no_filterdefines paths that should be included in the matrix regardless of if they've been modified
- batchesdefines a fixed number of matrix jobs to run for the workflow
- Returns a comma-separated list of changed files for a PR
- Include the regular expression parameter 'pattern' to add a filter, it will return any filepath that matches.
- Creates a new in-progress Github "deployment" for a commit. More information on Github deployment events can be found here
- Checks if a specified GitHub user is a core member for a given pull request.
- Checks if the specifed GitHub user exists within an organization team
- Adds a comment listing the due date (based on SLA guidelines) to issues with a priority label attached
- Adds a 'due soon' label to issues with a priority label that will become overdue in 7 days
- Adds an 'overdue' label to issues with a priority label that are overdue
- Manages a queue for PRs as follows:
- Adding the READY TO MERGElabel to a PR will add the PR to the "merge queue", represented by aQUEUED FOR MERGE #Xlabel. RemovingREADY TO MERGEwill remove this label and thus remove the PR from the queue.
- If a PR is first in the queue, the QUEUE CHECKERcommit status will be set tosuccess, and it will bependingotherwise. Github's branch protection rules can be used to ensure this requirement is met prior to merging.
- Merging a PR will update the positions of all PRs in the queue.
- Adding the JUMP THE QUEUElabel to a PR will make that PR first in the queue immediately.
- When a PR is merged, it automatically updates the first-queued PR with the default branch.
 
- Adding the 
- You can also pass loginandslack_webhook_urlto notify the PR author when they are in the 1st position of the merge queue.
- Passing skip_auto_merge: truechanges the default behaviour of automatically enabling auto-merge for PRs from the merge queue. In such case auto-merging should be enabled manually on individual PRs. It can be useful to avoid unattended deployments in case of CICD pipelines which are not fully prepared for continuous deployment.
- Sets a "pipeline" commit status to green for all open PRs
- Merges the default branch into the pull request that has the QUEUED FOR MERGE #1label
- Removes a label from a PR
- Removes a PR from the merge queue if it has a stale failing status check. A PR check is considered stale if it is older than the provided number of seconds.
- Reopens a pull request in your current repo or in another repo.
- Reruns all of the latest workflow checks on a pull request (helpful if they were cancelled for some reason, either manually or due to rate limiting, for example).
- Sets a commit status
- You can pass in skip_if_already_set: trueif you'd like to skip setting a status if it's already been set on the commit by a workflow
- Updates a Github deployment status
- Determines whether the pipeline is clear for a PR. This means it will set the "pipeline" commit status to pendingif there is an in-progress production deployment for the repo, andsuccessotherwise.
- Updates the result of a previous PR check tied to a commit status.
This project is available under the Apache 2.0 License.
Copyright 2021 Expedia, Inc.