OPEN TO WORK

Available for new opportunities! Let's build something amazing together.

Dispatch a GitHub Action workflow with script action

GitHub Actions GitHub
post

You can use the GitHub Actions workflow repository_dispatch event trigger to start a workflow by triggering a webhook.

I use this event trigger to start a workflow for building my website when I create or update content in my blog repository. Because my website and the blog content are two separate repositories, I must use the repository_dispatch event to trigger the website build workflow. Another use case is to start my E2E tests when I deploy a new application version.

Configure the workflow to trigger

In the workflow file you want to trigger, you must add the repository_dispatch event with a types key. The types key is an array of event types that you can define to limit your workflow to run on those specific types.

name: Playwright Tests
on:
repository_dispatch:
types: [trigger-e2e-tests]

How to trigger the workflow

You can start the workflow by making a POST request to the dispatches endpoint of the GitHub API. The endpoint is POST /repos/{owner}/{repo}/dispatches.

The request body should contain the event_type key with the event name you want to trigger. You can also add a client_payload key with additional data you wish to send to the workflow.

POST https://api.github.com/repos/{owner}/{repo}/dispatches HTTP/1.1
Content-Type: application/json
Authorization: Bearer <PAT>
X-GitHub-Api-Version: 2022-11-28
{
"event_type": "trigger-e2e-tests",
}

Trigger the workflow with the GitHub script action

A helpful workflow action is the GitHub script action. This action allows you to use the Octokit/rest.js library to interact with the GitHub API and trigger the repository_dispatch event.

Here is an example of how you can trigger the repository_dispatch event with the GitHub script action:

jobs:
build:
runs-on: ubuntu-latest
steps:
# All your other steps
- name: Start E2E tests
uses: actions/github-script@v7
with:
github-token: ${{ secrets.REPO_ACCESS_TOKEN }}
script: |
await github.rest.repos.createDispatchEvent({
owner: context.repo.owner,
repo: "<your repo name>",
event_type: "trigger-e2e-tests"
});

In the script, you need to replace <your repo name> with the repository’s name where you want to trigger the workflow.

Related articles

Report issues or make changes on GitHub

Found a typo or issue in this article? Visit the GitHub repository to make changes or submit a bug report.

Comments

Elio Struyf

Solutions Architect & Developer Expert

Loading...

Let's build together

Manage content in VS Code

Present from VS Code