Merge branch '3.3.x'

This commit is contained in:
Phillip Webb 2024-11-15 14:26:28 -08:00
commit d83d34d111
1 changed files with 26 additions and 1 deletions

View File

@ -20,6 +20,7 @@ import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.io.PrintWriter;
import java.time.Duration;
import java.util.ArrayList;
import java.util.List;
import java.util.function.Consumer;
@ -267,7 +268,7 @@ class PaketoBuilderTests {
writeServletInitializerClass();
String imageName = "paketo-integration/" + this.gradleBuild.getProjectDir().getName();
ImageReference imageReference = ImageReference.of(ImageName.of(imageName));
BuildResult result = buildImage(imageName);
BuildResult result = buildImageWithRetry(imageName);
assertThat(result.task(":bootBuildImage").getOutcome()).isEqualTo(TaskOutcome.SUCCESS);
assertThat(result.getOutput()).contains("Running creator");
try (GenericContainer<?> container = new GenericContainer<>(imageName)) {
@ -378,6 +379,30 @@ class PaketoBuilderTests {
}
}
private BuildResult buildImageWithRetry(String imageName, String... arguments) {
long start = System.nanoTime();
while (true) {
try {
return buildImage(imageName, arguments);
}
catch (Exception ex) {
if (Duration.ofNanos(System.nanoTime() - start).toMinutes() > 6) {
throw ex;
}
sleep(500);
}
}
}
private void sleep(long time) {
try {
Thread.sleep(time);
}
catch (InterruptedException ex) {
Thread.currentThread().interrupt();
}
}
private BuildResult buildImage(String imageName, String... arguments) {
List<String> args = new ArrayList<>(List.of(arguments));
args.add("bootBuildImage");