Merge branch '2.7.x' into 3.0.x
This commit is contained in:
commit
2c27ec5b7b
|
|
@ -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 {
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -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 {
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -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()}.
|
||||||
|
|
|
||||||
|
|
@ -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));
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue