From 778834e1dea04fe9a84483a1bb4d31cf1c186c2d Mon Sep 17 00:00:00 2001 From: Roberto Cortez Date: Tue, 20 Aug 2024 13:38:37 +0100 Subject: [PATCH] Ignore config ServiceLoader files from Gradle sources --- .../quarkus/gradle/tasks/EffectiveConfig.java | 34 +++++++++++++++++-- 1 file changed, 32 insertions(+), 2 deletions(-) diff --git a/devtools/gradle/gradle-application-plugin/src/main/java/io/quarkus/gradle/tasks/EffectiveConfig.java b/devtools/gradle/gradle-application-plugin/src/main/java/io/quarkus/gradle/tasks/EffectiveConfig.java index 096f3e9f8670a..52583a3088096 100644 --- a/devtools/gradle/gradle-application-plugin/src/main/java/io/quarkus/gradle/tasks/EffectiveConfig.java +++ b/devtools/gradle/gradle-application-plugin/src/main/java/io/quarkus/gradle/tasks/EffectiveConfig.java @@ -5,10 +5,13 @@ import static java.util.Collections.unmodifiableMap; import java.io.File; +import java.io.IOException; import java.net.MalformedURLException; import java.net.URL; import java.net.URLClassLoader; import java.util.ArrayList; +import java.util.Collections; +import java.util.Enumeration; import java.util.HashMap; import java.util.List; import java.util.Map; @@ -75,7 +78,6 @@ private EffectiveConfig(Builder builder) { .withMapping(PackageConfig.class) .withMapping(NativeConfig.class) .withInterceptors(ConfigCompatibility.FrontEnd.instance(), ConfigCompatibility.BackEnd.instance()) - .setAddDiscoveredSecretKeysHandlers(false) .build(); this.values = generateFullConfigMap(config); } @@ -168,6 +170,17 @@ Builder withProfile(String profile) { } } + /** + * Builds a specific {@link ClassLoader} for {@link SmallRyeConfig} to include potential configuration files in + * the application source paths. The {@link ClassLoader} excludes the path META-INF/services because + * in most cases, the ServiceLoader files will reference service implementations that are not yet compiled. It is + * possible that the service files reference implementations from dependencies, which are valid and, in this case, + * wrongly excluded, but most likely only required for the application and not the Gradle build. We will rewrite + * the implementation to cover that case if this becomes an issue. + * + * @param sourceDirectories a Set of source directories specified by the Gradle build. + * @return a {@link ClassLoader} with the source paths + */ private static ClassLoader toUrlClassloader(Set sourceDirectories) { List urls = new ArrayList<>(); for (File sourceDirectory : sourceDirectories) { @@ -177,6 +190,23 @@ private static ClassLoader toUrlClassloader(Set sourceDirectories) { throw new RuntimeException(e); } } - return new URLClassLoader(urls.toArray(new URL[0])); + + return new URLClassLoader(urls.toArray(new URL[0]), Thread.currentThread().getContextClassLoader()) { + @Override + public URL getResource(String name) { + if (name.startsWith("META-INF/services/")) { + return null; + } + return super.getResource(name); + } + + @Override + public Enumeration getResources(String name) throws IOException { + if (name.startsWith("META-INF/services/")) { + return Collections.emptyEnumeration(); + } + return super.getResources(name); + } + }; } }