Skip to main content

Personal CI

Pulsar CI is currently hosted on Apache Infrastructure resources. Since we cannot add more resources to Pulsar CI, we need to find alternative ways to reduce the load on the system.

After merging PR-17693, pull requests sent directly to apache/pulsar will no longer trigger CI builds.

Therefore, pull requests should first be tested in your own fork. GitHub Actions provides a separate quota for pull requests that are executed in forked repositories.

CI workflows in a fork

Before using personal CI workflows, ensure GitHub Actions is enabled for your fork in the GitHub UI. You can check this under your fork's "Settings" > "Actions" > "General" tab. Choose the "Allow all actions and reusable workflows" option.

Here are the steps to use your personal CI on GitHub:

  1. Push your intended pull request changes to a new branch in your fork (following the standard process).
  2. Create a pull request targeting your own fork instead of the main repository.

You can create the pull request in two ways:

Using GitHub CLI

First, install and configure the GitHub CLI. Then use this single command to create a PR to your fork:

gh pr create --repo=<your-github-id>/pulsar --base master --head <your-pr-branch> -f

Using GitHub Web Interface

Alternatively, you can create a PR to your own fork through the GitHub web interface:

  1. When creating a new PR, select your fork as both the "base repository" and "head repository" in the dropdown menus.
  2. Choose "master" as the "base" branch and your PR branch as the "compare" branch (should be the default)
  3. Complete the PR creation process as normal

Stay in-sync with upstream

It's worth keeping your master branch in sync with apache/pulsar's master (the upstream) so that the diff of PR will be reasonable in your own fork.

Read more about the instructions to sync a fork from the WebUI, from the GitHub CI, or from the command line at Syncing a fork.

SSH to CI jobs

The additional benefit of the "Personal CI" is that you get SSH access to the build VMs when the build is running. That is handled by this logic in the pulsar-ci.yaml GitHub Actions workflow file:

- name: Setup ssh access to build runner VM
# ssh access is enabled for builds in own forks
if: ${{ github.repository != 'apache/pulsar' && github.event_name == 'pull_request' }}
uses: ./.github/actions/ssh-access
with:
limit-access-to-actor: true

Here is the inline ssh-access composite action implementation.

The SSH access is secured with the SSH key registered in GitHub. For example, your public keys are https://github.com/YOUR_GITHUB_ID.keys. You will first have to register an SSH public key in GitHub for that to work.