From 44dca6f09f9f49a857ffde28baaf95b47e56aa14 Mon Sep 17 00:00:00 2001 From: Roberto Cortez Date: Fri, 2 Sep 2022 08:52:04 +0100 Subject: [PATCH] Update SmallRye Config to 2.12.0 --- bom/application/pom.xml | 2 +- .../BuildTimeConfigurationReader.java | 4 +- .../arc/runtime/ConfigMappingCreator.java | 37 ++++++++++++++++++- .../jwt/deployment/SmallRyeJwtProcessor.java | 23 +++++------- integration-tests/smallrye-config/pom.xml | 9 ++--- .../it/smallrye/config/ConfigResource.java | 8 ++++ .../it/smallrye/config/QuarkusConfigTest.java | 31 ++++++++++++++++ .../smallrye/config/ServerResourceTest.java | 17 ++------- jakarta/rewrite.yml | 4 +- 9 files changed, 96 insertions(+), 39 deletions(-) create mode 100644 integration-tests/smallrye-config/src/test/java/io/quarkus/it/smallrye/config/QuarkusConfigTest.java diff --git a/bom/application/pom.xml b/bom/application/pom.xml index 794e3c4e0ad63..83e7b28af4731 100644 --- a/bom/application/pom.xml +++ b/bom/application/pom.xml @@ -40,7 +40,7 @@ 1.2 1.0 1.13.1 - 2.11.1 + 2.12.0 3.2.1 3.0.5 2.2.0 diff --git a/core/deployment/src/main/java/io/quarkus/deployment/configuration/BuildTimeConfigurationReader.java b/core/deployment/src/main/java/io/quarkus/deployment/configuration/BuildTimeConfigurationReader.java index 46030d8daf6a8..c9ea61d5ae4af 100644 --- a/core/deployment/src/main/java/io/quarkus/deployment/configuration/BuildTimeConfigurationReader.java +++ b/core/deployment/src/main/java/io/quarkus/deployment/configuration/BuildTimeConfigurationReader.java @@ -404,7 +404,7 @@ ReadResult run() { // we always have to set the map entry ourselves Field field = matched.findField(); Converter converter = getConverter(config, field, ConverterType.of(field)); - map.put(key, config.convertValue(configValue.getNameProfiled(), configValue.getValue(), converter)); + map.put(key, config.convertValue(configValue, converter)); allBuildTimeValues.put(configValue.getNameProfiled(), configValue.getValue()); continue; } @@ -437,7 +437,7 @@ ReadResult run() { // we always have to set the map entry ourselves Field field = matched.findField(); Converter converter = getConverter(config, field, ConverterType.of(field)); - map.put(key, config.convertValue(configValue.getNameProfiled(), configValue.getValue(), converter)); + map.put(key, config.convertValue(configValue, converter)); // cache the resolved value allBuildTimeValues.put(configValue.getNameProfiled(), configValue.getValue()); buildTimeRunTimeValues.put(configValue.getNameProfiled(), configValue.getValue()); diff --git a/extensions/arc/runtime/src/main/java/io/quarkus/arc/runtime/ConfigMappingCreator.java b/extensions/arc/runtime/src/main/java/io/quarkus/arc/runtime/ConfigMappingCreator.java index 7cedbcb1c47e6..276b55345b2fe 100644 --- a/extensions/arc/runtime/src/main/java/io/quarkus/arc/runtime/ConfigMappingCreator.java +++ b/extensions/arc/runtime/src/main/java/io/quarkus/arc/runtime/ConfigMappingCreator.java @@ -1,16 +1,19 @@ package io.quarkus.arc.runtime; -import static io.smallrye.config.inject.ConfigMappingInjectionBean.getPrefixFromInjectionPoint; - +import java.lang.annotation.Annotation; import java.util.Map; +import java.util.Optional; import javax.enterprise.context.spi.CreationalContext; +import javax.enterprise.inject.spi.Annotated; import javax.enterprise.inject.spi.InjectionPoint; import org.eclipse.microprofile.config.ConfigProvider; +import org.eclipse.microprofile.config.inject.ConfigProperties; import io.quarkus.arc.BeanCreator; import io.quarkus.arc.impl.InjectionPointProvider; +import io.smallrye.config.ConfigMapping; import io.smallrye.config.SmallRyeConfig; public class ConfigMappingCreator implements BeanCreator { @@ -27,4 +30,34 @@ public Object create(CreationalContext creationalContext, Map getPrefixFromInjectionPoint(final InjectionPoint injectionPoint) { + Annotated annotated = injectionPoint.getAnnotated(); + if (annotated != null) { + ConfigMapping configMapping = annotated.getAnnotation(ConfigMapping.class); + if (configMapping != null) { + if (!configMapping.prefix().isEmpty()) { + return Optional.of(configMapping.prefix()); + } + } + + ConfigProperties configProperties = annotated.getAnnotation(ConfigProperties.class); + if (configProperties != null) { + if (!ConfigProperties.UNCONFIGURED_PREFIX.equals(configProperties.prefix())) { + return Optional.of(configProperties.prefix()); + } + } + } + + for (Annotation qualifier : injectionPoint.getQualifiers()) { + if (qualifier instanceof ConfigProperties) { + ConfigProperties configPropertiesQualifier = (ConfigProperties) qualifier; + if (!ConfigProperties.UNCONFIGURED_PREFIX.equals(configPropertiesQualifier.prefix())) { + return Optional.of(configPropertiesQualifier.prefix()); + } + } + } + + return Optional.empty(); + } } diff --git a/extensions/smallrye-jwt/deployment/src/main/java/io/quarkus/smallrye/jwt/deployment/SmallRyeJwtProcessor.java b/extensions/smallrye-jwt/deployment/src/main/java/io/quarkus/smallrye/jwt/deployment/SmallRyeJwtProcessor.java index b38b6ef614995..7076b433bddc8 100644 --- a/extensions/smallrye-jwt/deployment/src/main/java/io/quarkus/smallrye/jwt/deployment/SmallRyeJwtProcessor.java +++ b/extensions/smallrye-jwt/deployment/src/main/java/io/quarkus/smallrye/jwt/deployment/SmallRyeJwtProcessor.java @@ -1,7 +1,6 @@ package io.quarkus.smallrye.jwt.deployment; import java.util.HashSet; -import java.util.NoSuchElementException; import java.util.Optional; import java.util.Set; import java.util.function.BooleanSupplier; @@ -120,18 +119,16 @@ FeatureBuildItem feature() { * @return NativeImageResourceBuildItem */ @BuildStep(onlyIf = NativeOrNativeSourcesBuild.class) - NativeImageResourceBuildItem registerNativeImageResources() { - final Config config = ConfigProvider.getConfig(); - try { - Optional publicKeyLocationOpt = config.getOptionalValue("mp.jwt.verify.publickey.location", String.class); - if (publicKeyLocationOpt.isPresent()) { - final String publicKeyLocation = publicKeyLocationOpt.get(); - if (publicKeyLocation.indexOf(':') < 0 || publicKeyLocation.startsWith("classpath:")) { - log.infof("Adding %s to native image", publicKeyLocation); - return new NativeImageResourceBuildItem(publicKeyLocation); - } + void registerNativeImageResources(BuildProducer nativeImageResource) { + Config config = ConfigProvider.getConfig(); + Optional publicKeyLocationOpt = config.getOptionalValue("mp.jwt.verify.publickey.location", String.class); + if (publicKeyLocationOpt.isPresent()) { + String publicKeyLocation = publicKeyLocationOpt.get(); + if (publicKeyLocation.indexOf(':') < 0 || publicKeyLocation.startsWith("classpath:")) { + log.infof("Adding %s to native image", publicKeyLocation); + nativeImageResource.produce(new NativeImageResourceBuildItem(publicKeyLocation)); } - } catch (NoSuchElementException e) { + } else { // The Config may contain expansion variables. Don't fail in this case because the config is not build time. // The user will have to provide the config for runtime and register the resource manually String publicKeyRawValue = Expressions.withoutExpansion(new Supplier() { @@ -142,9 +139,7 @@ public String get() { }); log.warnf("Cannot determine %s of mp.jwt.verify.publickey.location to register with the native image", publicKeyRawValue); - return null; } - return null; } /** diff --git a/integration-tests/smallrye-config/pom.xml b/integration-tests/smallrye-config/pom.xml index f8ae7033bfaad..ece98c2440a4c 100644 --- a/integration-tests/smallrye-config/pom.xml +++ b/integration-tests/smallrye-config/pom.xml @@ -25,11 +25,11 @@ io.quarkus - quarkus-resteasy + quarkus-resteasy-reactive io.quarkus - quarkus-resteasy-jackson + quarkus-resteasy-reactive-jackson @@ -80,7 +80,6 @@ test - io.quarkus @@ -110,7 +109,7 @@ io.quarkus - quarkus-resteasy-deployment + quarkus-resteasy-reactive-deployment ${project.version} pom test @@ -123,7 +122,7 @@ io.quarkus - quarkus-resteasy-jackson-deployment + quarkus-resteasy-reactive-jackson-deployment ${project.version} pom test diff --git a/integration-tests/smallrye-config/src/main/java/io/quarkus/it/smallrye/config/ConfigResource.java b/integration-tests/smallrye-config/src/main/java/io/quarkus/it/smallrye/config/ConfigResource.java index b8f2e3003ff64..8cb380f7d6f49 100644 --- a/integration-tests/smallrye-config/src/main/java/io/quarkus/it/smallrye/config/ConfigResource.java +++ b/integration-tests/smallrye-config/src/main/java/io/quarkus/it/smallrye/config/ConfigResource.java @@ -8,6 +8,8 @@ import javax.ws.rs.core.MediaType; import javax.ws.rs.core.Response; +import org.eclipse.microprofile.config.ConfigProvider; + import io.quarkus.runtime.annotations.RegisterForReflection; import io.smallrye.config.SmallRyeConfig; @@ -29,6 +31,12 @@ public Response profiles() { return Response.ok(config.getProfiles()).build(); } + @GET + @Path("/uuid") + public Response uuid() { + return Response.ok(ConfigProvider.getConfig().getConfigValue("quarkus.uuid")).build(); + } + @RegisterForReflection(targets = { org.eclipse.microprofile.config.ConfigValue.class, io.smallrye.config.ConfigValue.class diff --git a/integration-tests/smallrye-config/src/test/java/io/quarkus/it/smallrye/config/QuarkusConfigTest.java b/integration-tests/smallrye-config/src/test/java/io/quarkus/it/smallrye/config/QuarkusConfigTest.java new file mode 100644 index 0000000000000..ad4d81df86e09 --- /dev/null +++ b/integration-tests/smallrye-config/src/test/java/io/quarkus/it/smallrye/config/QuarkusConfigTest.java @@ -0,0 +1,31 @@ +package io.quarkus.it.smallrye.config; + +import static io.restassured.RestAssured.given; +import static javax.ws.rs.core.Response.Status.OK; +import static org.hamcrest.Matchers.equalTo; +import static org.hamcrest.Matchers.is; +import static org.hamcrest.Matchers.notNullValue; + +import org.junit.jupiter.api.Test; + +import io.quarkus.test.junit.QuarkusTest; + +@QuarkusTest +public class QuarkusConfigTest { + @Test + void uuid() { + given() + .get("/config/{name}", "quarkus.uuid") + .then() + .statusCode(OK.getStatusCode()) + .body("value", is(notNullValue())) + .body("configSourceName", equalTo("DefaultValuesConfigSource")); + + given() + .get("/config/uuid") + .then() + .statusCode(OK.getStatusCode()) + .body("value", is(notNullValue())) + .body("configSourceName", equalTo("DefaultValuesConfigSource")); + } +} diff --git a/integration-tests/smallrye-config/src/test/java/io/quarkus/it/smallrye/config/ServerResourceTest.java b/integration-tests/smallrye-config/src/test/java/io/quarkus/it/smallrye/config/ServerResourceTest.java index 060c3bb661708..63bfed5338bfc 100644 --- a/integration-tests/smallrye-config/src/test/java/io/quarkus/it/smallrye/config/ServerResourceTest.java +++ b/integration-tests/smallrye-config/src/test/java/io/quarkus/it/smallrye/config/ServerResourceTest.java @@ -10,25 +10,13 @@ import static org.hamcrest.Matchers.hasItem; import static org.hamcrest.Matchers.hasSize; -import org.junit.jupiter.api.BeforeAll; import org.junit.jupiter.api.Test; import io.quarkus.test.junit.QuarkusTest; -import io.restassured.RestAssured; import io.restassured.http.Header; @QuarkusTest class ServerResourceTest { - @BeforeAll - static void beforeAll() { - RestAssured.filters( - (requestSpec, responseSpec, ctx) -> { - requestSpec.header(new Header(CONTENT_TYPE, APPLICATION_JSON)); - requestSpec.header(new Header(ACCEPT, APPLICATION_JSON)); - return ctx.next(requestSpec, responseSpec); - }); - } - @Test void mapping() { given() @@ -99,7 +87,10 @@ void info() { @Test void invalid() { - given().get("/server/validator/{prefix}", "cloud") + given() + .header(new Header(CONTENT_TYPE, APPLICATION_JSON)) + .header(new Header(ACCEPT, APPLICATION_JSON)) + .get("/server/validator/{prefix}", "cloud") .then() .statusCode(OK.getStatusCode()) .body("errors", hasSize(9)) diff --git a/jakarta/rewrite.yml b/jakarta/rewrite.yml index c1ab91fd318a6..f1fe2de23efbb 100644 --- a/jakarta/rewrite.yml +++ b/jakarta/rewrite.yml @@ -502,7 +502,7 @@ displayName: Adjust SmallRye dependencies recipeList: - org.openrewrite.maven.ChangePropertyValue: key: smallrye-common.version - newValue: 2.0.0-RC3 + newValue: 2.0.0 - org.openrewrite.maven.ChangePropertyValue: key: microprofile-context-propagation.version newValue: 1.3 @@ -514,7 +514,7 @@ recipeList: newValue: 3.0 - org.openrewrite.maven.ChangePropertyValue: key: smallrye-config.version - newValue: 3.0.0-RC4 + newValue: 3.0.0 - org.openrewrite.maven.ChangePropertyValue: key: smallrye-fault-tolerance.version newValue: 6.0.0-RC4