Skip to content

Commit

Permalink
Allow additional JVM args when running tests via toolchain
Browse files Browse the repository at this point in the history
  • Loading branch information
dreis2211 committed Jun 24, 2021
1 parent 674b9fb commit 1eb8a3d
Show file tree
Hide file tree
Showing 4 changed files with 22 additions and 9 deletions.
Expand Up @@ -17,6 +17,7 @@
package org.springframework.boot.build.toolchain;

import org.gradle.api.Project;
import org.gradle.api.provider.ListProperty;
import org.gradle.api.provider.Property;
import org.gradle.jvm.toolchain.JavaLanguageVersion;

Expand All @@ -29,10 +30,13 @@ public class ToolchainExtension {

private final Property<JavaLanguageVersion> maximumCompatibleJavaVersion;

private final ListProperty<String> testJvmArgs;

private final JavaLanguageVersion javaVersion;

public ToolchainExtension(Project project) {
this.maximumCompatibleJavaVersion = project.getObjects().property(JavaLanguageVersion.class);
this.testJvmArgs = project.getObjects().listProperty(String.class);
String toolchainVersion = (String) project.findProperty("toolchainVersion");
this.javaVersion = (toolchainVersion != null) ? JavaLanguageVersion.of(toolchainVersion) : null;
}
Expand All @@ -41,6 +45,10 @@ public Property<JavaLanguageVersion> getMaximumCompatibleJavaVersion() {
return this.maximumCompatibleJavaVersion;
}

public ListProperty<String> getTestJvmArgs() {
return this.testJvmArgs;
}

JavaLanguageVersion getJavaVersion() {
return this.javaVersion;
}
Expand Down
Expand Up @@ -16,9 +16,6 @@

package org.springframework.boot.build.toolchain;

import java.util.Collections;
import java.util.List;

import org.gradle.api.Plugin;
import org.gradle.api.Project;
import org.gradle.api.plugins.JavaPluginExtension;
Expand Down Expand Up @@ -56,7 +53,7 @@ private void configure(Project project, ToolchainExtension toolchain) {
JavaToolchainSpec toolchainSpec = project.getExtensions().getByType(JavaPluginExtension.class)
.getToolchain();
toolchainSpec.getLanguageVersion().set(toolchain.getJavaVersion());
configureTestToolchain(project);
configureTestToolchain(project, toolchain);
}
}

Expand All @@ -71,11 +68,11 @@ private void disableToolchainTasks(Project project) {
project.getTasks().withType(Test.class, (task) -> task.setEnabled(false));
}

private void configureTestToolchain(Project project) {
project.getTasks().withType(Test.class, (test) -> {
List<String> arguments = Collections.singletonList("--illegal-access=warn");
test.jvmArgs(arguments);
});
private void configureTestToolchain(Project project, ToolchainExtension toolchain) {
if (!toolchain.getTestJvmArgs().isPresent()) {
return;
}
project.getTasks().withType(Test.class, (test) -> test.jvmArgs(toolchain.getTestJvmArgs().get()));
}

}
Expand Up @@ -6,6 +6,10 @@ plugins {

description = "Spring Boot Loader"

toolchain {
testJvmArgs.add("--add-opens=java.base/java.util.zip=ALL-UNNAMED")
}

dependencies {
compileOnly("org.springframework:spring-core")

Expand Down
4 changes: 4 additions & 0 deletions spring-boot-project/spring-boot/build.gradle
Expand Up @@ -9,6 +9,10 @@ plugins {

description = "Spring Boot"

toolchain {
testJvmArgs.add("--add-opens=java.base/java.net=ALL-UNNAMED")
}

def tomcatConfigProperties = "$buildDir/tomcat-config-properties"

configurations {
Expand Down

0 comments on commit 1eb8a3d

Please sign in to comment.