-
Notifications
You must be signed in to change notification settings - Fork 0
executable file
·102 lines (85 loc) · 2.9 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
name: "Deep Focus CI/CD and Release Workflow"
on:
pull_request:
paths:
- "**/*.ts"
- "**/*.tsx"
- "**/*.js"
- "package.json"
- "package-lock.json"
push:
branches:
- main
paths:
- "**/*.ts"
- "**/*.js"
- "package.json"
- "package-lock.json"
- ".github/workflows/release.yml"
permissions:
contents: write
issues: write
pull-requests: write
id-token: write
jobs:
build-and-release:
runs-on: macos-latest
env:
CI_JOB_NUMBER: 1
steps:
- name: Checkout code
uses: actions/checkout@v4
with:
fetch-depth: 0
- name: Setup Node.js
uses: actions/setup-node@v4
with:
node-version: 'lts/*'
- name: Install dependencies
run: npm install
- name: Install Code Signing Certificate
run: |
echo "$CERTIFICATE_P12" | base64 --decode > Certificates.p12
security import Certificates.p12 -P "$CERTIFICATE_PASSWORD" -A
security unlock-keychain -p "$CERTIFICATE_PASSWORD" /Users/runner/Library/Keychains/login.keychain-db
security set-key-partition-list -S apple-tool:,apple: -s -k "$CERTIFICATE_PASSWORD" /Users/runner/Library/Keychains/login.keychain-db
env:
CERTIFICATE_P12: ${{ secrets.CERTIFICATE_P12 }}
CERTIFICATE_PASSWORD: ${{ secrets.CERTIFICATE_PASSWORD }}
- name: Store Notarization Credentials
run: |
xcrun notarytool store-credentials --apple-id "timwillie73@gmail.com" --team-id "3Y4F3KTSJA" --password ${{ secrets.APPLE_APP_PASSWORD }} --keychain-profile "notary"
- name: Run Linting
run: npm run lint
- name: Build Electron App
run: npm run make
- name: Package as Zip
run: |
mkdir -p release
zip -r release/DeepFocus-${{ github.run_number }}.zip out/make/*
- name: Analyze and Create Bundle Size Badge
uses: timeowilliams/package-size-badge-action@v1.0.7
with:
path: ".vite/build/*.js"
limit: "800"
label: "Bundle Size"
color: "green"
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
- name: Verify Package Integrity
run: npm audit
- name: Run Semantic Release
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
run: npx semantic-release
- name: Set Release Tag
id: set_tag
run: echo "RELEASE_TAG=$(git describe --tags $(git rev-list --tags --max-count=1))" >> $GITHUB_ENV
- name: Notarize App
run: |
xcrun notarytool submit release/DeepFocus-${{ github.run_number }}.zip --keychain-profile "notary" --wait
- name: Upload Release Artifact
uses: actions/upload-artifact@v4
with:
name: DeepFocus-${{ steps.set_tag.outputs.RELEASE_TAG }}-mac.zip
path: release/DeepFocus-${{ github.run_number }}.zip