Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

ArC: implement CDI 4.1 #40208

Merged
merged 17 commits into from
Apr 26, 2024
Merged

ArC: implement CDI 4.1 #40208

merged 17 commits into from
Apr 26, 2024

Conversation

Ladicek
Copy link
Contributor

@Ladicek Ladicek commented Apr 23, 2024

No description provided.

@Ladicek Ladicek requested review from mkouba and manovotn April 23, 2024 09:38
@Ladicek
Copy link
Contributor Author

Ladicek commented Apr 23, 2024

Each commit is best reviewed separately. They are all fairly small, except of the one that adds support for method invokers.

@quarkus-bot quarkus-bot bot added area/arc Issue related to ARC (dependency injection) area/dependencies Pull requests that update a dependency file area/devtools Issues/PR related to maven, gradle, platform and cli tooling/plugins area/documentation area/platform Issues related to definition and interaction with Quarkus Platform labels Apr 23, 2024
@gsmet
Copy link
Member

gsmet commented Apr 23, 2024

Not a review but nice work :).

This comment has been minimized.

This comment has been minimized.

Copy link

github-actions bot commented Apr 23, 2024

🙈 The PR is closed and the preview is expired.

@Ladicek
Copy link
Contributor Author

Ladicek commented Apr 24, 2024

Rebased.

This comment has been minimized.

Copy link
Contributor

@mkouba mkouba left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@Ladicek do you plan to add support for Quarkus build items used to define method invokers?

@Ladicek
Copy link
Contributor Author

Ladicek commented Apr 24, 2024

I don't think that's necessary. Method invokers can be registered in the bean registration phase, for which a build item already exists. (Aside: maybe this should be better documented?) I have a few examples (@Scheduled, @ConsumeEvent, Reactive Messaging) that I hope to submit after this is merged and I didn't need any new build items.

This comment has been minimized.

@mkouba
Copy link
Contributor

mkouba commented Apr 24, 2024

I don't think that's necessary. Method invokers can be registered in the bean registration phase, for which a build item already exists. (Aside: maybe this should be better documented?) I have a few examples (@Scheduled, @ConsumeEvent, Reactive Messaging) that I hope to submit after this is merged and I didn't need any new build items.

With BeanRegistrar#getInvokerFactory() you mean? Yes, that's hidden very well :-). OTOH we also have SyntheticBeanBuildItem and BeanRegistrar.RegistrationContext#configure() but I'm not sure if a dedicated build item would bring any benefit here...

@Ladicek
Copy link
Contributor Author

Ladicek commented Apr 24, 2024

With BeanRegistrar#getInvokerFactory() you mean? Yes, that's hidden very well :-)

Indeed that's what I meant :-) Yeah, I agree. I should probably write some documentation into the CDI integration guide...

This comment has been minimized.

This comment has been minimized.

@Ladicek
Copy link
Contributor Author

Ladicek commented Apr 26, 2024

Here's a PR to remove the test for @ManagedBean from the RESTEasy Reactive TCK: quarkusio/resteasy-reactive-testsuite#7 Will update this PR after that one is merged.

Ladicek added 17 commits April 26, 2024 09:57
A producer may have priority as defined by CDI 4.1 (or obtained from
a stereotype, as permitted but not really specified in CDI 4.0),
but does not necessarily have to be an alternative. During ambiguity
resolution, if such non-alternative producer with priority is declared
on an alternative bean, we must first consider the priority declared
on the producer, even if the producer is not itself an alternative.

To do that, this commit changes the ambiguity resolution implementation
to use `BeanInfo.getPririty()` instead of `getAlternativePriority()`.
The difference is that `getAlternativePriority()` returns `null` when
the bean itself is not an alternative. Given that the method was
previously only used during ambiguity resolution, and only after
non-alternative beans (and producers on non-alternative beans)
were eliminated, this is correct.

In fact, this commit also marks `BeanInfo.getAlternativePriority()`
as deprecated for removal. For all practical purposes, `getPriority()`
is a better choice; it is usually meaningless to consider a bean
priority only when the bean is an alternative, and pretend that
the bean has no priority when it is not an alternative.
The new version doesn't contain the `@ManagedBean` annotation,
which was removed in Jakarta Annotations 3.0.
@Ladicek
Copy link
Contributor Author

