mirror of
https://github.com/enso-org/enso.git
synced 2024-12-21 04:51:38 +03:00
Add retries when fetching tableau artifacts in sbt (#10984)
* Add retries when fetching tableau artifacts in sbt Seeing frequent network failures when fetching tableau artifacts e.g., https://github.com/enso-org/enso/actions/runs/10705660288/job/29681570936#step:7:918 Network failures are OK but we shouldn't kill builds immediately because of that. Let's try harder. * update codeowners * use backoff * fighting with sbt
This commit is contained in:
parent
51733ee876
commit
92dd3c9613
2
.github/CODEOWNERS
vendored
2
.github/CODEOWNERS
vendored
@ -30,7 +30,7 @@ Cargo.toml
|
||||
/build.sbt @4e6 @jaroslavtulach @hubertp @Akirathan
|
||||
/distribution/ @4e6 @jdunkerley @radeusgd @GregoryTravis @AdRiley @marthasharkey
|
||||
/engine/ @4e6 @jaroslavtulach @hubertp @Akirathan
|
||||
/project/ @4e6 @jaroslavtulach @hubertp
|
||||
/project/ @4e6 @jaroslavtulach @hubertp @Akirathan
|
||||
/tools/ @4e6 @jaroslavtulach @radeusgd @hubertp
|
||||
|
||||
# Enso Libraries
|
||||
|
37
build.sbt
37
build.sbt
@ -3583,14 +3583,47 @@ lazy val `std-tableau` = project
|
||||
val unmanagedPath = unmanagedDirectory.toPath
|
||||
IO.withTemporaryDirectory(
|
||||
tmp => {
|
||||
val files = IO.unzipURL(
|
||||
import scala.concurrent.ExecutionContext.Implicits.global
|
||||
implicit val filesNotEmptySuccess: retry.Success[Set[File]] =
|
||||
retry.Success(!_.isEmpty)
|
||||
import scala.concurrent.duration._
|
||||
val future = retry.Backoff(4, 1.second).apply { () =>
|
||||
scala.concurrent.Future {
|
||||
try {
|
||||
IO.unzipURL(
|
||||
unmanagedExternalZip.value,
|
||||
tmp,
|
||||
f =>
|
||||
f.endsWith(".jar") && !f.contains("gradle") && !f.contains(
|
||||
f.endsWith(".jar") && !f.contains("gradle") && !f
|
||||
.contains(
|
||||
"javadoc"
|
||||
) && !f.contains("jna")
|
||||
)
|
||||
} catch {
|
||||
case _: java.net.SocketException |
|
||||
_: java.net.ConnectException =>
|
||||
Set.empty[File]
|
||||
}
|
||||
}
|
||||
}
|
||||
future.onComplete { result =>
|
||||
if (result.isFailure || result.get.isEmpty) {
|
||||
logger.log(
|
||||
Level.Error,
|
||||
"Failed to fetch any external artifacts for tableau"
|
||||
)
|
||||
}
|
||||
}
|
||||
val files = scala.concurrent.Await.result(future, 60.seconds)
|
||||
if (files.isEmpty) {
|
||||
logger.log(
|
||||
Level.Error,
|
||||
"Failed to fetch any external artifacts for tableau"
|
||||
)
|
||||
throw new IllegalStateException(
|
||||
"Failed to fetch any external artifacts"
|
||||
)
|
||||
}
|
||||
files.map { f =>
|
||||
IO.move(f, unmanagedPath.resolve(f.getName).toFile)
|
||||
Attributed.blank(unmanagedPath.resolve(f.getName).toFile)
|
||||
|
@ -8,5 +8,6 @@ libraryDependencies += "io.circe" %% "circe-yaml" % "0
|
||||
libraryDependencies += "commons-io" % "commons-io" % "2.12.0"
|
||||
libraryDependencies += "nl.gn0s1s" %% "bump" % "0.1.3"
|
||||
libraryDependencies += "com.google.googlejavaformat" % "google-java-format" % "1.18.1"
|
||||
libraryDependencies += "com.softwaremill.retry" %% "retry" % "0.3.6"
|
||||
|
||||
scalacOptions ++= Seq("-deprecation", "-feature")
|
||||
|
Loading…
Reference in New Issue
Block a user