-
Notifications
You must be signed in to change notification settings - Fork 10
135 lines (120 loc) · 4.33 KB
/
stage.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
---
name: Stage
on:
workflow_dispatch:
push:
branches:
- main
paths-ignore:
- ".github/**"
jobs:
package:
strategy:
matrix:
include:
- os: macos-latest
targets: "darwin-x64,darwin-arm64"
- os: ubuntu-latest
targets: "linux-x64,linux-arm64"
- os: windows-latest
targets: "win32-x64"
name: Create a VSIX package for targets [ ${{ matrix.targets }} ]
runs-on: ${{ matrix.os }}
steps:
- name: Checkout sources
uses: actions/checkout@v4
- name: Install node 20
uses: actions/setup-node@v4
with:
node-version: '20'
cache: npm
- name: Install project modules
run: npm ci
- name: Create a VSIX package for targets [ ${{ matrix.targets }} ]
shell: bash
run: >
echo "${{ matrix.targets }}" | tr "," "\n" | while read -r target; do
npm run vsce:package -- \
--pre-release --target ${target} \
--out ocm-vscode-extension-${target}-early-access.vsix
done
- name: Upload VSIX package as artifact
uses: actions/upload-artifact@v4
with:
name: vsix
path: ./*.vsix
release:
runs-on: ubuntu-latest
name: Create an Early-access release
if: github.repository_owner == 'open-cluster-management-io'
needs: package
steps:
- name: Checkout sources
uses: actions/checkout@v4
with:
fetch-depth: 0
token: ${{ secrets.OCM_BOT_PAT }}
- name: Download VSIX package artifacts
uses: actions/download-artifact@v4
with:
name: vsix
path: ./vsix
- name: Check for existing EA release
id: existing_release
uses: actions/github-script@v7
continue-on-error: true
with:
github-token: ${{ secrets.OCM_BOT_PAT }}
script: |
const repo_name = context.payload.repository.full_name
var response = await github.request('GET /repos/' + repo_name + '/releases/tags/early-access')
// if the request fails (ie 404) the next steps will not occur and the output will not be set
core.setOutput('id', response.data.id)
- name: Delete EA release if exists
if: ${{ steps.existing_release.outputs.id }}
uses: actions/github-script@v7
with:
github-token: ${{ secrets.OCM_BOT_PAT }}
script: |
const repo_name = context.payload.repository.full_name
await github.request('DELETE /repos/' + repo_name + '/releases/' + ${{ steps.existing_release.outputs.id }})
- name: Delete EA tag if exists
continue-on-error: true
run: git push --delete origin early-access
# a little pause between deleting the release and creating a new one
# without it, the new release might be a weird release, i.e. a draft release which is not deleted with the previous step
- name: Sleep 5
run: sleep 5
- name: Create new EA release
id: new_release
uses: actions/github-script@v7
with:
github-token: ${{ secrets.OCM_BOT_PAT }}
script: |
const repo_name = context.payload.repository.full_name
const response = await github.request('POST /repos/' + repo_name + '/releases', {
tag_name: 'early-access',
name: 'Early-access',
prerelease: true,
generate_release_notes: true
})
core.setOutput('upload_url', response.data.upload_url)
- name: Create SHA256 checksums for the VSIX packages
working-directory: vsix
run: |
for pkg in *.vsix
do
sha_file=$(echo $pkg | sed 's/\.vsix/\.sha256/g')
sha256sum $pkg > $sha_file
done
- name: Upload packages and checksums as EA release assets
run: |
for file in ./vsix/*.{vsix,sha256}
do
asset_name=$(basename $file)
upload_url=$(echo "${{ steps.new_release.outputs.upload_url }}" | sed "s/{?name,label}/?name=$asset_name/g")
curl --data-binary @"$file" \
-H "Authorization: token ${{ secrets.OCM_BOT_PAT }}" \
-H "Content-Type: application/octet-stream" \
$upload_url
done