From fc678edc69a21f225b3bcb13a44d62674dbb1531 Mon Sep 17 00:00:00 2001 From: Foivos Zakkak Date: Wed, 24 Jul 2024 13:16:57 +0300 Subject: [PATCH] Limit external configuration sources parsing in native-mode `SmallryeConfigBuilder` tries to access properties files from various sources, despite them not being available at run-time nor supported in native-mode, see https://github.com/quarkusio/quarkus/issues/41994 This patch also avoids getting a `MissingRegistrationError` when using `-H:+ThrowMissingRegistrationErrors` or `--exact-reachability-metadata`. Related to https://github.com/quarkusio/quarkus/issues/41994 and https://github.com/quarkusio/quarkus/issues/41995 --- .../deployment/steps/ConfigBuildSteps.java | 12 ++++++++++ .../steps/ConfigGenerationBuildStep.java | 17 ++++++++++---- .../FileSystemOnlySourcesConfigBuilder.java | 22 +++++++++++++++++++ .../yaml/deployment/ConfigYamlProcessor.java | 19 ++++++++++++---- 4 files changed, 62 insertions(+), 8 deletions(-) create mode 100644 core/runtime/src/main/java/io/quarkus/runtime/configuration/FileSystemOnlySourcesConfigBuilder.java diff --git a/core/deployment/src/main/java/io/quarkus/deployment/steps/ConfigBuildSteps.java b/core/deployment/src/main/java/io/quarkus/deployment/steps/ConfigBuildSteps.java index 478b4b9d13ff42..ad76424ba89c53 100644 --- a/core/deployment/src/main/java/io/quarkus/deployment/steps/ConfigBuildSteps.java +++ b/core/deployment/src/main/java/io/quarkus/deployment/steps/ConfigBuildSteps.java @@ -15,7 +15,9 @@ import io.quarkus.deployment.builditem.StaticInitConfigBuilderBuildItem; import io.quarkus.deployment.builditem.nativeimage.RuntimeInitializedClassBuildItem; import io.quarkus.deployment.builditem.nativeimage.ServiceProviderBuildItem; +import io.quarkus.deployment.pkg.steps.NativeOrNativeSourcesBuild; import io.quarkus.deployment.util.ServiceUtil; +import io.quarkus.runtime.configuration.FileSystemOnlySourcesConfigBuilder; import io.quarkus.runtime.configuration.SystemOnlySourcesConfigBuilder; import io.quarkus.runtime.graal.InetRunTime; import io.smallrye.config.ConfigSourceInterceptor; @@ -62,6 +64,16 @@ void systemOnlySources(BuildProducer staticIni runTimeConfigBuilder.produce(new RunTimeConfigBuilderBuildItem(SystemOnlySourcesConfigBuilder.class.getName())); } + /** + * Limit external configuration sources parsing for native executables since they are not supported see + * https://github.com/quarkusio/quarkus/issues/41994 + */ + @BuildStep(onlyIf = NativeOrNativeSourcesBuild.class) + void nativeNoSources(BuildProducer staticInitConfigBuilder, + BuildProducer runTimeConfigBuilder) { + runTimeConfigBuilder.produce(new RunTimeConfigBuilderBuildItem(FileSystemOnlySourcesConfigBuilder.class.getName())); + } + private static class SystemOnlySources implements BooleanSupplier { ConfigBuildTimeConfig configBuildTimeConfig; diff --git a/core/deployment/src/main/java/io/quarkus/deployment/steps/ConfigGenerationBuildStep.java b/core/deployment/src/main/java/io/quarkus/deployment/steps/ConfigGenerationBuildStep.java index feb22a65981b2f..3a38a95c863e4c 100644 --- a/core/deployment/src/main/java/io/quarkus/deployment/steps/ConfigGenerationBuildStep.java +++ b/core/deployment/src/main/java/io/quarkus/deployment/steps/ConfigGenerationBuildStep.java @@ -58,6 +58,7 @@ import io.quarkus.deployment.builditem.ShutdownContextBuildItem; import io.quarkus.deployment.builditem.StaticInitConfigBuilderBuildItem; import io.quarkus.deployment.builditem.SuppressNonRuntimeConfigChangedWarningBuildItem; +import io.quarkus.deployment.builditem.nativeimage.NativeImageResourceBuildItem; import io.quarkus.deployment.builditem.nativeimage.ReflectiveClassBuildItem; import io.quarkus.deployment.builditem.nativeimage.ReflectiveMethodBuildItem; import io.quarkus.deployment.configuration.BuildTimeConfigurationReader; @@ -391,6 +392,17 @@ public void setupConfigOverride( @BuildStep public void watchConfigFiles(BuildProducer watchedFiles) { + for (String configWatchedFile : getConfigFiles()) { + watchedFiles.produce(new HotDeploymentWatchedFileBuildItem(configWatchedFile)); + } + } + + @BuildStep + public NativeImageResourceBuildItem nativeConfigFiles() { + return new NativeImageResourceBuildItem(getConfigFiles()); + } + + private List getConfigFiles() { List configWatchedFiles = new ArrayList<>(); SmallRyeConfig config = ConfigProvider.getConfig().unwrap(SmallRyeConfig.class); @@ -432,10 +444,7 @@ public void watchConfigFiles(BuildProducer wa } } }); - - for (String configWatchedFile : configWatchedFiles) { - watchedFiles.produce(new HotDeploymentWatchedFileBuildItem(configWatchedFile)); - } + return configWatchedFiles; } @BuildStep diff --git a/core/runtime/src/main/java/io/quarkus/runtime/configuration/FileSystemOnlySourcesConfigBuilder.java b/core/runtime/src/main/java/io/quarkus/runtime/configuration/FileSystemOnlySourcesConfigBuilder.java new file mode 100644 index 00000000000000..df17419a49ec3f --- /dev/null +++ b/core/runtime/src/main/java/io/quarkus/runtime/configuration/FileSystemOnlySourcesConfigBuilder.java @@ -0,0 +1,22 @@ +package io.quarkus.runtime.configuration; + +import static io.smallrye.config.PropertiesConfigSourceLoader.inFileSystem; + +import java.nio.file.Paths; + +import io.smallrye.config.SmallRyeConfigBuilder; + +public class FileSystemOnlySourcesConfigBuilder implements ConfigBuilder { + @Override + public SmallRyeConfigBuilder configBuilder(final SmallRyeConfigBuilder builder) { + return builder.withSources( + inFileSystem(Paths.get(System.getProperty("user.dir"), "config", "application.properties").toUri().toString(), + 260, Thread.currentThread().getContextClassLoader())); + } + + @Override + public int priority() { + return Integer.MAX_VALUE; + } + +} diff --git a/extensions/config-yaml/deployment/src/main/java/io/quarkus/config/yaml/deployment/ConfigYamlProcessor.java b/extensions/config-yaml/deployment/src/main/java/io/quarkus/config/yaml/deployment/ConfigYamlProcessor.java index c25fab1f0f91aa..f568a246804a90 100644 --- a/extensions/config-yaml/deployment/src/main/java/io/quarkus/config/yaml/deployment/ConfigYamlProcessor.java +++ b/extensions/config-yaml/deployment/src/main/java/io/quarkus/config/yaml/deployment/ConfigYamlProcessor.java @@ -14,6 +14,7 @@ import io.quarkus.deployment.builditem.HotDeploymentWatchedFileBuildItem; import io.quarkus.deployment.builditem.RunTimeConfigBuilderBuildItem; import io.quarkus.deployment.builditem.StaticInitConfigBuilderBuildItem; +import io.quarkus.deployment.builditem.nativeimage.NativeImageResourceBuildItem; import io.smallrye.config.SmallRyeConfig; public final class ConfigYamlProcessor { @@ -34,10 +35,23 @@ public void yamlConfig( @BuildStep void watchYamlConfig(BuildProducer watchedFiles) { + for (String configWatchedFile : getConfigWatchedFiles()) { + watchedFiles.produce(new HotDeploymentWatchedFileBuildItem(configWatchedFile)); + } + } + + @BuildStep + NativeImageResourceBuildItem nativeYamlConfig() { + return new NativeImageResourceBuildItem(getConfigWatchedFiles()); + } + + private static List getConfigWatchedFiles() { List configWatchedFiles = new ArrayList<>(); String userDir = System.getProperty("user.dir"); // Main files + configWatchedFiles.add("META-INF/microprofile-config.yaml"); + configWatchedFiles.add("META-INF/microprofile-config.yml"); configWatchedFiles.add("application.yaml"); configWatchedFiles.add("application.yml"); configWatchedFiles.add(Paths.get(userDir, "config", "application.yaml").toAbsolutePath().toString()); @@ -53,9 +67,6 @@ void watchYamlConfig(BuildProducer watchedFil configWatchedFiles.add( Paths.get(userDir, "config", String.format("application-%s.yml", profile)).toAbsolutePath().toString()); } - - for (String configWatchedFile : configWatchedFiles) { - watchedFiles.produce(new HotDeploymentWatchedFileBuildItem(configWatchedFile)); - } + return configWatchedFiles; } }