-
Notifications
You must be signed in to change notification settings - Fork 56
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Set up maintenance to automatically cherry-pick non-breaking commits …
…to main
- Loading branch information
Showing
2 changed files
with
138 additions
and
12 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -12,13 +12,13 @@ on: # yamllint disable-line rule:truthy | |
merge_group: | ||
|
||
env: | ||
node_version: 18 | ||
node_version: 23 | ||
|
||
jobs: | ||
typecheck: | ||
# Can run untrusted code so disable all permissions. | ||
permissions: {} | ||
name: type check code base | ||
name: Type Check Code Base | ||
runs-on: ubuntu-latest | ||
steps: | ||
# This pattern is reused a couple of times. | ||
|
@@ -48,13 +48,13 @@ jobs: | |
- run: npm ci --cache .npm --prefer-offline | ||
|
||
- name: compile typescript | ||
- name: Type Check | ||
run: npm run typecheck | ||
|
||
lint: | ||
# Can run untrusted code so disable all permissions. | ||
permissions: {} | ||
name: lint code base | ||
name: Lint Code Base | ||
runs-on: ubuntu-latest | ||
steps: | ||
- name: Checkout Branch | ||
|
@@ -65,7 +65,7 @@ jobs: | |
token: ${{ secrets.GITHUB_TOKEN }} | ||
fetch-depth: 1 | ||
|
||
- name: install node | ||
- name: Install Node | ||
uses: actions/setup-node@v4 | ||
with: | ||
node-version: ${{ env.node_version }} | ||
|
@@ -80,13 +80,14 @@ jobs: | |
${{ runner.OS }}- | ||
- run: npm ci --cache .npm --prefer-offline | ||
- name: run lints | ||
|
||
- name: Run Lints | ||
run: npm run lint:ci | ||
|
||
test: | ||
# Can run untrusted code so disable all permissions. | ||
permissions: {} | ||
name: test code base | ||
name: Test Code Base | ||
runs-on: ubuntu-latest | ||
continue-on-error: true | ||
steps: | ||
|
@@ -98,7 +99,7 @@ jobs: | |
token: ${{ secrets.GITHUB_TOKEN }} | ||
fetch-depth: 1 | ||
|
||
- name: install node | ||
- name: Install Node | ||
uses: actions/setup-node@v4 | ||
with: | ||
node-version: ${{ env.node_version }} | ||
|
@@ -114,7 +115,7 @@ jobs: | |
- run: npm ci --cache .npm --prefer-offline | ||
|
||
- name: execute tests | ||
- name: Execute Tests | ||
run: npm test -- --run --reporter github-actions --reporter=./.github/workflows/testsReporter.ts | ||
|
||
- name: Upload Main Test Results | ||
|
@@ -131,9 +132,134 @@ jobs: | |
name: pr-test-results | ||
path: test-results/vitest-report.json | ||
|
||
checkCanMergeToMaintenance: | ||
# Can run untrusted code so disable all permissions. | ||
permissions: {} | ||
name: Check Merge to Maintenance | ||
if: (github.event_name == 'push' && github.ref == 'refs/heads/main') || github.event.pull_request | ||
outputs: | ||
should_skip: ${{ steps.should_skip.outputs.should_skip }} | ||
runs-on: ubuntu-latest | ||
steps: | ||
- uses: 8BitJonny/[email protected] | ||
if: github.event.pull_request == null | ||
id: PR | ||
|
||
# Sets should_skip if this change wasn't made through a PR or if the PR is labeled as breaking. | ||
- name: Check if should skip | ||
id: should_skip | ||
if: | | ||
(github.event.pull_request && contains(steps.PR.outputs.pr_labels.*.name, 'breaking')) || | ||
(!github.event.pull_request && steps.PR.outputs.pr_found != 'true') || | ||
contains(steps.PR.outputs.pr_labels.*.name, 'breaking') | ||
run: | | ||
echo "Skipping the rest of the job because this change wasn't made through a PR or the PR is labeled as breaking." | ||
echo "${{ toJSON(fromJSON(steps.PR.outputs.pr)) }}" | ||
echo "should_skip=true" >> "$GITHUB_OUTPUT" | ||
- name: Get fetch depth | ||
id: fetch_depth | ||
if: steps.should_skip.outputs.should_skip != 'true' | ||
env: | ||
GITHUB_EVENT_COMMITS: ${{ toJSON(github.event.commits) }} | ||
run: | | ||
commitCount=$(jq length <<< "$GITHUB_EVENT_COMMITS") | ||
echo "fetch_depth=$(( commitCount + 1 ))" >> "$GITHUB_OUTPUT" | ||
- uses: actions/checkout@v4 | ||
if: steps.should_skip.outputs.should_skip != 'true' | ||
with: | ||
ref: ${{ github.head_ref || github.ref }} | ||
fetch-depth: ${{ steps.fetch_depth.outputs.fetch_depth }} | ||
|
||
- name: Check for merge conflicts | ||
if: steps.should_skip.outputs.should_skip != 'true' | ||
run: | | ||
git fetch --no-tags origin main maintenance:maintenance | ||
git checkout maintenance | ||
before="${{github.event.before}}" | ||
if [[ $before == "" ]]; then | ||
before=$(git merge-base origin/main "${{ github.base_ref }}") | ||
fi | ||
git cherry-pick --allow-empty --no-commit -m 1 "$baseCommit".."${{ github.sha }}" || ( | ||
echo "Merge conflicts detected with the maintenance branch!" && exit 1 | ||
) | ||
- name: Install Node | ||
if: steps.should_skip.outputs.should_skip != 'true' | ||
uses: actions/setup-node@v4 | ||
with: | ||
node-version: ${{ env.node_version }} | ||
|
||
- name: Cache Node.js modules | ||
if: steps.should_skip.outputs.should_skip != 'true' | ||
uses: actions/cache@v4 | ||
with: | ||
path: .npm | ||
key: ${{ runner.OS }}-node-${{ hashFiles('**/package-lock.json') }} | ||
restore-keys: | | ||
${{ runner.OS }}-node- | ||
${{ runner.OS }}- | ||
- if: steps.should_skip.outputs.should_skip != 'true' | ||
run: npm ci --cache .npm --prefer-offline | ||
|
||
- name: Run Lints on maintenance | ||
if: steps.should_skip.outputs.should_skip != 'true' | ||
run: npm run lint:ci | ||
|
||
- name: Type Check maintenance | ||
if: steps.should_skip.outputs.should_skip != 'true' | ||
run: npm run typecheck | ||
|
||
mergeToMaintenance: | ||
name: Merge To Maintenance | ||
needs: [checkCanMergeToMaintenance] | ||
if: needs.checkCanMergeToMaintenance.outputs.should_skip != 'true' | ||
runs-on: ubuntu-latest | ||
steps: | ||
- name: Get fetch depth | ||
id: fetch_depth | ||
env: | ||
GITHUB_EVENT_COMMITS: ${{ toJSON(github.event.commits) }} | ||
run: | | ||
commitCount=$(jq length <<< "$GITHUB_EVENT_COMMITS") | ||
echo "fetch_depth=$(( commitCount + 1 ))" >> "$GITHUB_OUTPUT" | ||
- uses: actions/checkout@v4 | ||
with: | ||
fetch-depth: ${{ steps.fetch_depth.outputs.fetch_depth }} | ||
|
||
- name: Fetch branches | ||
run: | | ||
git fetch origin maintenance:maintenance | ||
- name: Cherry pick commits onto maintenance | ||
run: | | ||
git switch maintenance | ||
# Commit using the GitHub Actions bot user. | ||
git config user.name "github-actions[bot]" | ||
git config user.email "41898282+github-actions[bot]@users.noreply.github.com" | ||
# Pick the freshly added commits onto the maintenance branch. | ||
git cherry-pick --allow-empty -m 1 "${{ github.event.before }}".."${{ github.event.after }}" || ( | ||
echo "Merge conflicts detected with maintenance branch! This can only happen if checkCanMergeToMaintenance is written incorrectly or someone pushed in between!" && exit 1 | ||
) | ||
- name: Push changes | ||
uses: ad-m/github-push-action@master | ||
with: | ||
branch: maintenance | ||
github_token: ${{ secrets.GITHUB_TOKEN }} | ||
|
||
reportTestResults: | ||
name: report test results | ||
needs: ["test"] | ||
name: Report Test Results | ||
needs: [test] | ||
runs-on: ubuntu-latest | ||
if: github.event_name == 'pull_request_target' || (github.event_name == 'push' && github.event.pull_request != null) | ||
steps: | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters