-
Notifications
You must be signed in to change notification settings - Fork 4
173 lines (146 loc) · 4.91 KB
/
release.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
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
name: release
concurrency: ${{ github.workflow }}-${{ github.ref }}
on:
push:
branches:
- main
workflow_dispatch:
inputs:
force_github_package_release:
description: Force GPM release
type: boolean
required: false
default: false
jobs:
install-deps:
name: 📦 Install dependencies
if: github.repository == 'lukemorales/next-safe-navigation' && github.event_name != 'pull_request'
runs-on: ubuntu-latest
steps:
- name: 🔑 Checkout Repository
uses: actions/checkout@v4
- name: 🔧 Install Bun
uses: oven-sh/setup-bun@v1
with:
bun-version: latest
- name: ♻️ Cache node_modules
uses: actions/cache@v4
id: cache
with:
path: "**/node_modules"
key: ${{ runner.os }}-node-${{ hashFiles('**/bun.lockb') }}
- run: bun install --frozen-lockfile
build:
name: 🏗️ Build package
runs-on: ubuntu-latest
needs: install-deps
steps:
- name: 🔑 Checkout Repository
uses: actions/checkout@v4
- name: 🔧 Install Bun
uses: oven-sh/setup-bun@v1
with:
bun-version: latest
- name: 📦 Install dependencies
if: steps.cache.outputs.cache-hit != 'true'
run: bun install --frozen-lockfile
- name: 🚨 Check for errors
run: bun run lint
- name: 🧪 Run tests
run: bun run test:ci
- name: ⚒️ Build package
run: bun run build
release:
name: 🚀 Release to NPM
if: github.event.inputs.force_github_package_release != 'true'
runs-on: ubuntu-latest
needs: build
outputs:
published: ${{ steps.changesets.outputs.published }}
steps:
- name: 🔑 Checkout Repository
uses: actions/checkout@v4
with:
fetch-depth: 0
- name: 🔧 Install Bun
uses: oven-sh/setup-bun@v1
with:
bun-version: latest
- name: ♻️ Load node_modules
uses: actions/cache@v4
with:
path: "**/node_modules"
key: ${{ runner.os }}-node-${{ hashFiles('**/bun.lockb') }}
- name: ♻️ Load build files
uses: actions/cache@v4
with:
path: "**/dist"
key: ${{ runner.os }}-build-${{ hashFiles('**/bun.lockb') }}
- name: 🛠️ Setup Node for NPM
uses: actions/setup-node@v4
with:
node-version: '20.x'
check-latest: true
registry-url: 'https://registry.npmjs.org'
- name: 👤 Set git user
run: |
git config --global user.email "[email protected]"
git config --global user.name "Luke Morales"
- name: 🚀 Create Changesets Pull Request or Publish to NPM
id: changesets
uses: changesets/action@v1
with:
setupGitUser: false
title: "chore(changesets): bump package version"
commit: "chore: bump package version"
version: node .github/changeset-version.js
publish: bun run release
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
NPM_TOKEN: ${{ secrets.NPM_TOKEN }}
gpm-release:
name: 🚀 Release to GitHub Package Manager
if: ${{ github.event.inputs.force_github_package_release == 'true' || needs.release.outputs.published == 'true' }}
runs-on: ubuntu-latest
needs: [build]
permissions:
packages: write
contents: read
steps:
- name: 🔑 Checkout Repository
uses: actions/checkout@v4
- name: 🔧 Install Bun
uses: oven-sh/setup-bun@v1
with:
bun-version: latest
- name: ♻️ Load node_modules
uses: actions/cache@v4
with:
path: "**/node_modules"
key: ${{ runner.os }}-node-${{ hashFiles('**/bun.lockb') }}
- name: ♻️ Load build files
uses: actions/cache@v4
with:
path: "**/dist"
key: ${{ runner.os }}-build-${{ hashFiles('**/bun.lockb') }}
- name: 🛠️ Setup Node for GPM
uses: actions/setup-node@v4
with:
node-version: '20.x'
check-latest: true
registry-url: 'https://npm.pkg.github.com'
- name: 📦 Install dependencies
if: steps.cache.outputs.cache-hit != 'true'
run: bun install --frozen-lockfile
- name: 🏷️ Overwrite package name with user scope
uses: sergeysova/jq-action@v2
with:
cmd: echo "$( jq '.name="@${{ github.repository }}"' package.json )" > package.json
- name: 🚀 Publish to GPM
run: |
echo "//npm.pkg.github.com/:_authToken=${{ env.NODE_AUTH_TOKEN }}" >> .npmrc
echo "@${{ github.repository_owner }}:registry=https://npm.pkg.github.com" >> .npmrc
npm publish --registry=https://npm.pkg.github.com
env:
NODE_AUTH_TOKEN: ${{ secrets.GITHUB_TOKEN }}