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

Problem with class-based projections since Spring Framework 6.1.x #3225

Closed
sondemar opened this issue Dec 20, 2024 · 1 comment
Closed

Problem with class-based projections since Spring Framework 6.1.x #3225

sondemar opened this issue Dec 20, 2024 · 1 comment
Assignees
Labels
type: bug A general bug

Comments

@sondemar
Copy link

According to the Spring Framework issue, the LocalVariableTableParameterNameDiscoverer was completely removed. As a result, the Spring Data JPA project cannot recognize the parameters of constructors for class-based projections in DTO classes that do not include parameter names in the compiled bytecode (i.e., classes compiled without the -parameters flag).

When using such DTO classes from a third-party dependency JAR, the parameter names appear as arg0, arg1, etc. The DefaultParameterNameDiscoverer now only utilizes StandardReflectionParameterNameDiscoverer, which cannot handle these parameter names. Previously, a warning would have been logged for such cases.

I have prepared an example project to demonstrate the issue.

@spring-projects-issues spring-projects-issues added the status: waiting-for-triage An issue we've not yet triaged label Dec 20, 2024
@mp911de
Copy link
Member

mp911de commented Jan 7, 2025

We rely entirely on Spring's infrastructure to correlate property names to constructor arg names. With the removal of LocalVariableTableParameterNameDiscoverer, there's nothing we can do here really. ReturnedClass.detectConstructorParameterNames doesn't check for parameter absence, so we could introduce some logging to indicate improper usage. I'm moving the ticket into Spring Data Commons as that is the place where projection infrastructure comes from.

@mp911de mp911de self-assigned this Jan 7, 2025
@mp911de mp911de transferred this issue from spring-projects/spring-data-jpa Jan 7, 2025
@mp911de mp911de added type: enhancement A general enhancement type: bug A general bug and removed status: waiting-for-triage An issue we've not yet triaged type: enhancement A general enhancement labels Jan 15, 2025
@mp911de mp911de added this to the 3.4.2 (2024.1.2) milestone Jan 15, 2025
mp911de added a commit that referenced this issue Jan 15, 2025
We now skip unnamed DTO projection properties and issue a warning log to raise awareness.

Skipping unnamed (null) properties avoids identification as DTO and only selects properties stemming from named constructor arguments.

Add tests for Kotlin data classes using value classes for verification.

Closes #3225
mp911de added a commit that referenced this issue Jan 15, 2025
We now skip unnamed DTO projection properties and issue a warning log to raise awareness.

Skipping unnamed (null) properties avoids identification as DTO and only selects properties stemming from named constructor arguments.

Add tests for Kotlin data classes using value classes for verification.

Closes #3225
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
type: bug A general bug
Projects
None yet
Development

No branches or pull requests

3 participants