ci: error out if someone sends a PR to the wrong branch

This commit is contained in:
Pietro Albini 2021-05-06 18:47:37 +02:00
parent 81a97cea83
commit 392723ec6e
No known key found for this signature in database
GPG key ID: 3E06ABE80BAAF19C
4 changed files with 53 additions and 0 deletions

View file

@ -72,6 +72,9 @@ jobs:
- name: decide whether to skip this job - name: decide whether to skip this job
run: src/ci/scripts/should-skip-this.sh run: src/ci/scripts/should-skip-this.sh
if: success() && !env.SKIP_JOB if: success() && !env.SKIP_JOB
- name: ensure the channel matches the target branch
run: src/ci/scripts/verify-channel.sh
if: success() && !env.SKIP_JOB
- name: configure GitHub Actions to kill the build when outdated - name: configure GitHub Actions to kill the build when outdated
uses: rust-lang/simpleinfra/github-actions/cancel-outdated-builds@master uses: rust-lang/simpleinfra/github-actions/cancel-outdated-builds@master
with: with:
@ -434,6 +437,9 @@ jobs:
- name: decide whether to skip this job - name: decide whether to skip this job
run: src/ci/scripts/should-skip-this.sh run: src/ci/scripts/should-skip-this.sh
if: success() && !env.SKIP_JOB if: success() && !env.SKIP_JOB
- name: ensure the channel matches the target branch
run: src/ci/scripts/verify-channel.sh
if: success() && !env.SKIP_JOB
- name: configure GitHub Actions to kill the build when outdated - name: configure GitHub Actions to kill the build when outdated
uses: rust-lang/simpleinfra/github-actions/cancel-outdated-builds@master uses: rust-lang/simpleinfra/github-actions/cancel-outdated-builds@master
with: with:
@ -541,6 +547,9 @@ jobs:
- name: decide whether to skip this job - name: decide whether to skip this job
run: src/ci/scripts/should-skip-this.sh run: src/ci/scripts/should-skip-this.sh
if: success() && !env.SKIP_JOB if: success() && !env.SKIP_JOB
- name: ensure the channel matches the target branch
run: src/ci/scripts/verify-channel.sh
if: success() && !env.SKIP_JOB
- name: configure GitHub Actions to kill the build when outdated - name: configure GitHub Actions to kill the build when outdated
uses: rust-lang/simpleinfra/github-actions/cancel-outdated-builds@master uses: rust-lang/simpleinfra/github-actions/cancel-outdated-builds@master
with: with:

View file

@ -126,6 +126,10 @@ x--expand-yaml-anchors--remove:
run: src/ci/scripts/should-skip-this.sh run: src/ci/scripts/should-skip-this.sh
<<: *step <<: *step
- name: ensure the channel matches the target branch
run: src/ci/scripts/verify-channel.sh
<<: *step
- name: configure GitHub Actions to kill the build when outdated - name: configure GitHub Actions to kill the build when outdated
uses: rust-lang/simpleinfra/github-actions/cancel-outdated-builds@master uses: rust-lang/simpleinfra/github-actions/cancel-outdated-builds@master
with: with:

View file

@ -0,0 +1,28 @@
#!/bin/bash
# We want to make sure all PRs are targeting the right branch when they're
# opened, otherwise we risk (for example) to land a beta-specific change to the
# master branch. This script ensures the branch of the PR matches the channel.
set -euo pipefail
IFS=$'\n\t'
source "$(cd "$(dirname "$0")" && pwd)/../shared.sh"
declare -A CHANNEL_BRANCH
CHANNEL_BRANCH["nightly"]="master"
CHANNEL_BRANCH["beta"]="beta"
CHANNEL_BRANCH["stable"]="stable"
if isCiBranch auto || isCiBranch try; then
echo "channel verification is only executed on PR builds"
exit
fi
channel=$(cat "$(ciCheckoutPath)/src/ci/channel")
branch="$(ciBaseBranch)"
if [[ "${branch}" != "${CHANNEL_BRANCH[$channel]}" ]]; then
echo "error: PRs changing the \`${channel}\` channel should be sent to the \
\`${CHANNEL_BRANCH[$channel]}\` branch!"
exit 1
fi

View file

@ -73,6 +73,18 @@ function isCiBranch {
fi fi
} }
function ciBaseBranch {
if isAzurePipelines; then
echo "unsupported on Azure Pipelines"
exit 1
elif isGitHubActions; then
echo "${GITHUB_BASE_REF#refs/heads/}"
else
echo "ciBaseBranch only works inside CI!"
exit 1
fi
}
function ciCommit { function ciCommit {
if isAzurePipelines; then if isAzurePipelines; then
echo "${BUILD_SOURCEVERSION}" echo "${BUILD_SOURCEVERSION}"