-
Notifications
You must be signed in to change notification settings - Fork 0
69 lines (63 loc) · 2.15 KB
/
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
name: Bump Version
on:
pull_request:
types:
- closed
branches:
- main
workflow_dispatch:
workflow_call:
jobs:
build:
uses: ./.github/workflows/build.yml
if_manual:
needs: [build]
if: github.event_name != 'pull_request'
runs-on: ubuntu-latest
steps:
- run: |
echo The workflow is manually triggered, no version bump.
bump-version:
needs: [build]
if: github.event.pull_request.merged == true
name: 'Bump version on main branch'
runs-on: ubuntu-latest
permissions:
contents: write
steps:
- name: Checkout Git repository
uses: 'actions/checkout@v3'
with:
ref: ${{ github.ref }}
- name: Read package.json
run: cat ./package.json
- name: Automated Version Bump
id: version-bump
uses: 'phips28/gh-action-bump-version@master'
with:
tag-prefix: 'v'
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: Read package.json
run: cat ./package.json
- name: Output Step
env:
NEW_TAG: ${{ steps.version-bump.outputs.newTag }}
run: echo "new tag $NEW_TAG"
# Workflow:
#
# 1. Based on the commit messages, increment the version from the latest release.
# * If the string "BREAKING CHANGE", "major" or the Attention pattern
# `refactor!: drop support for Node 6` is found anywhere in any of the commit messages or
# descriptions the major version will be incremented.
# * If a commit message begins with the string "feat" or includes "minor" then the minor version
# will be increased. This works for most common commit metadata for feature additions: "feat:
# new API" and "feature: new API".
# * If a commit message contains the word "pre-alpha" or "pre-beta" or "pre-rc" then the
# pre-release version will be increased (for example specifying pre-alpha: 1.6.0-alpha.1 ->
# 1.6.0-alpha.2 or, specifying pre-beta: 1.6.0-alpha.1 -> 1.6.0-beta.0)
# * All other changes will increment the patch version.
#
# 2. Push the bumped npm version in package.json back into the repo.
#
# 3. Push a tag for the new version back into the repo.