-
Notifications
You must be signed in to change notification settings - Fork 0
150 lines (141 loc) · 4.39 KB
/
release.yml
File metadata and controls
150 lines (141 loc) · 4.39 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
145
146
147
148
149
150
name: release
on:
push:
tags: ["v*"]
workflow_dispatch:
inputs:
version:
description: "Version to release (x.y.z)"
required: true
type: string
jobs:
build:
runs-on: ubuntu-latest
permissions:
contents: read
steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v4
with:
node-version: 20.x
cache: npm
- name: Sync version from tag or input
if: startsWith(github.ref, 'refs/tags/') || (github.event_name == 'workflow_dispatch' && github.event.inputs.version != '')
env:
VERSION_INPUT: ${{ github.event.inputs.version }}
run: |
if [[ "${GITHUB_REF_NAME}" == v* ]]; then
version="${GITHUB_REF_NAME#v}"
else
version="${VERSION_INPUT}"
fi
node scripts/sync-version.mjs --version "$version"
- run: npm ci
- run: npm run build
- run: npm test
- name: Package artifacts
run: |
mkdir -p dist-artifacts
tar -czf dist-artifacts/mermkit-packages.tgz packages/*/dist
tar -czf dist-artifacts/mermkit-bindings.tgz bindings
- uses: actions/upload-artifact@v4
with:
name: mermkit-artifacts
path: dist-artifacts
github-release:
runs-on: ubuntu-latest
needs: build
permissions:
contents: write
steps:
- uses: actions/checkout@v4
- uses: softprops/action-gh-release@v2
with:
generate_release_notes: true
publish-npm:
runs-on: ubuntu-latest
needs: build
environment: release
permissions:
contents: read
id-token: write
steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v4
with:
node-version: 20.x
registry-url: https://registry.npmjs.org
cache: npm
- name: Sync version from tag or input
if: startsWith(github.ref, 'refs/tags/') || (github.event_name == 'workflow_dispatch' && github.event.inputs.version != '')
env:
VERSION_INPUT: ${{ github.event.inputs.version }}
run: |
if [[ "${GITHUB_REF_NAME}" == v* ]]; then
version="${GITHUB_REF_NAME#v}"
else
version="${VERSION_INPUT}"
fi
node scripts/sync-version.mjs --version "$version"
# IMPORTANT for OIDC: npm CLI must be new enough
- run: npm i -g npm@^11.5.1
- run: npm ci
- run: npm run build
- run: npm run publish:npm
env:
NODE_AUTH_TOKEN: ""
NPM_TOKEN: ""
publish-pypi:
runs-on: ubuntu-latest
needs: build
environment: release
permissions:
contents: read
id-token: write
steps:
- uses: actions/checkout@v4
- uses: actions/setup-python@v5
with:
python-version: "3.11"
- name: Sync version from tag or input
if: startsWith(github.ref, 'refs/tags/') || (github.event_name == 'workflow_dispatch' && github.event.inputs.version != '')
env:
VERSION_INPUT: ${{ github.event.inputs.version }}
run: |
if [[ "${GITHUB_REF_NAME}" == v* ]]; then
version="${GITHUB_REF_NAME#v}"
else
version="${VERSION_INPUT}"
fi
node scripts/sync-version.mjs --version "$version"
- run: python -m pip install --upgrade pip build
- run: python -m build
working-directory: bindings/python
- uses: pypa/gh-action-pypi-publish@release/v1
with:
packages-dir: bindings/python/dist
publish-crates:
runs-on: ubuntu-latest
needs: build
permissions:
contents: read
steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v4
with:
node-version: 20.x
- uses: dtolnay/rust-toolchain@stable
- name: Sync version from tag or input
if: startsWith(github.ref, 'refs/tags/') || (github.event_name == 'workflow_dispatch' && github.event.inputs.version != '')
env:
VERSION_INPUT: ${{ github.event.inputs.version }}
run: |
if [[ "${GITHUB_REF_NAME}" == v* ]]; then
version="${GITHUB_REF_NAME#v}"
else
version="${VERSION_INPUT}"
fi
node scripts/sync-version.mjs --version "$version"
- run: npm run publish:crates
env:
CARGO_REGISTRY_TOKEN: ${{ secrets.CARGO_REGISTRY_TOKEN }}