Build Logs
cb372/cats-retry • 3.8.0:2026-01-13
Errors
0
Warnings
24
Total Lines
315
1##################################
2Clonning https://github.com/cb372/cats-retry.git into /build/repo using revision v2.1.2
3##################################
4Note: switching to 'b2e14551585e84ceb184600d054221433d259344'.
5
6You are in 'detached HEAD' state. You can look around, make experimental
7changes and commit them, and you can discard any commits you make in this
8state without impacting any branches by switching back to a branch.
9
10If you want to create a new branch to retain commits you create, you may
11do so (now or later) by using -c with the switch command. Example:
12
13 git switch -c <new-branch-name>
14
15Or undo this operation with:
16
17 git switch -
18
19Turn off this advice by setting config variable advice.detachedHead to false
20
21----
22Preparing build for 3.8.0
23Scala binary version found: 3.8
24Implicitly using source version 3.8
25Scala binary version found: 3.8
26Implicitly using source version 3.8
27Would try to apply common scalacOption (best-effort, sbt/mill only):
28Append: ,REQUIRE:-source:3.8
29Remove: ,-deprecation,-feature,-Xfatal-warnings,-Werror,MATCH:.*-Wconf.*any:e
30----
31Starting build for 3.8.0
32Execute tests: true
33sbt project found:
34Sbt version 1.5.0 is not supported, minimal supported version is 1.11.5
35Enforcing usage of sbt in version 1.11.5
36No prepare script found for project cb372/cats-retry
37##################################
38Scala version: 3.8.0
39Targets: com.github.cb372%alleycats-retry com.github.cb372%cats-retry com.github.cb372%cats-retry-mtl
40Project projectConfig: {"projects":{"exclude":[],"overrides":{}},"java":{"version":"17"},"sbt":{"commands":[],"options":[]},"mill":{"options":[]},"tests":"full","migrationVersions":[],"sourcePatches":[]}
41##################################
42Using extra scalacOptions: ,REQUIRE:-source:3.8
43Filtering out scalacOptions: ,-deprecation,-feature,-Xfatal-warnings,-Werror,MATCH:.*-Wconf.*any:e
44[sbt_options] declare -a sbt_options=()
45[process_args] java_version = '17'
46[copyRt] java9_rt = '/root/.sbt/1.0/java9-rt-ext-eclipse_adoptium_17_0_8/rt.jar'
47# Executing command line:
48java
49-Dfile.encoding=UTF-8
50-Dcommunitybuild.scala=3.8.0
51-Dcommunitybuild.project.dependencies.add=
52-Xmx7G
53-Xms4G
54-Xss8M
55-Dsbt.script=/root/.sdkman/candidates/sbt/current/bin/sbt
56-Dscala.ext.dirs=/root/.sbt/1.0/java9-rt-ext-eclipse_adoptium_17_0_8
57-jar
58/root/.sdkman/candidates/sbt/1.11.5/bin/sbt-launch.jar
59"setCrossScalaVersions 3.8.0"
60"++3.8.0 -v"
61"mapScalacOptions ",REQUIRE:-source:3.8,-Wconf:msg=can be rewritten automatically under:s" ",-deprecation,-feature,-Xfatal-warnings,-Werror,MATCH:.*-Wconf.*any:e""
62"set every credentials := Nil"
63"excludeLibraryDependency com.github.ghik:zerowaste_{scalaVersion} com.olegpy:better-monadic-for_3 org.polyvariant:better-tostring_{scalaVersion} org.wartremover:wartremover_{scalaVersion}"
64"removeScalacOptionsStartingWith -P:wartremover"
65
66moduleMappings
67"runBuild 3.8.0 """{"projects":{"exclude":[],"overrides":{}},"java":{"version":"17"},"sbt":{"commands":[],"options":[]},"mill":{"options":[]},"tests":"full","migrationVersions":[],"sourcePatches":[]}""" com.github.cb372%alleycats-retry com.github.cb372%cats-retry com.github.cb372%cats-retry-mtl"
68
69[info] welcome to sbt 1.11.5 (Eclipse Adoptium Java 17.0.8)
70[info] loading settings for project repo-build from akka.sbt, plugins.sbt...
71[info] loading project definition from /build/repo/project
72[info] compiling 2 Scala sources to /build/repo/project/target/scala-2.12/sbt-1.0/classes ...
73[info] Non-compiled module 'compiler-bridge_2.12' for Scala 2.12.20. Compiling...
74[info] Compilation completed in 8.761s.
75[info] done compiling
76[info] loading settings for project root from build.sbt...
77[info] set current project to root (in build file:/build/repo/)
78Execute setCrossScalaVersions: 3.8.0
79OpenCB::Changing crossVersion 3.3.5 -> 3.8.0 in coreJVM/crossScalaVersions
80OpenCB::Changing crossVersion 3.3.5 -> 3.8.0 in mtlRetryJVM/crossScalaVersions
81OpenCB::Changing crossVersion 3.3.5 -> 3.8.0 in coreJS/crossScalaVersions
82OpenCB::Limitting incorrect crossVersions List() -> List(2.12.13) in docs/crossScalaVersions
83OpenCB::Limitting incorrect crossVersions List() -> List(2.12.13) in root/crossScalaVersions
84OpenCB::Changing crossVersion 3.3.5 -> 3.8.0 in alleycatsRetryJVM/crossScalaVersions
85OpenCB::Changing crossVersion 3.3.5 -> 3.8.0 in mtlRetryJS/crossScalaVersions
86OpenCB::Changing crossVersion 3.3.5 -> 3.8.0 in alleycatsRetryJS/crossScalaVersions
87[info] set current project to root (in build file:/build/repo/)
88[info] Setting Scala version to 3.8.0 on 6 projects.
89[info] Switching Scala version on:
90[info] mtlRetryJVM (2.13.5, 2.12.13, 3.8.0)
91[info] mtlRetryJS (2.13.5, 2.12.13, 3.8.0)
92[info] alleycatsRetryJS (2.13.5, 2.12.13, 3.8.0)
93[info] coreJS (2.13.5, 2.12.13, 3.8.0)
94[info] coreJVM (2.13.5, 2.12.13, 3.8.0)
95[info] alleycatsRetryJVM (2.13.5, 2.12.13, 3.8.0)
96[info] Excluding projects:
97[info] * root (2.12.13)
98[info] docs (2.12.13)
99[info] Reapplying settings...
100[info] set current project to root (in build file:/build/repo/)
101Execute mapScalacOptions: ,REQUIRE:-source:3.8,-Wconf:msg=can be rewritten automatically under:s ,-deprecation,-feature,-Xfatal-warnings,-Werror,MATCH:.*-Wconf.*any:e
102[info] Reapplying settings...
103[info] set current project to root (in build file:/build/repo/)
104[info] Defining Global / credentials, alleycatsRetryJS / credentials and 6 others.
105[info] The new values will be used by Global / pgpSelectPassphrase, Global / pgpSigningKey and 39 others.
106[info] Run `last` for details.
107[info] Reapplying settings...
108[info] set current project to root (in build file:/build/repo/)
109Execute excludeLibraryDependency: com.github.ghik:zerowaste_{scalaVersion} com.olegpy:better-monadic-for_3 org.polyvariant:better-tostring_{scalaVersion} org.wartremover:wartremover_{scalaVersion}
110[info] Reapplying settings...
111OpenCB::Failed to reapply settings in excludeLibraryDependency: Reference to undefined setting:
112
113 Global / allExcludeDependencies from Global / allExcludeDependencies (CommunityBuildPlugin.scala:331)
114 Did you mean allExcludeDependencies ?
115 , retry without global scopes
116[info] Reapplying settings...
117[info] set current project to root (in build file:/build/repo/)
118Execute removeScalacOptionsStartingWith: -P:wartremover
119[info] Reapplying settings...
120[info] set current project to root (in build file:/build/repo/)
121[success] Total time: 0 s, completed Jan 13, 2026, 4:04:41 PM
122Build config: {"projects":{"exclude":[],"overrides":{}},"java":{"version":"17"},"sbt":{"commands":[],"options":[]},"mill":{"options":[]},"tests":"full","migrationVersions":[],"sourcePatches":[]}
123Parsed config: Success(ProjectBuildConfig(ProjectsConfig(List(),Map()),Full,List()))
124Starting build...
125Projects: Set(alleycatsRetryJVM, coreJVM, mtlRetryJVM)
126Starting build for ProjectRef(file:/build/repo/,alleycatsRetryJVM) (alleycats-retry)... [0/3]
127OpenCB::Exclude Scala3 specific scalacOption `REQUIRE:-source:3.8` in Scala 2.12.20 module Global
128OpenCB::Filter out '-deprecation', matches setting pattern '^-?-deprecation'
129Compile scalacOptions: -Xfuture, -Ywarn-dead-code, -Ywarn-unused, -encoding, UTF-8, -language:higherKinds, -language:implicitConversions, -unchecked, -Wconf:msg=can be rewritten automatically under:s, -source:3.8
130[info] Formatting 1 Scala sources...
131[info] Formatting 6 Scala sources...
132[info] Formatting 2 Scala sources...
133[info] Formatting 12 Scala sources...
134[info] compiling 12 Scala sources to /build/repo/modules/core/jvm/target/scala-3.8.0/classes ...
135[warn] bad option '-Xfuture' was ignored
136[warn] bad option '-Ywarn-dead-code' was ignored
137[warn] bad option '-Ywarn-unused' was ignored
138[warn] three warnings found
139[info] done compiling
140[info] compiling 2 Scala sources to /build/repo/modules/alleycats/jvm/target/scala-3.8.0/classes ...
141[warn] bad option '-Xfuture' was ignored
142[warn] bad option '-Ywarn-dead-code' was ignored
143[warn] bad option '-Ywarn-unused' was ignored
144[warn] three warnings found
145[info] done compiling
146[info] compiling 1 Scala source to /build/repo/modules/alleycats/jvm/target/scala-3.8.0/test-classes ...
147[warn] bad option '-Xfuture' was ignored
148[warn] bad option '-Ywarn-dead-code' was ignored
149[warn] bad option '-Ywarn-unused' was ignored
150[warn] three warnings found
151[info] done compiling
152retry.alleycats.PackageObjectLazinessSuite:
153 + retryingOnFailures should not evaluate the next attempt until it has finished sleeping 1.077s
154Starting build for ProjectRef(file:/build/repo/,coreJVM) (cats-retry)... [1/3]
155Compile scalacOptions: -Xfuture, -Ywarn-dead-code, -Ywarn-unused, -encoding, UTF-8, -language:higherKinds, -language:implicitConversions, -unchecked, -Wconf:msg=can be rewritten automatically under:s, -source:3.8
156[info] compiling 6 Scala sources to /build/repo/modules/core/jvm/target/scala-3.8.0/test-classes ...
157[warn] bad option '-Xfuture' was ignored
158[warn] bad option '-Ywarn-dead-code' was ignored
159[warn] bad option '-Ywarn-unused' was ignored
160[warn] three warnings found
161[info] done compiling
162retry.PackageObjectSuite:
163retry.FibonacciSuite:
164retry.SyntaxSuite:
165 + Fibonacci should calculate the Fibonacci sequence 0.014s
166retry.RetryPolicySuite:
167 + BoundedSemilattice append should give up if either of the composed policies decides to give up 0.047s
168 + BoundedSemilattice append should choose the maximum of the delays if both of the composed policies decides to retry 0.005s
169 + retryingOnFailures should retry until the action succeeds 0.085s
170 + retryingOnFailures should retry until the action succeeds 0.087s
171 + retryingOnFailures should retry until the policy chooses to give up 0.005s
172 + retryingOnFailures should retry until the policy chooses to give up 0.005s
173 + retryingOnFailures should retry in a stack-safe way 0.069s
174 + retryingOnSomeErrors should retry until the action succeeds 0.016s
175 + retryingOnSomeErrors should retry only if the error is worth retrying 0.005s
176 + retryingOnSomeErrors should retry until the policy chooses to give up 0.004s
177retry.RetryPoliciesSuite:
178 + retryingOnSomeErrors should retry in a stack-safe way 0.055s
179 + retryingOnAllErrors should retry until the action succeeds 0.004s
180 + retryingOnAllErrors should retry until the policy chooses to give up 0.001s
181 + retryingOnAllErrors should retry in a stack-safe way 0.03s
182 + retryingOnFailuresAndSomeErrors should retry until the action succeeds 0.004s
183 + retryingOnFailuresAndSomeErrors should retry only if the error is worth retrying 0.004s
184 + retryingOnFailuresAndSomeErrors should retry until the policy chooses to give up due to errors 0.005s
185 + retryingOnFailuresAndSomeErrors should retry until the policy chooses to give up due to failures 0.005s
186 + retryingOnSomeErrors should retry until the action succeeds 0.224s
187 + retryingOnSomeErrors should retry only if the error is worth retrying 0.005s
188 + retryingOnFailuresAndSomeErrors should retry in a stack-safe way 0.027s
189 + retryingOnSomeErrors should retry until the policy chooses to give up 0.002s
190 + retryingOnFailuresAndAllErrors should retry until the action succeeds 0.002s
191 + retryingOnFailuresAndAllErrors should retry until the policy chooses to give up due to errors 0.002s
192 + retryingOnAllErrors should retry until the action succeeds 0.003s
193 + retryingOnFailuresAndAllErrors should retry until the policy chooses to give up due to failures 0.003s
194 + retryingOnAllErrors should retry until the policy chooses to give up 0.002s
195 + constantDelay should always retry with the same delay 0.104s
196 + exponentialBackoff should start with the base delay and double the delay after each iteration 0.001s
197 + fibonacciBackoff should start with the base delay and increase the delay in a Fibonacci-y way 0.001s
198 + retryingOnFailuresAndAllErrors should retry in a stack-safe way 0.026s
199 + fullJitter should implement the AWS Full Jitter backoff algorithm 0.052s
200 + all built-in policies should never try to create a FiniteDuration of more than Long.MaxValue nanoseconds 0.001s
201retry.RetryPolicyLawsSuite:
202 + limitRetries should retry with no delay until the limit is reached 0.016s
203 + capDelay should cap the delay 0.026s
204 + limitRetriesByDelay should give up if the underlying policy chooses a delay greater than the threshold 0.012s
205 + limitRetriesByCumulativeDelay should give up if cumulativeDelay + underlying policy's next delay >= threshold 0.001s
206 + meet associativity 0.092s
207 + meet commutativity 0.026s
208 + meet idempotence 0.015s
209 + meet identity 0.012s
210 + join meet absorption 0.022s
211 + meet join absorption 0.114s
212 + meet absorption 0.006s
213 + join absorption 0.005s
214 + join meet distributivity 0.023s
215 + meet join distributivity 0.017s
216 + mapK identity 0.007s
217 + mapDelay identity 0.007s
218 + mapDelay composition 0.013s
219 + flatMapDelay identity 0.007s
220 + flatMapDelay composition 0.013s
221 + BoundedSemilattice[RetryPolicy]: boundedSemilattice.associative 0.008s
222 + BoundedSemilattice[RetryPolicy]: boundedSemilattice.collect0 0.001s
223 + BoundedSemilattice[RetryPolicy]: boundedSemilattice.combine all 0.058s
224 + BoundedSemilattice[RetryPolicy]: boundedSemilattice.combineAllOption 0.028s
225 + BoundedSemilattice[RetryPolicy]: boundedSemilattice.commutative 0.003s
226 + BoundedSemilattice[RetryPolicy]: boundedSemilattice.idempotency 0.003s
227 + BoundedSemilattice[RetryPolicy]: boundedSemilattice.intercalateCombineAllOption 0.035s
228 + BoundedSemilattice[RetryPolicy]: boundedSemilattice.intercalateIntercalates 0.004s
229 + BoundedSemilattice[RetryPolicy]: boundedSemilattice.intercalateRepeat1 0.003s
230 + BoundedSemilattice[RetryPolicy]: boundedSemilattice.intercalateRepeat2 0.003s
231 + BoundedSemilattice[RetryPolicy]: boundedSemilattice.is id 0.002s
232 + BoundedSemilattice[RetryPolicy]: boundedSemilattice.left identity 0.003s
233 + BoundedSemilattice[RetryPolicy]: boundedSemilattice.repeat0 0.001s
234 + BoundedSemilattice[RetryPolicy]: boundedSemilattice.repeat1 0.003s
235 + BoundedSemilattice[RetryPolicy]: boundedSemilattice.repeat2 0.002s
236 + BoundedSemilattice[RetryPolicy]: boundedSemilattice.reverseCombineAllOption 0.02s
237 + BoundedSemilattice[RetryPolicy]: boundedSemilattice.reverseRepeat1 0.002s
238 + BoundedSemilattice[RetryPolicy]: boundedSemilattice.reverseRepeat2 0.002s
239 + BoundedSemilattice[RetryPolicy]: boundedSemilattice.reverseReverses 0.002s
240 + BoundedSemilattice[RetryPolicy]: boundedSemilattice.right identity 0.003s
241 + followedBy associativity 0.005s
242 + followedBy left identity 0.003s
243 + followedBy right identity 0.002s
244Starting build for ProjectRef(file:/build/repo/,mtlRetryJVM) (cats-retry-mtl)... [2/3]
245Compile scalacOptions: -Xfuture, -Ywarn-dead-code, -Ywarn-unused, -encoding, UTF-8, -language:higherKinds, -language:implicitConversions, -unchecked, -Wconf:msg=can be rewritten automatically under:s, -source:3.8
246[info] Formatting 2 Scala sources...
247[info] Formatting 4 Scala sources...
248[info] compiling 4 Scala sources to /build/repo/modules/mtl/jvm/target/scala-3.8.0/classes ...
249[warn] bad option '-Xfuture' was ignored
250[warn] bad option '-Ywarn-dead-code' was ignored
251[warn] bad option '-Ywarn-unused' was ignored
252[warn] three warnings found
253[info] done compiling
254[info] compiling 2 Scala sources to /build/repo/modules/mtl/jvm/target/scala-3.8.0/test-classes ...
255[warn] bad option '-Xfuture' was ignored
256[warn] bad option '-Ywarn-dead-code' was ignored
257[warn] bad option '-Ywarn-unused' was ignored
258[warn] three warnings found
259[info] done compiling
260retry.mtl.SyntaxSpec:
261retry.mtl.PackageObjectSpec:
262 + retryingOnSomectx.errors should retry until the action succeeds 0.054s
263 + retryingOnSomeMtlErrors should retry until the action succeeds 0.055s
264 + retryingOnSomectx.errors should retry only if the error is worth retrying 0.002s
265 + retryingOnSomeMtlErrors should retry only if the error is worth retrying 0.003s
266 + retryingOnSomectx.errors should retry until the policy chooses to give up 0.004s
267 + retryingOnSomeMtlErrors should retry until the policy chooses to give up 0.003s
268 + retryingOnAllMtlErrors should retry until the action succeeds 0.003s
269 + retryingOnAllMtlErrors should retry until the policy chooses to give up 0.003s
270 + retryingOnSomectx.errors should retry in a stack-safe way 0.068s
271 + retryingOnAllctx.errors should retry until the action succeeds 0.001s
272 + retryingOnAllctx.errors should retry until the policy chooses to give up 0.002s
273 + retryingOnAllctx.errors should retry in a stack-safe way 0.031s
274
275************************
276Build summary:
277[{
278 "module": "alleycats-retry",
279 "compile": {"status": "ok", "tookMs": 11233, "warnings": 0, "errors": 0, "sourceVersion": "3.8"},
280 "doc": {"status": "skipped", "tookMs": 0, "files": 0, "totalSizeKb": 0},
281 "test-compile": {"status": "ok", "tookMs": 1153, "warnings": 0, "errors": 0, "sourceVersion": "3.8"},
282 "test": {"status": "ok", "tookMs": 1524, "passed": 1, "failed": 0, "ignored": 0, "skipped": 0, "total": 1, "byFramework": [{"framework": "munit", "stats": {"passed": 1, "failed": 0, "ignored": 0, "skipped": 0, "total": 1}}]},
283 "publish": {"status": "skipped", "tookMs": 0},
284 "metadata": {
285 "crossScalaVersions": ["2.13.5", "2.12.13", "3.3.5"]
286}
287},{
288 "module": "cats-retry",
289 "compile": {"status": "ok", "tookMs": 58, "warnings": 0, "errors": 0, "sourceVersion": "3.8"},
290 "doc": {"status": "skipped", "tookMs": 0, "files": 0, "totalSizeKb": 0},
291 "test-compile": {"status": "ok", "tookMs": 4885, "warnings": 0, "errors": 0, "sourceVersion": "3.8"},
292 "test": {"status": "ok", "tookMs": 1138, "passed": 76, "failed": 0, "ignored": 0, "skipped": 0, "total": 76, "byFramework": [{"framework": "munit", "stats": {"passed": 76, "failed": 0, "ignored": 0, "skipped": 0, "total": 76}}]},
293 "publish": {"status": "skipped", "tookMs": 0},
294 "metadata": {
295 "crossScalaVersions": ["2.13.5", "2.12.13", "3.3.5"]
296}
297},{
298 "module": "cats-retry-mtl",
299 "compile": {"status": "ok", "tookMs": 927, "warnings": 0, "errors": 0, "sourceVersion": "3.8"},
300 "doc": {"status": "skipped", "tookMs": 0, "files": 0, "totalSizeKb": 0},
301 "test-compile": {"status": "ok", "tookMs": 1253, "warnings": 0, "errors": 0, "sourceVersion": "3.8"},
302 "test": {"status": "ok", "tookMs": 366, "passed": 12, "failed": 0, "ignored": 0, "skipped": 0, "total": 12, "byFramework": [{"framework": "munit", "stats": {"passed": 12, "failed": 0, "ignored": 0, "skipped": 0, "total": 12}}]},
303 "publish": {"status": "skipped", "tookMs": 0},
304 "metadata": {
305 "crossScalaVersions": ["2.13.5", "2.12.13", "3.3.5"]
306}
307}]
308************************
309[success] Total time: 25 s, completed Jan 13, 2026, 4:05:06 PM
310[0JChecking patch project/plugins.sbt...
311Checking patch project/build.properties...
312Checking patch build.sbt...
313Applied patch project/plugins.sbt cleanly.
314Applied patch project/build.properties cleanly.
315Applied patch build.sbt cleanly.