-
-
Notifications
You must be signed in to change notification settings - Fork 102
123 lines (109 loc) · 4.23 KB
/
smoke-tests-cli.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
name: SmokeTests - CLI
on:
push:
branches: [ main ]
jobs:
precheck:
if: github.repository == 'jreleaser/jreleaser' && startsWith(github.event.head_commit.message, 'Releasing version') != true
runs-on: ubuntu-latest
outputs:
VERSION: ${{ steps.vars.outputs.VERSION }}
steps:
- name: Checkout
uses: actions/checkout@v3
- uses: n1hility/cancel-previous-runs@v2
with:
token: ${{ secrets.GITHUB_TOKEN }}
- name: Version
id: vars
shell: bash
run: |
version=$(cat VERSION)
echo "VERSION=$(echo "$version")" >>$GITHUB_OUTPUT
build:
needs: [ precheck ]
if: endsWith(${{ needs.precheck.outputs.VERSION }}, '-SNAPSHOT')
name: 'Build ${{ matrix.job.os }}-${{ matrix.job.sign }}'
strategy:
fail-fast: false
matrix:
job:
- { os: macos-latest , sign: gpg , args: '-xp docker' }
- { os: macos-latest , sign: cosign, args: '-xp docker' }
- { os: ubuntu-latest , sign: gpg , args: '' }
- { os: ubuntu-latest , sign: cosign, args: '' }
- { os: windows-latest, sign: gpg , args: '-xp docker' }
- { os: windows-latest, sign: cosign, args: '-xp docker' }
runs-on: ${{ matrix.job.os }}
steps:
- name: Checkout
uses: actions/checkout@v3
with:
fetch-depth: 0
- name: Setup Java
uses: actions/setup-java@v3
with:
java-version: 11
distribution: 'zulu'
- uses: actions/cache@v3
with:
path: ~/.gradle/caches
key: ${{ runner.os }}-gradle-${{ hashFiles('**/*.gradle') }}-${{ hashFiles('**/gradle.properties') }}
restore-keys: |
${{ runner.os }}-gradle-
- uses: actions/cache@v3
with:
path: ~/.gradle/wrapper
key: ${{ runner.os }}-gradlew-${{ hashFiles('**/gradlew') }}
restore-keys: |
${{ runner.os }}-gradlew-
- name: Build
run: ./gradlew -Prelease=true build -S
- name: Prepare
shell: bash
run: |
unzip -qo plugins/jreleaser/build/distributions/jreleaser-${{ needs.precheck.outputs.VERSION }}.zip
cp .github/test-files/jreleaser-${{ matrix.job.sign }}.yml jreleaser.yml
- name: Assemble
shell: bash
run: |
./jreleaser-${{ needs.precheck.outputs.VERSION }}/bin/jreleaser assemble
env:
JRELEASER_PROJECT_VERSION: ${{ needs.precheck.outputs.VERSION }}
JRELEASER_GITHUB_TOKEN: ${{ secrets.GIT_ACCESS_TOKEN }}
- name: JReleaser assemble output
if: always()
uses: actions/upload-artifact@v3
with:
retention-days: 10
name: 'jreleaser-assemble-cli-${{ runner.os }}-${{ matrix.job.sign }}'
path: |
out/jreleaser/trace.log
out/jreleaser/output.properties
- name: Full Release
shell: bash
run: |
./jreleaser-${{ needs.precheck.outputs.VERSION }}/bin/jreleaser full-release --dry-run ${{ matrix.job.args }}
env:
JRELEASER_PROJECT_VERSION: ${{ needs.precheck.outputs.VERSION }}
JRELEASER_GITHUB_TOKEN: ${{ secrets.GIT_ACCESS_TOKEN }}
JRELEASER_GPG_PASSPHRASE: ${{ secrets.GPG_PASSPHRASE }}
JRELEASER_GPG_PUBLIC_KEY: ${{ secrets.GPG_PUBLIC_KEY }}
JRELEASER_GPG_SECRET_KEY: ${{ secrets.GPG_SECRET_KEY }}
JRELEASER_COSIGN_PASSWORD: ${{ secrets.COSIGN_PASSWORD }}
JRELEASER_DOCKER_DEFAULT_PASSWORD: ${{ secrets.JRELEASER_DOCKER_PASSWORD }}
JRELEASER_S3_JRELEASER_REGION: ${{ secrets.S3_REGION }}
JRELEASER_S3_JRELEASER_BUCKET: ${{ secrets.S3_BUCKET }}
JRELEASER_S3_JRELEASER_ACCESS_KEY_ID: ${{ secrets.S3_ACCESS_KEY_ID }}
JRELEASER_S3_JRELEASER_SECRET_KEY: ${{ secrets.S3_SECRET_KEY }}
- name: JReleaser full-release output
if: always()
uses: actions/upload-artifact@v3
with:
retention-days: 10
name: 'jreleaser-full-release-cli-${{ runner.os }}-${{ matrix.job.sign }}'
path: |
out/jreleaser/trace.log
out/jreleaser/output.properties
out/jreleaser/release/CHANGELOG.md
out/jreleaser/prepare