From ba3f62a4debf2a3cf0540b4a77be8a09fca1c21f Mon Sep 17 00:00:00 2001 From: Martin Kouba Date: Fri, 7 Jun 2024 10:43:10 +0200 Subject: [PATCH] Qute: fix regression for optimized generated value resolvers - fix regression introduced in https://github.com/quarkusio/quarkus/pull/33984 - if there are multiple type-safe templates with the same parameter declaration then _no_ or _incomplete_ value resolver may be generated --- .../qute/deployment/QuteProcessor.java | 2 +- .../ImplicitValueResolversTest.java | 61 +++++++++++++++++++ 2 files changed, 62 insertions(+), 1 deletion(-) create mode 100644 extensions/qute/deployment/src/test/java/io/quarkus/qute/deployment/generatedresolvers/ImplicitValueResolversTest.java diff --git a/extensions/qute/deployment/src/main/java/io/quarkus/qute/deployment/QuteProcessor.java b/extensions/qute/deployment/src/main/java/io/quarkus/qute/deployment/QuteProcessor.java index 39b225344a89d..5b97c298ee690 100644 --- a/extensions/qute/deployment/src/main/java/io/quarkus/qute/deployment/QuteProcessor.java +++ b/extensions/qute/deployment/src/main/java/io/quarkus/qute/deployment/QuteProcessor.java @@ -1001,7 +1001,7 @@ public String apply(String id) { // Register all param declarations as targets of implicit value resolvers for (ParameterDeclaration paramDeclaration : templateAnalysis.parameterDeclarations) { Type type = TypeInfos.resolveTypeFromTypeInfo(paramDeclaration.getTypeInfo()); - if (type != null) { + if (type != null && !implicitClassToMembersUsed.containsKey(type.name())) { implicitClassToMembersUsed.put(type.name(), new HashSet<>()); } } diff --git a/extensions/qute/deployment/src/test/java/io/quarkus/qute/deployment/generatedresolvers/ImplicitValueResolversTest.java b/extensions/qute/deployment/src/test/java/io/quarkus/qute/deployment/generatedresolvers/ImplicitValueResolversTest.java new file mode 100644 index 0000000000000..2b740c276290d --- /dev/null +++ b/extensions/qute/deployment/src/test/java/io/quarkus/qute/deployment/generatedresolvers/ImplicitValueResolversTest.java @@ -0,0 +1,61 @@ +package io.quarkus.qute.deployment.generatedresolvers; + +import static org.junit.jupiter.api.Assertions.assertEquals; +import static org.junit.jupiter.api.Assertions.assertNotNull; + +import java.util.List; + +import jakarta.inject.Inject; + +import org.jboss.shrinkwrap.api.asset.StringAsset; +import org.junit.jupiter.api.Test; +import org.junit.jupiter.api.extension.RegisterExtension; + +import io.quarkus.qute.CheckedTemplate; +import io.quarkus.qute.Engine; +import io.quarkus.qute.TemplateInstance; +import io.quarkus.qute.ValueResolver; +import io.quarkus.qute.generator.ValueResolverGenerator; +import io.quarkus.test.QuarkusUnitTest; + +public class ImplicitValueResolversTest { + + @RegisterExtension + static final QuarkusUnitTest config = new QuarkusUnitTest() + .withApplicationRoot((jar) -> jar + .addAsResource(new StringAsset("{name.toUpperCase}"), "templates/hello.html") + .addAsResource(new StringAsset("{name}"), "templates/bye.html") + .addAsResource(new StringAsset("{name}"), "templates/zero.html")); + + @CheckedTemplate(basePath = "") + record hello(String name) implements TemplateInstance { + }; + + @CheckedTemplate(basePath = "") + record bye(String name) implements TemplateInstance { + }; + + @CheckedTemplate(basePath = "") + record zero(String name) implements TemplateInstance { + }; + + @Inject + Engine engine; + + @Test + public void testImplicitResolvers() { + assertEquals("FOO", new hello("Foo").render()); + assertEquals("Bar", new bye("Bar").render()); + assertEquals("Baz", new zero("Baz").render()); + List resolvers = engine.getValueResolvers(); + ValueResolver stringResolver = null; + for (ValueResolver valueResolver : resolvers) { + if (valueResolver.getClass().getName().endsWith(ValueResolverGenerator.SUFFIX) + && valueResolver.getClass().getName().contains("String")) { + stringResolver = valueResolver; + } + } + assertNotNull(stringResolver); + } + +}