-
Notifications
You must be signed in to change notification settings - Fork 38.3k
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
@ComponentScan
added directly and via a meta-annotation leads to multiple scanning
#31704
Comments
I encountered the same issue where this incompatible change prevents me from controlling the scanning scope of the I hope that the Spring Boot team can fix this issue in version 3.2.1. |
Please share a minimal reproducer. |
You can use this project to reproduce this issue: https://github.com/HzjNeverStop/ComponentScanReproducer The main branch use SpringBoot 3.1.5,ChildBean will not register. Then change the SpringBoot version to 3.2.0,ChildBean will be scan and applicaiton init fail |
Thanks for the sample. This appears to be a Spring Framework regression. The failure occurs with Spring Boot 3.1.5 (or 3.1.6) when Spring Framework is upgraded to 6.1. Trying various Framework versions, the problem appears to have been introduced in 6.1.0-M4. We'll transfer this to the Framework team so that they can investigate. |
This comment was marked as resolved.
This comment was marked as resolved.
This comment was marked as resolved.
This comment was marked as resolved.
This seems to be a regression introduced by #30941 |
@ComponentScan
added directly and via a meta-annotation leads to multiple scanning
I plan to address this by allowing a directly present Doing that would still allow us to support the "multiple meta-annotations" use case that we originally sought to support in 6.1 (see #30941). In addition, the behavior for |
Using Spring Boot 3.1.5, my main
Application
class was annotated with both@SpringBootApplication
and@ComponentScan
. The latter is necessary as we have a multi-module project that needs to exclude certain classes to avoid conflicts.I am not able to paste our exact class names, so this is an example:
This worked fine for scanning all our components and autowiring everything together. After upgrading to Spring Boot 3.2, the component scan seems to be running twice: once on
"my.company.module"
as expected with the appropriate filters, but then again on a blank package (thus re-scanning all our components and attempting to create them again, causing bean conflicts).Using a debugger, I traced the change down into
ConfigurationClassParser
inspring-context
, specifically to this line:Set<AnnotationAttributes> componentScans = AnnotationConfigUtils.attributesForRepeatable( sourceClass.getMetadata(), ComponentScan.class, ComponentScans.class);
This specifically occurs when it is processing the main application class:
In 3.1.5, this set after the function call has 1 entry with an expected base package
"my.company.module"
member.In 3.2, this set has 2 entries after the function call, the first with
"my.company.module"
base package member, and the second with a base package of an empty array.After doing some more testing, it seems as though starting in 3.2, each
@ComponentScan
is processed independently even if a package has already been scanned, causing Spring to believe that a component or bean might be duplicated when it isn't.Ex: If my root package is
"my.company"
and I do a component scan of"my.company"
and in another configuration have a scan of"my.company.foo"
, a component that appears inmy.company.foo
package will be detected as a duplicate bean of itself.The text was updated successfully, but these errors were encountered: