-
-
Notifications
You must be signed in to change notification settings - Fork 2
144 lines (119 loc) · 4.09 KB
/
ci.yml
File metadata and controls
144 lines (119 loc) · 4.09 KB
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
139
140
141
142
143
144
name: CI
on:
pull_request:
push:
branches:
- master
- staging
- 'dev/*'
- 'fix/*'
paths-ignore:
- '**.md'
- '**.txt'
- 'LICENSE'
env:
CI: true
# Make sure we disable husky as it might interfere with some operations here
HUSKY: 0
jobs:
lint:
name: 📋 Lint
runs-on: ubuntu-latest
steps:
- name: 🕶️ Checkout repository
uses: actions/checkout@v6
- name: 🚀 Bootstrap
uses: ./.github/common/bootstrap
- name: 📋 Lint
run: pnpm run lint
typecheck:
name: ✅ Typecheck
runs-on: ubuntu-latest
steps:
- name: 🕶️ Checkout repository
uses: actions/checkout@v6
- name: 🚀 Bootstrap
uses: ./.github/common/bootstrap
- name: ✅ Typecheck
run: pnpm run typecheck
build:
name: 🔨 Build
needs: [lint, typecheck]
runs-on: ubuntu-latest
steps:
- name: 🕶️ Checkout repository
uses: actions/checkout@v6
- name: 🚀 Bootstrap
uses: ./.github/common/bootstrap
- name: 🔬 Verify integrity
run: npm audit signatures
- name: 🔨 Build all
run: pnpm run build
test:
name: 🧪 Test
needs: [lint, typecheck]
runs-on: ubuntu-latest
steps:
- name: 🕶️ Checkout repository
uses: actions/checkout@v6
- name: 🚀 Bootstrap
uses: ./.github/common/bootstrap
- name: 🧪 Test
run: pnpm run test
- name: 🦺 Codecov coverage reports
if: ${{ !cancelled() }}
uses: codecov/codecov-action@v5
with:
token: ${{ secrets.CODECOV_TOKEN }}
slug: filiphsps/AdaptiveShell
- name: 🦺 Upload test results to Codecov
if: ${{ !cancelled() }}
uses: codecov/test-results-action@v1
with:
token: ${{ secrets.CODECOV_TOKEN }}
slug: filiphsps/AdaptiveShell
release:
name: 🚢 Release
needs: [build, test]
runs-on: ubuntu-latest
if: github.ref == 'refs/heads/master'
permissions: write-all
concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
env:
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
NPM_TOKEN: ${{ secrets.NPM_TOKEN }}
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
steps:
- name: 🕶️ Checkout repository
uses: actions/checkout@v6
with:
fetch-depth: 0
submodules: 'recursive'
- name: 🚀 Bootstrap
uses: ./.github/common/bootstrap
- name: 🔬 Verify integrity
run: npm audit signatures
- name: 🔨 Build all
run: pnpm run build:packages
- name: 📦 Generate changeset(s) from commit messages
run: pnpm changeset:conventional
- name: 🤝 Create release PR or 📦 Publish
id: changesets
uses: changesets/action@v1
with:
createGithubReleases: true
version: pnpm run version
publish: pnpm run release
setupGitUser: true
commit: |
ci(release): Release packages and bump versions
Congratulations on the new release! 🎉
This is an automated commit triggered by the `release` workflow.
title: 🚀 Release packages
- name: 🫨 Create Unstable Release
if: steps.changesets.outputs.published != 'true'
run: |
git checkout master
pnpm run version:unstable
pnpm run release:unstable