Ladicek commented Apr 26, 2024

Rebased and updated the RESTEasy Reactive TCK.

Copy link

quarkus-bot bot commented Apr 26, 2024

Status for workflow Quarkus Documentation CI

This is the status report for running Quarkus Documentation CI on commit 944008f.

✅ The latest workflow run for the pull request has completed successfully.

It should be safe to merge provided you have a look at the other checks in the summary.

⚠️ There are other workflow runs running, you probably need to wait for their status before merging.

Copy link

quarkus-bot bot commented Apr 26, 2024

Status for workflow Quarkus CI

This is the status report for running Quarkus CI on commit 944008f.

Failing Jobs

Status Name Step Failures Logs Raw logs Build scan
✔️ JVM Tests - JDK 17 Logs Raw logs 🔍
✔️ JVM Tests - JDK 21 Logs Raw logs 🔍
JVM Tests - JDK 17 Windows Build ⚠️ Check → Logs Raw logs 🚧

You can consult the Develocity build scans.


Flaky tests - Develocity

⚙️ Maven Tests - JDK 17 Windows

📦 integration-tests/maven

io.quarkus.maven.it.CreateProjectMojoIT.testProjectGenerationFromScratch - History

  • Cannot delete directory: target\test-classes\projects\project-generation - java.lang.RuntimeException
java.lang.RuntimeException: Cannot delete directory: target\test-classes\projects\project-generation
	at io.quarkus.maven.it.MojoTestBase.initEmptyProject(MojoTestBase.java:72)
	at io.quarkus.maven.it.CreateProjectMojoIT.testProjectGenerationFromScratch(CreateProjectMojoIT.java:60)
	at java.base/java.lang.reflect.Method.invoke(Method.java:568)
	at java.base/java.util.ArrayList.forEach(ArrayList.java:1511)
	at java.base/java.util.ArrayList.forEach(ArrayList.java:1511)
Caused by: org.apache.commons.io.IOExceptionList: 1 exception(s): [org.apache.commons.io.IOIndexedException: IOException #0: Cannot delete file: target\test-classes\projects\project-generation\build-create-project-generation.log]
	at org.apache.commons.io.IOExceptionList.checkEmpty(IOExceptionList.java:50)

io.quarkus.maven.it.CreateProjectMojoIT.testProjectGenerationFromScratch - History

  • Cannot delete directory: target\test-classes\projects\project-generation - java.lang.RuntimeException
java.lang.RuntimeException: Cannot delete directory: target\test-classes\projects\project-generation
	at io.quarkus.maven.it.MojoTestBase.initEmptyProject(MojoTestBase.java:72)
	at io.quarkus.maven.it.CreateProjectMojoIT.testProjectGenerationFromScratch(CreateProjectMojoIT.java:60)
	at java.base/java.lang.reflect.Method.invoke(Method.java:568)
	at java.base/java.util.ArrayList.forEach(ArrayList.java:1511)
	at java.base/java.util.ArrayList.forEach(ArrayList.java:1511)
Caused by: org.apache.commons.io.IOExceptionList: 1 exception(s): [org.apache.commons.io.IOIndexedException: IOException #0: Cannot delete file: target\test-classes\projects\project-generation\build-create-project-generation.log]
	at org.apache.commons.io.IOExceptionList.checkEmpty(IOExceptionList.java:50)

@gsmet
Copy link
Member

gsmet commented Apr 26, 2024

@mkouba @manovotn all good for you? CI looks happy. I let you merge if you are :).

@manovotn manovotn merged commit b77999a into quarkusio:main Apr 26, 2024
53 of 54 checks passed
@quarkus-bot quarkus-bot bot added this to the 3.11 - main milestone Apr 26, 2024
@Ladicek Ladicek deleted the arc-cdi-4.1 branch April 29, 2024 06:34
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
area/arc Issue related to ARC (dependency injection) area/dependencies Pull requests that update a dependency file area/devtools Issues/PR related to maven, gradle, platform and cli tooling/plugins area/documentation area/platform Issues related to definition and interaction with Quarkus Platform triage/flaky-test
Projects
Development

Successfully merging this pull request may close these issues.

5 participants