-
Notifications
You must be signed in to change notification settings - Fork 1
89 lines (88 loc) · 2.75 KB
/
build-and-deploy.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
name: CI/CD Process
on:
workflow_call:
workflow_dispatch:
jobs:
# Runs all tests
build:
strategy:
fail-fast: false
matrix:
os: [ windows, macos, ubuntu ]
runs-on: ${{ matrix.os }}-latest
timeout-minutes: 120
steps:
- name: Checkout
uses: DanySK/[email protected]
- uses: DanySK/[email protected]
with:
retries-on-failure: 3
build-command: >-
# ./gradlew build --parallel
true
check-command: true
deploy-command: >-
./gradlew uploadAllPublicationsToMavenCentralNexus close drop --parallel
should-run-codecov: ${{ runner.os == 'Linux' }}
should-deploy: >-
${{
runner.os == 'Linux'
&& !github.event.repository.fork
&& github.event_name != 'pull_request'
}}
maven-central-username: ${{ secrets.MAVEN_CENTRAL_USERNAME }}
maven-central-password: ${{ secrets.MAVEN_CENTRAL_PASSWORD }}
signing-key: ${{ secrets.SIGNING_KEY }}
signing-password: ${{ secrets.SIGNING_PASSWORD }}
# Performs a release if needed
release:
permissions:
contents: write
needs:
- build
runs-on: ubuntu-latest
if: >-
!github.event.repository.fork
&& github.event_name != 'pull_request'
concurrency:
group: release-${{ github.event.number || github.ref }}
cancel-in-progress: false
timeout-minutes: 120
steps:
- name: Checkout
uses: actions/[email protected]
with:
submodules: recursive
token: ${{ secrets.DEPLOYMENT_TOKEN }}
- name: Install Node
uses: actions/[email protected]
with:
node-version-file: package.json
- uses: DanySK/[email protected]
with:
retries-on-failure: 1
build-command: true
check-command: true
deploy-command: |
npm install
npx semantic-release
should-run-codecov: false
should-deploy: true
github-token: ${{ secrets.DEPLOYMENT_TOKEN }}
maven-central-username: ${{ secrets.MAVEN_CENTRAL_USERNAME }}
maven-central-password: ${{ secrets.MAVEN_CENTRAL_PASSWORD }}
signing-key: ${{ secrets.SIGNING_KEY }}
signing-password: ${{ secrets.SIGNING_PASSWORD }}
success:
runs-on: ubuntu-latest
needs:
- build
- release
if: >-
always() && (
contains(join(needs.*.result, ','), 'failure')
|| !contains(join(needs.*.result, ','), 'cancelled')
)
steps:
- name: Verify that there were no failures
run: ${{ !contains(join(needs.*.result, ','), 'failure') }}