commit
25234219ce
|
@ -0,0 +1,49 @@
|
||||||
|
/*
|
||||||
|
* Copyright 2012-2021 the original author or authors.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* https://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.springframework.boot.gradle.junit;
|
||||||
|
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import org.junit.jupiter.api.extension.ConditionEvaluationResult;
|
||||||
|
import org.junit.jupiter.api.extension.ExecutionCondition;
|
||||||
|
import org.junit.jupiter.api.extension.Extension;
|
||||||
|
import org.junit.jupiter.api.extension.ExtensionContext;
|
||||||
|
import org.junit.jupiter.api.extension.TestTemplateInvocationContext;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@link TestTemplateInvocationContext} that disables tests.
|
||||||
|
*
|
||||||
|
* @author Christoph Dreis
|
||||||
|
*/
|
||||||
|
final class DisabledTemplateInvocationContext implements TestTemplateInvocationContext {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<Extension> getAdditionalExtensions() {
|
||||||
|
return Collections.singletonList(new DisabledCondition());
|
||||||
|
}
|
||||||
|
|
||||||
|
private static class DisabledCondition implements ExecutionCondition {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ConditionEvaluationResult evaluateExecutionCondition(ExtensionContext context) {
|
||||||
|
return ConditionEvaluationResult.disabled("");
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -47,6 +47,9 @@ final class GradleCompatibilityExtension implements TestTemplateInvocationContex
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Stream<TestTemplateInvocationContext> provideTestTemplateInvocationContexts(ExtensionContext context) {
|
public Stream<TestTemplateInvocationContext> provideTestTemplateInvocationContexts(ExtensionContext context) {
|
||||||
|
if (GRADLE_VERSIONS.isEmpty()) {
|
||||||
|
return Stream.of(new DisabledTemplateInvocationContext());
|
||||||
|
}
|
||||||
Stream<String> gradleVersions = GRADLE_VERSIONS.stream();
|
Stream<String> gradleVersions = GRADLE_VERSIONS.stream();
|
||||||
GradleCompatibility gradleCompatibility = AnnotationUtils
|
GradleCompatibility gradleCompatibility = AnnotationUtils
|
||||||
.findAnnotation(context.getRequiredTestClass(), GradleCompatibility.class).get();
|
.findAnnotation(context.getRequiredTestClass(), GradleCompatibility.class).get();
|
||||||
|
|
|
@ -20,6 +20,7 @@ import java.util.Arrays;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.stream.Stream;
|
import java.util.stream.Stream;
|
||||||
|
|
||||||
|
import org.gradle.api.JavaVersion;
|
||||||
import org.junit.jupiter.api.TestTemplate;
|
import org.junit.jupiter.api.TestTemplate;
|
||||||
import org.junit.jupiter.api.extension.Extension;
|
import org.junit.jupiter.api.extension.Extension;
|
||||||
import org.junit.jupiter.api.extension.ExtensionContext;
|
import org.junit.jupiter.api.extension.ExtensionContext;
|
||||||
|
@ -42,6 +43,9 @@ public class GradleMultiDslExtension implements TestTemplateInvocationContextPro
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Stream<TestTemplateInvocationContext> provideTestTemplateInvocationContexts(ExtensionContext context) {
|
public Stream<TestTemplateInvocationContext> provideTestTemplateInvocationContexts(ExtensionContext context) {
|
||||||
|
if (JavaVersion.current() == JavaVersion.VERSION_17) {
|
||||||
|
return Stream.of(new DisabledTemplateInvocationContext());
|
||||||
|
}
|
||||||
return Stream.of(Dsl.values()).map(DslTestTemplateInvocationContext::new);
|
return Stream.of(Dsl.values()).map(DslTestTemplateInvocationContext::new);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,81 @@
|
||||||
|
/*
|
||||||
|
* Copyright 2012-2021 the original author or authors.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* https://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.springframework.boot.gradle.junit;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
|
||||||
|
import org.gradle.api.JavaVersion;
|
||||||
|
import org.gradle.api.Project;
|
||||||
|
import org.gradle.internal.nativeintegration.services.NativeServices;
|
||||||
|
import org.gradle.testfixtures.ProjectBuilder;
|
||||||
|
import org.gradle.testfixtures.internal.ProjectBuilderImpl;
|
||||||
|
|
||||||
|
import org.springframework.util.Assert;
|
||||||
|
import org.springframework.util.StringUtils;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Helper class to build Gradle {@link Project Projects} for test fixtures. Wraps
|
||||||
|
* functionality of Gradle's own {@link ProjectBuilder} in order to workaround an issue on
|
||||||
|
* JDK 17.
|
||||||
|
*
|
||||||
|
* @author Christoph Dreis
|
||||||
|
* @see <a href="https://github.com/gradle/gradle/issues/16857">Gradle Support JDK 17</a>
|
||||||
|
*/
|
||||||
|
public final class GradleProjectBuilder {
|
||||||
|
|
||||||
|
private File projectDir;
|
||||||
|
|
||||||
|
private String name;
|
||||||
|
|
||||||
|
private GradleProjectBuilder() {
|
||||||
|
}
|
||||||
|
|
||||||
|
public static GradleProjectBuilder builder() {
|
||||||
|
return new GradleProjectBuilder();
|
||||||
|
}
|
||||||
|
|
||||||
|
public GradleProjectBuilder withProjectDir(File dir) {
|
||||||
|
this.projectDir = dir;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public GradleProjectBuilder withName(String name) {
|
||||||
|
this.name = name;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Project build() {
|
||||||
|
Assert.notNull(this.projectDir, "ProjectDir must not be null");
|
||||||
|
ProjectBuilder builder = ProjectBuilder.builder();
|
||||||
|
builder.withProjectDir(this.projectDir);
|
||||||
|
File userHome = new File(this.projectDir, "userHome");
|
||||||
|
builder.withGradleUserHomeDir(userHome);
|
||||||
|
if (StringUtils.hasText(this.name)) {
|
||||||
|
builder.withName(this.name);
|
||||||
|
}
|
||||||
|
if (JavaVersion.current() == JavaVersion.VERSION_17) {
|
||||||
|
NativeServices.initialize(userHome);
|
||||||
|
try {
|
||||||
|
ProjectBuilderImpl.getGlobalServices();
|
||||||
|
}
|
||||||
|
catch (Throwable ignore) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return builder.build();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright 2012-2020 the original author or authors.
|
* Copyright 2012-2021 the original author or authors.
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
|
@ -20,10 +20,10 @@ import java.io.File;
|
||||||
|
|
||||||
import org.gradle.api.Project;
|
import org.gradle.api.Project;
|
||||||
import org.gradle.api.artifacts.Configuration;
|
import org.gradle.api.artifacts.Configuration;
|
||||||
import org.gradle.testfixtures.ProjectBuilder;
|
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
import org.junit.jupiter.api.io.TempDir;
|
import org.junit.jupiter.api.io.TempDir;
|
||||||
|
|
||||||
|
import org.springframework.boot.gradle.junit.GradleProjectBuilder;
|
||||||
import org.springframework.boot.testsupport.classpath.ClassPathExclusions;
|
import org.springframework.boot.testsupport.classpath.ClassPathExclusions;
|
||||||
|
|
||||||
import static org.assertj.core.api.Assertions.assertThat;
|
import static org.assertj.core.api.Assertions.assertThat;
|
||||||
|
@ -42,7 +42,7 @@ class SpringBootPluginTests {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
void bootArchivesConfigurationsCannotBeResolved() {
|
void bootArchivesConfigurationsCannotBeResolved() {
|
||||||
Project project = ProjectBuilder.builder().withProjectDir(this.temp).build();
|
Project project = GradleProjectBuilder.builder().withProjectDir(this.temp).build();
|
||||||
project.getPlugins().apply(SpringBootPlugin.class);
|
project.getPlugins().apply(SpringBootPlugin.class);
|
||||||
Configuration bootArchives = project.getConfigurations()
|
Configuration bootArchives = project.getConfigurations()
|
||||||
.getByName(SpringBootPlugin.BOOT_ARCHIVES_CONFIGURATION_NAME);
|
.getByName(SpringBootPlugin.BOOT_ARCHIVES_CONFIGURATION_NAME);
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright 2012-2020 the original author or authors.
|
* Copyright 2012-2021 the original author or authors.
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
|
@ -26,10 +26,10 @@ import java.util.Properties;
|
||||||
import org.gradle.api.Project;
|
import org.gradle.api.Project;
|
||||||
import org.gradle.api.internal.project.ProjectInternal;
|
import org.gradle.api.internal.project.ProjectInternal;
|
||||||
import org.gradle.initialization.GradlePropertiesController;
|
import org.gradle.initialization.GradlePropertiesController;
|
||||||
import org.gradle.testfixtures.ProjectBuilder;
|
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
import org.junit.jupiter.api.io.TempDir;
|
import org.junit.jupiter.api.io.TempDir;
|
||||||
|
|
||||||
|
import org.springframework.boot.gradle.junit.GradleProjectBuilder;
|
||||||
import org.springframework.boot.testsupport.classpath.ClassPathExclusions;
|
import org.springframework.boot.testsupport.classpath.ClassPathExclusions;
|
||||||
|
|
||||||
import static org.assertj.core.api.Assertions.assertThat;
|
import static org.assertj.core.api.Assertions.assertThat;
|
||||||
|
@ -131,7 +131,7 @@ class BuildInfoTests {
|
||||||
|
|
||||||
private Project createProject(String projectName) {
|
private Project createProject(String projectName) {
|
||||||
File projectDir = new File(this.temp, projectName);
|
File projectDir = new File(this.temp, projectName);
|
||||||
Project project = ProjectBuilder.builder().withProjectDir(projectDir).withName(projectName).build();
|
Project project = GradleProjectBuilder.builder().withProjectDir(projectDir).withName(projectName).build();
|
||||||
((ProjectInternal) project).getServices().get(GradlePropertiesController.class)
|
((ProjectInternal) project).getServices().get(GradlePropertiesController.class)
|
||||||
.loadGradlePropertiesFrom(projectDir);
|
.loadGradlePropertiesFrom(projectDir);
|
||||||
return project;
|
return project;
|
||||||
|
|
|
@ -61,11 +61,11 @@ import org.gradle.api.artifacts.component.ProjectComponentIdentifier;
|
||||||
import org.gradle.api.internal.file.archive.ZipCopyAction;
|
import org.gradle.api.internal.file.archive.ZipCopyAction;
|
||||||
import org.gradle.api.tasks.bundling.AbstractArchiveTask;
|
import org.gradle.api.tasks.bundling.AbstractArchiveTask;
|
||||||
import org.gradle.api.tasks.bundling.Jar;
|
import org.gradle.api.tasks.bundling.Jar;
|
||||||
import org.gradle.testfixtures.ProjectBuilder;
|
|
||||||
import org.junit.jupiter.api.BeforeEach;
|
import org.junit.jupiter.api.BeforeEach;
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
import org.junit.jupiter.api.io.TempDir;
|
import org.junit.jupiter.api.io.TempDir;
|
||||||
|
|
||||||
|
import org.springframework.boot.gradle.junit.GradleProjectBuilder;
|
||||||
import org.springframework.boot.loader.tools.DefaultLaunchScript;
|
import org.springframework.boot.loader.tools.DefaultLaunchScript;
|
||||||
import org.springframework.boot.loader.tools.JarModeLibrary;
|
import org.springframework.boot.loader.tools.JarModeLibrary;
|
||||||
|
|
||||||
|
@ -115,7 +115,7 @@ abstract class AbstractBootArchiveTests<T extends Jar & BootArchive> {
|
||||||
try {
|
try {
|
||||||
File projectDir = new File(this.temp, "project");
|
File projectDir = new File(this.temp, "project");
|
||||||
projectDir.mkdirs();
|
projectDir.mkdirs();
|
||||||
this.project = ProjectBuilder.builder().withProjectDir(projectDir).build();
|
this.project = GradleProjectBuilder.builder().withProjectDir(projectDir).build();
|
||||||
this.project.setDescription("Test project for " + this.taskClass.getSimpleName());
|
this.project.setDescription("Test project for " + this.taskClass.getSimpleName());
|
||||||
this.task = configure(this.project.getTasks().create("testArchive", this.taskClass));
|
this.task = configure(this.project.getTasks().create("testArchive", this.taskClass));
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,7 +24,6 @@ import java.util.Map;
|
||||||
import org.gradle.api.GradleException;
|
import org.gradle.api.GradleException;
|
||||||
import org.gradle.api.JavaVersion;
|
import org.gradle.api.JavaVersion;
|
||||||
import org.gradle.api.Project;
|
import org.gradle.api.Project;
|
||||||
import org.gradle.testfixtures.ProjectBuilder;
|
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
import org.junit.jupiter.api.io.TempDir;
|
import org.junit.jupiter.api.io.TempDir;
|
||||||
|
|
||||||
|
@ -32,6 +31,7 @@ import org.springframework.boot.buildpack.platform.build.BuildRequest;
|
||||||
import org.springframework.boot.buildpack.platform.build.BuildpackReference;
|
import org.springframework.boot.buildpack.platform.build.BuildpackReference;
|
||||||
import org.springframework.boot.buildpack.platform.build.PullPolicy;
|
import org.springframework.boot.buildpack.platform.build.PullPolicy;
|
||||||
import org.springframework.boot.buildpack.platform.docker.type.Binding;
|
import org.springframework.boot.buildpack.platform.docker.type.Binding;
|
||||||
|
import org.springframework.boot.gradle.junit.GradleProjectBuilder;
|
||||||
|
|
||||||
import static org.assertj.core.api.Assertions.assertThat;
|
import static org.assertj.core.api.Assertions.assertThat;
|
||||||
import static org.assertj.core.api.Assertions.assertThatExceptionOfType;
|
import static org.assertj.core.api.Assertions.assertThatExceptionOfType;
|
||||||
|
@ -55,7 +55,7 @@ class BootBuildImageTests {
|
||||||
BootBuildImageTests() {
|
BootBuildImageTests() {
|
||||||
File projectDir = new File(this.temp, "project");
|
File projectDir = new File(this.temp, "project");
|
||||||
projectDir.mkdirs();
|
projectDir.mkdirs();
|
||||||
this.project = ProjectBuilder.builder().withProjectDir(projectDir).withName("build-image-test").build();
|
this.project = GradleProjectBuilder.builder().withProjectDir(projectDir).withName("build-image-test").build();
|
||||||
this.project.setDescription("Test project for BootBuildImage");
|
this.project.setDescription("Test project for BootBuildImage");
|
||||||
this.buildImage = this.project.getTasks().create("buildImage", BootBuildImage.class);
|
this.buildImage = this.project.getTasks().create("buildImage", BootBuildImage.class);
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,6 +17,7 @@
|
||||||
package org.springframework.boot.testsupport.gradle.testkit;
|
package org.springframework.boot.testsupport.gradle.testkit;
|
||||||
|
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
|
import java.util.Collections;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import org.gradle.api.JavaVersion;
|
import org.gradle.api.JavaVersion;
|
||||||
|
@ -33,6 +34,9 @@ public final class GradleVersions {
|
||||||
}
|
}
|
||||||
|
|
||||||
public static List<String> allCompatible() {
|
public static List<String> allCompatible() {
|
||||||
|
if (isJava17()) {
|
||||||
|
return Collections.emptyList();
|
||||||
|
}
|
||||||
if (isJava16()) {
|
if (isJava16()) {
|
||||||
return Arrays.asList("7.0.2", "7.1");
|
return Arrays.asList("7.0.2", "7.1");
|
||||||
}
|
}
|
||||||
|
@ -46,6 +50,10 @@ public final class GradleVersions {
|
||||||
return GradleVersion.current().getVersion();
|
return GradleVersion.current().getVersion();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static boolean isJava17() {
|
||||||
|
return JavaVersion.current().isCompatibleWith(JavaVersion.VERSION_17);
|
||||||
|
}
|
||||||
|
|
||||||
private static boolean isJava16() {
|
private static boolean isJava16() {
|
||||||
return JavaVersion.current().isCompatibleWith(JavaVersion.VERSION_16);
|
return JavaVersion.current().isCompatibleWith(JavaVersion.VERSION_16);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue