-
Notifications
You must be signed in to change notification settings - Fork 2
138 lines (138 loc) Β· 4.19 KB
/
ci.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
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
name: π€ΉββοΈ Continuous Integration
on:
push:
branches: [main]
pull_request:
branches: [main]
workflow_dispatch:
env:
SCOPRE_OWNER: '@pungrumpy'
jobs:
security:
name: π Security
uses: ./.github/workflows/security.yml
codeql:
needs: [security]
name: π«Έ CodeQL
uses: ./.github/workflows/codeql.yml
lint:
needs: [codeql]
strategy:
fail-fast: false
matrix:
os: [ubuntu-latest]
node-version: [20, 21]
name: βοΈ Lint
runs-on: ${{ matrix.os }}
steps:
- name: π« Checkout Code
uses: actions/checkout@v4
- name: π¦ Setup Node
uses: actions/setup-node@v4
with:
node-version: ${{ matrix.node-version }}
registry-url: https://registry.npmjs.org/
scope: ${{ env.SCOPRE_OWNER }}
- name: π Setup Bun
uses: oven-sh/setup-bun@v1
- name: π΅ Cache bun
uses: actions/cache@v4
id: cache-bun
with:
path: ~/.bun
key: ${{ runner.os }}-bun-${{ hashFiles('**/bun.lockb') }}
restore-keys: |
${{ runner.os }}-bun-
- name: π½ Install Dependencies
run: bun install
- name: βοΈ Lint
run: bun lint
test:
needs: [lint]
strategy:
fail-fast: false
matrix:
os: [ubuntu-latest, macos-latest]
node-version: [21]
name: π§ͺ Test
runs-on: ${{ matrix.os }}
steps:
- name: π« Checkout Code
uses: actions/checkout@v4
- name: π¦ Setup Node
uses: actions/setup-node@v4
with:
node-version: ${{ matrix.node-version }}
registry-url: https://registry.npmjs.org/
scope: ${{ env.SCOPRE_OWNER }}
- name: π Setup Bun
uses: oven-sh/setup-bun@v1
- name: π΅ Cache bun
uses: actions/cache@v4
id: cache-bun
with:
path: ~/.bun
key: ${{ runner.os }}-bun-${{ hashFiles('**/bun.lockb') }}
restore-keys: |
${{ runner.os }}-bun-
- name: π½ Install Dependencies
run: bun install
- name: π§ͺ Test
# run: bun test --timeout 5000 --coverage --update-snapshots
run: bun run test:ci
release:
strategy:
fail-fast: false
matrix:
os: [ubuntu-latest]
node-version: [21]
if: ${{ github.ref == 'refs/heads/main' }} && !contains(github.event.head_commit.message, '[skip ci]')
name: π Release
permissions:
contents: write
pull-requests: write
runs-on: ${{ matrix.os }}
needs: [test]
steps:
- name: π€ Automated Release
uses: google-github-actions/release-please-action@v4
id: release
with:
token: ${{ secrets.GITHUB_TOKEN }}
release-type: node
- name: π Checkout
uses: actions/checkout@v4
- name: π¦ Setup Node
uses: actions/setup-node@v4
with:
node-version: ${{ matrix.node-version }}
registry-url: https://registry.npmjs.org/
scope: ${{ env.SCOPRE_OWNER }}
- name: π Setup Bun
uses: oven-sh/setup-bun@v1
- name: π΅ Cache bun
uses: actions/cache@v4
id: cache-bun
with:
path: ~/.bun
key: ${{ runner.os }}-bun-${{ hashFiles('**/bun.lockb') }}
restore-keys: |
${{ runner.os }}-bun-
- name: π½ Install Dependencies
run: bun install
- name: π·οΈ Tag stable versions
if: ${{ steps.release.outputs.release_created }}
run: |
git config user.name github-actions[bot]
git config user.email github-actions[bot]@users.noreply.github.com
git remote add gh-token "https://${{ secrets.GITHUB_TOKEN }}@github.com/google-github-actions/release-please-action.git"
git tag -d stable || true
git push origin :stable || true
git tag -a stable -m "chore: release stable version ${{ steps.release.outputs.tag_name }}"
git push origin stable
- name: π¦ Publish
if: ${{ steps.release.outputs.release_created }}
run: npm publish
env:
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
continue-on-error: true