From b0af544108ee17c4435291af23c358fd39c8e883 Mon Sep 17 00:00:00 2001 From: Gasper Kojek Date: Mon, 29 Jan 2024 12:35:36 +0100 Subject: [PATCH] Make runtimeclasspath an internal input, from which the resolvedClasspathNames are calculated and retreived as inputs. --- .../gradle/ApplicationClasspathInspector.java | 15 ++++++++++----- .../gradle/MicronautComponentPlugin.java | 1 - 2 files changed, 10 insertions(+), 6 deletions(-) diff --git a/minimal-plugin/src/main/java/io/micronaut/gradle/ApplicationClasspathInspector.java b/minimal-plugin/src/main/java/io/micronaut/gradle/ApplicationClasspathInspector.java index f0f93d2e..f1db6e8e 100644 --- a/minimal-plugin/src/main/java/io/micronaut/gradle/ApplicationClasspathInspector.java +++ b/minimal-plugin/src/main/java/io/micronaut/gradle/ApplicationClasspathInspector.java @@ -19,8 +19,9 @@ import org.gradle.api.file.ConfigurableFileCollection; import org.gradle.api.file.RegularFileProperty; import org.gradle.api.tasks.CacheableTask; -import org.gradle.api.tasks.Classpath; import org.gradle.api.tasks.InputFiles; +import org.gradle.api.tasks.Input; +import org.gradle.api.tasks.Internal; import org.gradle.api.tasks.OutputFile; import org.gradle.api.tasks.PathSensitive; import org.gradle.api.tasks.PathSensitivity; @@ -31,6 +32,7 @@ import java.io.IOException; import java.io.PrintWriter; import java.util.Set; +import java.util.stream.Collectors; @CacheableTask public abstract class ApplicationClasspathInspector extends DefaultTask { @@ -38,10 +40,14 @@ public abstract class ApplicationClasspathInspector extends DefaultTask { @PathSensitive(PathSensitivity.RELATIVE) public abstract ConfigurableFileCollection getResources(); - @InputFiles - @Classpath + @Internal public abstract ConfigurableFileCollection getRuntimeClasspath(); + @Input + public Set getResolvedClasspathNames() { + return getRuntimeClasspath().getFiles().stream().map(File::getName).collect(Collectors.toSet()); + } + @OutputFile public abstract RegularFileProperty getReportFile(); @@ -51,8 +57,7 @@ void inspect() throws IOException { Set resources = getResources().getFiles(); if (resources.stream().anyMatch(ApplicationClasspathInspector::isYamlConfigurationFile)) { writer.println("YAML configuration file detected"); - Set runtimeClasspath = getRuntimeClasspath().getFiles(); - if (runtimeClasspath.stream().noneMatch(f -> f.getName().startsWith("snakeyaml"))) { + if (getResolvedClasspathNames().stream().noneMatch(n -> n.startsWith("snakeyaml"))) { writer.println("Didn't find snakeyaml on classpath. Failing"); throw new RuntimeException("YAML configuration file detected but snakeyaml is not on classpath. Make sure to add a runtimeOnly dependency on snakeyaml, e.g 'runtimeOnly(\"org.yaml:snakeyaml\")'"); } diff --git a/minimal-plugin/src/main/java/io/micronaut/gradle/MicronautComponentPlugin.java b/minimal-plugin/src/main/java/io/micronaut/gradle/MicronautComponentPlugin.java index cc0047c3..87f9f7e8 100644 --- a/minimal-plugin/src/main/java/io/micronaut/gradle/MicronautComponentPlugin.java +++ b/minimal-plugin/src/main/java/io/micronaut/gradle/MicronautComponentPlugin.java @@ -297,7 +297,6 @@ private void configureDefaultGroovySourceSet(Project p, private static TaskProvider registerInspectRuntimeClasspath(Project project, TaskContainer tasks) { return tasks.register(INSPECT_RUNTIME_CLASSPATH_TASK_NAME, ApplicationClasspathInspector.class, task -> { - var javaPluginExtension = PluginsHelper.javaPluginExtensionOf(project); task.setGroup(BasePlugin.BUILD_GROUP); task.setDescription("Performs sanity checks of the runtime classpath to warn about misconfigured builds"); task.getRuntimeClasspath().from(project.getConfigurations().getByName(JavaPlugin.RUNTIME_CLASSPATH_CONFIGURATION_NAME));