forked from maidsafe/autonomi
-
Notifications
You must be signed in to change notification settings - Fork 0
99 lines (86 loc) · 3.65 KB
/
version_bump.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
# Automatically run the version bump script.
name: Version Bump
# prevent concurrent version bumps
concurrency:
group: "version-bump-${{ github.ref_name }}"
on:
workflow_dispatch:
inputs:
suffix:
description: "Suffix to append to the version (alpha/beta), leave empty for no suffix."
required: false
env:
RELEASE_PLZ_BIN_URL: https://github.com/MarcoIeni/release-plz/releases/download/release-plz-v0.3.43/release-plz-x86_64-unknown-linux-gnu.tar.gz
WORKFLOW_URL: https://github.com/maidsafe/safe_network/actions/runs
jobs:
bump_version:
# only run if its maidsafe repo and not already a release commit.
if: >
github.repository_owner == 'maidsafe' &&
!startsWith(github.event.head_commit.message, 'chore(release):')
runs-on: ubuntu-22.04
steps:
- uses: actions/checkout@v4
with:
fetch-depth: "0"
token: ${{ secrets.VERSION_BUMP_COMMIT_PAT }}
ref: ${{ github.ref_name }}
- name: Get the SHA of the last release commit
id: get-sha
run: echo "sha=$(git log --grep='chore(release):' -n 1 --pretty=format:"%H")" >> $GITHUB_ENV
- name: Fetch the latest code from the specified branch
run: git pull origin ${{ github.ref_name }}
- uses: actions-rs/toolchain@v1
with:
profile: minimal
toolchain: stable
override: true
# install cargo-edit for bump script, this makes it simpler to bump into workspaces
- name: Install cargo-edit with vendored-openssl
run: cargo install cargo-edit --features vendored-openssl
- shell: bash
run: |
git config --local user.email "[email protected]"
git config --local user.name "GitHub Action"
# It's possible to `cargo install` release-plz, but it's very slow to compile on GHA infra.
# Therefore we just pull the binary from the Github Release.
- name: install release-plz
shell: bash
run: |
curl -L -O $RELEASE_PLZ_BIN_URL
tar xvf release-plz-x86_64-unknown-linux-gnu.tar.gz
rm release-plz-x86_64-unknown-linux-gnu.tar.gz
sudo mv release-plz /usr/local/bin
- shell: bash
# run as the branch name with the suffix from workflow dispatch, allowing for an empty suffix as a valid option
run: |
if [[ -z "${{ github.event.inputs.suffix }}" && "${{ github.ref_name }}" != stable* ]]; then
echo "Error: Empty suffix is only allowed on branches starting with 'stable'."
exit 1
fi
./resources/scripts/bump_version.sh ${{ github.event.inputs.suffix }}
- name: push version bump commit
uses: ad-m/github-push-action@master
with:
github_token: ${{ secrets.VERSION_BUMP_COMMIT_PAT }}
branch: ${{ github.ref_name }}
tags: true
- name: Cherry-pick to main if on stable
if: ${{ github.ref_name == 'stable' }}
run: |
git fetch origin main
git checkout main
git cherry-pick stable
- name: Push updated version bump commit to main
if: ${{ github.ref_name == 'stable' }}
uses: ad-m/github-push-action@master
with:
github_token: ${{ secrets.VERSION_BUMP_COMMIT_PAT }}
branch: main
- name: post notification to slack on failure
if: ${{ failure() }}
uses: bryannice/[email protected]
env:
SLACK_INCOMING_WEBHOOK: ${{ secrets.SLACK_GH_ACTIONS_WEBHOOK_URL }}
SLACK_MESSAGE: "Please check the logs for the run at ${{ env.WORKFLOW_URL }}/${{ github.run_id }}"
SLACK_TITLE: "Version Bumping Failed"