15
15
tags : [v*]
16
16
17
17
env :
18
- PGP_PASSPHRASE : ${{ secrets.PGP_PASSPHRASE }}
19
- SONATYPE_PASSWORD : ${{ secrets.SONATYPE_PASSWORD }}
20
- SONATYPE_CREDENTIAL_HOST : ${{ secrets.SONATYPE_CREDENTIAL_HOST }}
21
- SONATYPE_USERNAME : ${{ secrets.SONATYPE_USERNAME }}
22
- PGP_SECRET : ${{ secrets.PGP_SECRET }}
23
18
GITHUB_TOKEN : ${{ secrets.GITHUB_TOKEN }}
24
19
20
+
21
+ concurrency :
22
+ group : ${{ github.workflow }} @ ${{ github.ref }}
23
+ cancel-in-progress : true
24
+
25
25
jobs :
26
26
build :
27
- name : Build and Test
27
+ name : Test
28
28
strategy :
29
29
matrix :
30
- os : [ubuntu-latest ]
31
- scala : [2.13.11 , 3.3.0 ]
30
+ os : [ubuntu-22.04 ]
31
+ scala : [2.13, 3]
32
32
java : [temurin@8]
33
33
runs-on : ${{ matrix.os }}
34
+ timeout-minutes : 60
34
35
steps :
35
36
- name : Checkout current branch (full)
36
- uses : actions/checkout@v3
37
+ uses : actions/checkout@v4
37
38
with :
38
39
fetch-depth : 0
39
40
40
- - name : Download Java (temurin@8)
41
- id : download-java-temurin-8
42
- if : matrix.java == 'temurin@8'
43
- uses : typelevel/download-java@v2
44
- with :
45
- distribution : temurin
46
- java-version : 8
41
+ - name : Setup sbt
42
+ uses : sbt/setup-sbt@v1
47
43
48
44
- name : Setup Java (temurin@8)
45
+ id : setup-java-temurin-8
49
46
if : matrix.java == 'temurin@8'
50
- uses : actions/setup-java@v3
47
+ uses : actions/setup-java@v4
51
48
with :
52
- distribution : jdkfile
49
+ distribution : temurin
53
50
java-version : 8
54
- jdkFile : ${{ steps.download-java-temurin-8.outputs.jdkFile }}
51
+ cache : sbt
55
52
56
- - name : Cache sbt
57
- uses : actions/cache@v3
58
- with :
59
- path : |
60
- ~/.sbt
61
- ~/.ivy2/cache
62
- ~/.coursier/cache/v1
63
- ~/.cache/coursier/v1
64
- ~/AppData/Local/Coursier/Cache/v1
65
- ~/Library/Caches/Coursier/v1
66
- key : ${{ runner.os }}-sbt-cache-v2-${{ hashFiles('**/*.sbt') }}-${{ hashFiles('project/build.properties') }}
53
+ - name : sbt update
54
+ if : matrix.java == 'temurin@8' && steps.setup-java-temurin-8.outputs.cache-hit == 'false'
55
+ run : sbt +update
67
56
68
57
- name : Check that workflows are up to date
69
58
run : sbt githubWorkflowCheck
70
59
71
60
- name : Check headers and formatting
72
- if : matrix.java == 'temurin@8' && matrix.os == 'ubuntu-latest '
61
+ if : matrix.java == 'temurin@8' && matrix.os == 'ubuntu-22.04 '
73
62
run : sbt '++ ${{ matrix.scala }}' headerCheckAll scalafmtCheckAll 'project /' scalafmtSbtCheck
74
63
75
64
- name : Test
76
65
run : sbt '++ ${{ matrix.scala }}' test
77
66
78
67
- name : Check binary compatibility
79
- if : matrix.java == 'temurin@8' && matrix.os == 'ubuntu-latest '
68
+ if : matrix.java == 'temurin@8' && matrix.os == 'ubuntu-22.04 '
80
69
run : sbt '++ ${{ matrix.scala }}' mimaReportBinaryIssues
81
70
82
71
- name : Generate API documentation
83
- if : matrix.java == 'temurin@8' && matrix.os == 'ubuntu-latest '
72
+ if : matrix.java == 'temurin@8' && matrix.os == 'ubuntu-22.04 '
84
73
run : sbt '++ ${{ matrix.scala }}' doc
85
74
86
75
- name : Make target directories
87
76
if : github.event_name != 'pull_request' && (startsWith(github.ref, 'refs/tags/v') || github.ref == 'refs/heads/main')
88
- run : mkdir -p target project/target
77
+ run : mkdir -p target core/.jvm/target core/.native/target core/.js/target project/target
89
78
90
79
- name : Compress target directories
91
80
if : github.event_name != 'pull_request' && (startsWith(github.ref, 'refs/tags/v') || github.ref == 'refs/heads/main')
92
- run : tar cf targets.tar target project/target
81
+ run : tar cf targets.tar target core/.jvm/target core/.native/target core/.js/target project/target
93
82
94
83
- name : Upload target directories
95
84
if : github.event_name != 'pull_request' && (startsWith(github.ref, 'refs/tags/v') || github.ref == 'refs/heads/main')
96
- uses : actions/upload-artifact@v3
85
+ uses : actions/upload-artifact@v4
97
86
with :
98
87
name : target-${{ matrix.os }}-${{ matrix.java }}-${{ matrix.scala }}
99
88
path : targets.tar
@@ -104,73 +93,71 @@ jobs:
104
93
if : github.event_name != 'pull_request' && (startsWith(github.ref, 'refs/tags/v') || github.ref == 'refs/heads/main')
105
94
strategy :
106
95
matrix :
107
- os : [ubuntu-latest ]
96
+ os : [ubuntu-22.04 ]
108
97
java : [temurin@8]
109
98
runs-on : ${{ matrix.os }}
110
99
steps :
111
100
- name : Checkout current branch (full)
112
- uses : actions/checkout@v3
101
+ uses : actions/checkout@v4
113
102
with :
114
103
fetch-depth : 0
115
104
116
- - name : Download Java (temurin@8)
117
- id : download-java-temurin-8
118
- if : matrix.java == 'temurin@8'
119
- uses : typelevel/download-java@v2
120
- with :
121
- distribution : temurin
122
- java-version : 8
105
+ - name : Setup sbt
106
+ uses : sbt/setup-sbt@v1
123
107
124
108
- name : Setup Java (temurin@8)
109
+ id : setup-java-temurin-8
125
110
if : matrix.java == 'temurin@8'
126
- uses : actions/setup-java@v3
111
+ uses : actions/setup-java@v4
127
112
with :
128
- distribution : jdkfile
113
+ distribution : temurin
129
114
java-version : 8
130
- jdkFile : ${{ steps.download-java-temurin-8.outputs.jdkFile }}
115
+ cache : sbt
131
116
132
- - name : Cache sbt
133
- uses : actions/cache@v3
134
- with :
135
- path : |
136
- ~/.sbt
137
- ~/.ivy2/cache
138
- ~/.coursier/cache/v1
139
- ~/.cache/coursier/v1
140
- ~/AppData/Local/Coursier/Cache/v1
141
- ~/Library/Caches/Coursier/v1
142
- key : ${{ runner.os }}-sbt-cache-v2-${{ hashFiles('**/*.sbt') }}-${{ hashFiles('project/build.properties') }}
143
-
144
- - name : Download target directories (2.13.11)
145
- uses : actions/download-artifact@v3
117
+ - name : sbt update
118
+ if : matrix.java == 'temurin@8' && steps.setup-java-temurin-8.outputs.cache-hit == 'false'
119
+ run : sbt +update
120
+
121
+ - name : Download target directories (2.13)
122
+ uses : actions/download-artifact@v4
146
123
with :
147
- name : target-${{ matrix.os }}-${{ matrix.java }}-2.13.11
124
+ name : target-${{ matrix.os }}-${{ matrix.java }}-2.13
148
125
149
- - name : Inflate target directories (2.13.11 )
126
+ - name : Inflate target directories (2.13)
150
127
run : |
151
128
tar xf targets.tar
152
129
rm targets.tar
153
130
154
- - name : Download target directories (3.3.0 )
155
- uses : actions/download-artifact@v3
131
+ - name : Download target directories (3)
132
+ uses : actions/download-artifact@v4
156
133
with :
157
- name : target-${{ matrix.os }}-${{ matrix.java }}-3.3.0
134
+ name : target-${{ matrix.os }}-${{ matrix.java }}-3
158
135
159
- - name : Inflate target directories (3.3.0 )
136
+ - name : Inflate target directories (3)
160
137
run : |
161
138
tar xf targets.tar
162
139
rm targets.tar
163
140
164
141
- name : Import signing key
165
142
if : env.PGP_SECRET != '' && env.PGP_PASSPHRASE == ''
166
- run : echo $PGP_SECRET | base64 -di | gpg --import
143
+ env :
144
+ PGP_SECRET : ${{ secrets.PGP_SECRET }}
145
+ PGP_PASSPHRASE : ${{ secrets.PGP_PASSPHRASE }}
146
+ run : echo $PGP_SECRET | base64 -d -i - | gpg --import
167
147
168
148
- name : Import signing key and strip passphrase
169
149
if : env.PGP_SECRET != '' && env.PGP_PASSPHRASE != ''
150
+ env :
151
+ PGP_SECRET : ${{ secrets.PGP_SECRET }}
152
+ PGP_PASSPHRASE : ${{ secrets.PGP_PASSPHRASE }}
170
153
run : |
171
- echo "$PGP_SECRET" | base64 -di > /tmp/signing-key.gpg
154
+ echo "$PGP_SECRET" | base64 -d -i - > /tmp/signing-key.gpg
172
155
echo "$PGP_PASSPHRASE" | gpg --pinentry-mode loopback --passphrase-fd 0 --import /tmp/signing-key.gpg
173
156
(echo "$PGP_PASSPHRASE"; echo; echo) | gpg --command-fd 0 --pinentry-mode loopback --change-passphrase $(gpg --list-secret-keys --with-colons 2> /dev/null | grep '^sec:' | cut --delimiter ':' --fields 5 | tail -n 1)
174
157
175
158
- name : Publish
159
+ env :
160
+ SONATYPE_USERNAME : ${{ secrets.SONATYPE_USERNAME }}
161
+ SONATYPE_PASSWORD : ${{ secrets.SONATYPE_PASSWORD }}
162
+ SONATYPE_CREDENTIAL_HOST : ${{ secrets.SONATYPE_CREDENTIAL_HOST }}
176
163
run : sbt tlCiRelease
0 commit comments