Merge branch '2.7.x' into 3.0.x

This commit is contained in:
Phillip Webb 2023-05-02 15:42:00 -07:00
commit 2c27ec5b7b
4 changed files with 36 additions and 22 deletions

View File

@ -36,7 +36,6 @@ import org.apache.commons.compress.utils.IOUtils;
import org.gradle.testkit.runner.BuildResult; import org.gradle.testkit.runner.BuildResult;
import org.gradle.testkit.runner.TaskOutcome; import org.gradle.testkit.runner.TaskOutcome;
import org.junit.jupiter.api.TestTemplate; import org.junit.jupiter.api.TestTemplate;
import org.junit.jupiter.api.condition.DisabledOnOs;
import org.junit.jupiter.api.condition.OS; import org.junit.jupiter.api.condition.OS;
import org.springframework.boot.buildpack.platform.docker.DockerApi; import org.springframework.boot.buildpack.platform.docker.DockerApi;
@ -47,6 +46,7 @@ import org.springframework.boot.buildpack.platform.docker.type.VolumeName;
import org.springframework.boot.buildpack.platform.io.FilePermissions; import org.springframework.boot.buildpack.platform.io.FilePermissions;
import org.springframework.boot.gradle.junit.GradleCompatibility; import org.springframework.boot.gradle.junit.GradleCompatibility;
import org.springframework.boot.testsupport.gradle.testkit.GradleBuild; import org.springframework.boot.testsupport.gradle.testkit.GradleBuild;
import org.springframework.boot.testsupport.junit.DisabledOnOs;
import org.springframework.boot.testsupport.testcontainers.DisabledIfDockerUnavailable; import org.springframework.boot.testsupport.testcontainers.DisabledIfDockerUnavailable;
import static org.assertj.core.api.Assertions.assertThat; import static org.assertj.core.api.Assertions.assertThat;
@ -60,7 +60,7 @@ import static org.assertj.core.api.Assertions.assertThat;
*/ */
@GradleCompatibility(configurationCache = true) @GradleCompatibility(configurationCache = true)
@DisabledIfDockerUnavailable @DisabledIfDockerUnavailable
@org.springframework.boot.testsupport.junit.DisabledOnOs(os = { OS.LINUX, OS.MAC }, architecture = "aarch64", @DisabledOnOs(os = { OS.LINUX, OS.MAC }, architecture = "aarch64",
disabledReason = "The builder image has no ARM support") disabledReason = "The builder image has no ARM support")
class BootBuildImageIntegrationTests { class BootBuildImageIntegrationTests {

View File

@ -33,6 +33,7 @@ import org.springframework.boot.buildpack.platform.docker.DockerApi.VolumeApi;
import org.springframework.boot.buildpack.platform.docker.type.ImageName; import org.springframework.boot.buildpack.platform.docker.type.ImageName;
import org.springframework.boot.buildpack.platform.docker.type.ImageReference; import org.springframework.boot.buildpack.platform.docker.type.ImageReference;
import org.springframework.boot.buildpack.platform.docker.type.VolumeName; import org.springframework.boot.buildpack.platform.docker.type.VolumeName;
import org.springframework.boot.testsupport.junit.DisabledOnOs;
import org.springframework.boot.testsupport.testcontainers.DisabledIfDockerUnavailable; import org.springframework.boot.testsupport.testcontainers.DisabledIfDockerUnavailable;
import static org.assertj.core.api.Assertions.assertThat; import static org.assertj.core.api.Assertions.assertThat;
@ -46,7 +47,7 @@ import static org.assertj.core.api.Assertions.assertThat;
*/ */
@ExtendWith(MavenBuildExtension.class) @ExtendWith(MavenBuildExtension.class)
@DisabledIfDockerUnavailable @DisabledIfDockerUnavailable
@org.springframework.boot.testsupport.junit.DisabledOnOs(os = { OS.LINUX, OS.MAC }, architecture = "aarch64", @DisabledOnOs(os = { OS.LINUX, OS.MAC }, architecture = "aarch64",
disabledReason = "The builder image has no ARM support") disabledReason = "The builder image has no ARM support")
class BuildImageTests extends AbstractArchiveIntegrationTests { class BuildImageTests extends AbstractArchiveIntegrationTests {

View File

@ -37,16 +37,22 @@ import org.junit.jupiter.api.extension.ExtendWith;
public @interface DisabledOnOs { public @interface DisabledOnOs {
/** /**
* See {@link org.junit.jupiter.api.condition.DisabledOnOs#value()}. * The operating systems on which the annotated class or method should be disabled.
* @return os * @return the operating systems where the test is disabled
*/ */
OS[] os(); OS[] value() default {};
/** /**
* Architecture of the operating system. * The operating systems on which the annotated class or method should be disabled.
* @return architecture * @return the operating systems where the test is disabled
*/ */
String architecture(); OS[] os() default {};
/**
* The architectures on which the annotated class or method should be disabled.
* @return the architectures where the test is disabled
*/
String[] architecture() default {};
/** /**
* See {@link org.junit.jupiter.api.condition.DisabledOnOs#disabledReason()}. * See {@link org.junit.jupiter.api.condition.DisabledOnOs#disabledReason()}.

View File

@ -16,43 +16,50 @@
package org.springframework.boot.testsupport.junit; package org.springframework.boot.testsupport.junit;
import java.util.Optional; import java.util.Arrays;
import org.junit.jupiter.api.condition.OS; import org.junit.jupiter.api.condition.OS;
import org.junit.jupiter.api.extension.ConditionEvaluationResult; import org.junit.jupiter.api.extension.ConditionEvaluationResult;
import org.junit.jupiter.api.extension.ExecutionCondition; import org.junit.jupiter.api.extension.ExecutionCondition;
import org.junit.jupiter.api.extension.ExtensionContext; import org.junit.jupiter.api.extension.ExtensionContext;
import org.junit.platform.commons.util.AnnotationUtils;
import org.springframework.core.annotation.MergedAnnotation;
import org.springframework.core.annotation.MergedAnnotations;
import org.springframework.core.annotation.MergedAnnotations.SearchStrategy;
/** /**
* Evaluates {@link DisabledOnOs}. * Evaluates {@link DisabledOnOs}.
* *
* @author Moritz Halbritter * @author Moritz Halbritter
* @author Phillip Webb
*/ */
class DisabledOnOsCondition implements ExecutionCondition { class DisabledOnOsCondition implements ExecutionCondition {
@Override @Override
public ConditionEvaluationResult evaluateExecutionCondition(ExtensionContext context) { public ConditionEvaluationResult evaluateExecutionCondition(ExtensionContext context) {
Optional<DisabledOnOs> annotation = AnnotationUtils.findAnnotation(context.getElement(), DisabledOnOs.class); if (!context.getElement().isPresent()) {
return ConditionEvaluationResult.enabled("No element for @DisabledOnOs found");
}
MergedAnnotation<DisabledOnOs> annotation = MergedAnnotations
.from(context.getElement().get(), SearchStrategy.TYPE_HIERARCHY)
.get(DisabledOnOs.class);
if (!annotation.isPresent()) { if (!annotation.isPresent()) {
return ConditionEvaluationResult.enabled("No @DisabledOnOs found"); return ConditionEvaluationResult.enabled("No @DisabledOnOs found");
} }
return evaluate(annotation.get()); return evaluate(annotation.synthesize());
} }
private ConditionEvaluationResult evaluate(DisabledOnOs annotation) { private ConditionEvaluationResult evaluate(DisabledOnOs annotation) {
String architecture = System.getProperty("os.arch"); String architecture = System.getProperty("os.arch");
String os = System.getProperty("os.name"); String os = System.getProperty("os.name");
if (annotation.architecture().equals(architecture)) { boolean onDisabledOs = Arrays.stream(annotation.os()).anyMatch(OS::isCurrentOs);
for (OS targetOs : annotation.os()) { boolean onDisabledArchitecture = Arrays.stream(annotation.architecture()).anyMatch(architecture::equals);
if (targetOs.isCurrentOs()) { if (onDisabledOs && onDisabledArchitecture) {
String reason = annotation.disabledReason().isEmpty() String reason = annotation.disabledReason().isEmpty()
? String.format("Disabled on OS = %s, architecture = %s", os, architecture) ? String.format("Disabled on OS = %s, architecture = %s", os, architecture)
: annotation.disabledReason(); : annotation.disabledReason();
return ConditionEvaluationResult.disabled(reason); return ConditionEvaluationResult.disabled(reason);
} }
}
}
return ConditionEvaluationResult return ConditionEvaluationResult
.enabled(String.format("Enabled on OS = %s, architecture = %s", os, architecture)); .enabled(String.format("Enabled on OS = %s, architecture = %s", os, architecture));
} }