generated from typerefinery-ai/template-electron-vuex-vuetify
-
Notifications
You must be signed in to change notification settings - Fork 2
321 lines (279 loc) · 9.94 KB
/
pipeline.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
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
name: pipeline
on:
push:
branches:
- "*"
tags:
- "*"
pull_request:
types: [opened, reopened, synchronize]
# Sets permissions of the GITHUB_TOKEN to allow deployment to GitHub Pages
permissions:
contents: write
pages: write
id-token: write
# Allow one concurrent deployment
concurrency:
group: ${{ github.ref }}
cancel-in-progress: true
jobs:
branch-naming-rules:
if: "!contains(github.event.head_commit.message , 'skip ci')"
runs-on: ubuntu-latest
steps:
- name: Check branch name
uses: deepakputhraya/action-branch-name@master
if: "!startsWith(github.ref, 'refs/tags/')"
with:
regex: '([a-z])+\/([#0-9a-z-])+' # Regex the branch should match. This example enforces grouping
allowed_prefixes: "feature,stable,fix" # All branches should start with the given prefix
ignore: main,master,develop # Ignore exactly matching branch names from convention
min_length: 5 # Min length of the branch name
max_length: 200 # Max length of the branch names
- name: Skipped
if: "startsWith(github.ref, 'refs/tags/')"
run: echo "skipped"
unit-test:
needs: [branch-naming-rules]
name: ${{ matrix.friendlyName }}
runs-on: ${{ matrix.os }}
strategy:
matrix:
node: [18.20.4]
os: [
# macos-latest,
# ubuntu-latest,
windows-latest
]
include:
- os: windows-latest
friendlyName: Unit Test - Windows
# - os: ubuntu-latest
# friendlyName: Unit Test - Ubuntu
# - os: macos-latest
# friendlyName: Unit Test - MacOS
steps:
- name: Check out Git repository
uses: actions/checkout@v3
- name: Install Node.js, NPM and Yarn
uses: actions/setup-node@v3
with:
node-version: ${{ matrix.node }}
# - name: Get npm cache directory
# id: npm-cache-dir
# run: |
# echo "::set-output name=dir::$(npm config get cache)"
# - name: Cache node modules
# uses: actions/cache@v3
# id: npm-cache # use this to check for `cache-hit` ==> if: steps.npm-cache.outputs.cache-hit != 'true'
# with:
# path: ${{ steps.npm-cache-dir.outputs.dir }}
# key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }}
# restore-keys: |
# ${{ runner.os }}-node-
- name: Run Install
run: |
npm install
# - name: Run Lint
# run: |
# npm run lint:style
- name: Run Typecheck
run: |
npm run typecheck
# functional-test:
# needs: [unit-test]
# if: "!contains(github.event.head_commit.message, 'skip ci') && !startsWith(github.ref, 'refs/tags/v')"
# name: ${{ matrix.friendlyName }}
# runs-on: ${{ matrix.os }}
# env:
# NODE_ENV: development
# NODE_OPTIONS: "--max_old_space_size=4096"
# CYPRESS_CACHE_FOLDER: cypress/cache
# strategy:
# matrix:
# node: [18.3.0]
# os: [windows-latest]
# include:
# - os: windows-latest
# friendlyName: Functional Test - Windows
# steps:
# - name: Check out Git repository
# uses: actions/checkout@v3
# - name: Install Node.js, NPM and Yarn
# uses: actions/setup-node@v3
# with:
# node-version: ${{ matrix.node }}
# - name: Get npm cache directory
# id: npm-cache-dir
# run: |
# echo "::set-output name=dir::$(npm config get cache)"
# - name: Cache node modules
# uses: actions/cache@v3
# id: npm-cache # use this to check for `cache-hit` ==> if: steps.npm-cache.outputs.cache-hit != 'true'
# with:
# path: ${{ steps.npm-cache-dir.outputs.dir }}
# key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }}
# restore-keys: |
# ${{ runner.os }}-node-
# - name: Cache Cypress Binary
# id: cache-cypress-binary
# uses: actions/cache@v3
# with:
# path: cypress/cache
# #key: cypress-binary-${{ hashFiles('package-lock.json') }}
# key: ${{ runner.os }}-cypress-${{ hashFiles('**/package-lock.json') }}
# - name: Run Install
# run: |
# npm install
# - name: Cypress run
# uses: cypress-io/github-action@v4
# with:
# config: pageLoadTimeout=250000,baseUrl=http://localhost:3000
# wait-on: "http://localhost:3000"
# install: false
# build: |
# npm run build
# start: |
# npm run preview:wait:ci
# command: |
# npm run test:ci
# record: true
# env:
# CYPRESS_RECORD_KEY: ${{ secrets.CYPRESS_RECORD_KEY }}
# CYPRESS_PROJECT_ID: ${{ secrets.CYPRESS_PROJECT_ID }}
# GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
# COMMIT_INFO_MESSAGE: ${{ github.event.inputs.title }}
# - name: Generate Reports
# if: always()
# run: |
# npm run posttest
# # # This workaround is required for running npm install
# # - name: Set permissions
# # run: |
# # chmod -R 777 ./
# # - name: Run Cypress using Docker
# # id: cypress
# # continue-on-error: true
# # run: |
# # docker compose --profile testing up --exit-code-from cypress
# # - name: Generate Reports using Docker
# # continue-on-error: true
# # run: |
# # docker compose --profile reports up reports
# - name: Deploy Reports to gh-pages
# uses: JamesIves/github-pages-deploy-action@v4.2.5
# with:
# branch: gh-pages
# folder: cypress/reports
release:
needs: [unit-test]
if: "!contains(github.event.head_commit.message, 'skip ci')"
name: ${{ matrix.friendlyName }}
runs-on: ${{ matrix.os }}
env:
NODE_ENV: develop
strategy:
matrix:
node: [18.20.4]
os: [
# macos-latest,
# ubuntu-latest,
windows-latest
]
# os: [windows-latest]
include:
- os: windows-latest
friendlyName: Release - Windows
# - os: ubuntu-latest
# friendlyName: Release - Ubuntu
# - os: macos-latest
# friendlyName: Release - MacOS
steps:
- name: Set git to use LF
run: |
git config --global core.autocrlf false
git config --global core.eol lf
- name: Check out Git repository
uses: actions/checkout@v3
- name: Install Node.js, NPM and Yarn
uses: actions/setup-node@v3
with:
node-version: ${{ matrix.node }}
# - name: Remove service contents that are not required for this OS build.
# if: ${{ contains(matrix.os, 'windows') }}
# run: ./services/prep-win32.ps1 -DOREMOVE
# - name: Remove service contents that are not required for this OS build.
# if: ${{ contains(matrix.os, 'macos') }}
# run: bash ./services/prep-darwin.sh true
# - name: Remove service contents that are not required for this OS build.
# if: ${{ contains(matrix.os, 'linux') }}
# run: bash ./services/prep-linux.sh true
# - name: Get npm cache directory
# id: npm-cache-dir
# run: |
# echo "::set-output name=dir::$(npm config get cache)"
# - name: Cache node modules
# uses: actions/cache@v3
# id: npm-cache # use this to check for `cache-hit` ==> if: steps.npm-cache.outputs.cache-hit != 'true'
# with:
# path: ${{ steps.npm-cache-dir.outputs.dir }}
# key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }}
# restore-keys: |
# ${{ runner.os }}-node-
- name: Run Install
run: |
npm install
- name: Update node-gyp
if: ${{ contains(matrix.os, 'windows-latest') }}
run: ./.github/workflows/install-node-gyp.ps1
- name: install dmg-license
if: ${{ contains(matrix.os, 'macos') }}
run: npm i dmg-license
# - name: Install Snapcraft
# uses: samuelmeuli/action-snapcraft@v1
# # Only install Snapcraft on Ubuntu
# if: startsWith(matrix.os, 'ubuntu')
# with:
# # Log in to Snap Store
# snapcraft_token: ${{ secrets.SNAPCRAFT_TOKEN }}
# - name: Build/release Electron app
# uses: typerefinery-ai/action-electron-builder@v1
# env:
# DEBUG: electron-builder,electron-builder:*
# with:
# # GitHub token, automatically provided to the action
# # (No need to define this secret in the repo settings)
# github_token: ${{ secrets.GITHUB_TOKEN }}
# # always publish
# args: "-p always -c.releaseInfo.releaseName=\"${{ github.ref }}\""
# use_vue_cli: true
# # If the commit is tagged with a version (e.g. "v1.0.0"),
# # release the app after building
# release: ${{ startsWith(github.ref, 'refs/tags/v') }}
- name: Build electron
run: |
npm run app:build
env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
# - name: Upload Artifact
# uses: actions/upload-artifact@v3
# with:
# name: release_on_${{ matrix. os }}
# path: dist_electron/
# retention-days: 5
- name: Release
uses: softprops/action-gh-release@v1
if: startsWith(github.ref, 'refs/tags/')
with:
token: ${{ secrets.GITHUB_TOKEN }}
fail_on_unmatched_files: false
generate_release_notes: true
files: |
dist_electron/*.exe
dist_electron/*.exe.blockmap
dist_electron/*.AppImage
dist_electron/*.snap
dist_electron/*-mac.zip
dist_electron/*.dmg
dist_electron/*.dmg.blockmap
dist_electron/latest*.yml