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

@Attribute annotation silently gets ignored if the field name doesn't match a getter #171

Open
doublep opened this issue Jul 28, 2022 · 0 comments

Comments

@doublep
Copy link

doublep commented Jul 28, 2022

Is your feature request related to a problem? Please describe.
If you use any non-standard names for storage fields (e.g. _foo rather than just foo), @Attribute annotation on it silently gets ignored. However, since it's the getter that determines what gets delivered as resource properties, this is extremely difficult to notice. In other words, when you access /scim/MyTypeX/123, you get "foo": ... in the response as expected. But the attribute is not present in the response to /scim/Schemas/SCHEMA-URI-FOR-TYPE-X. Renaming field _foo to foo does fix this, but it is extremely unobvious.

Describe the solution you'd like
When the library scans for @Attribute, it should complain about annotations on fields with names it doesn't understand (i.e. that don't match property names). If not with exceptions (this would break backward compatibility, though maybe in this case it's worth it), then at least by logging a big fat warning that is easy to spot.

Describe alternatives you've considered
As I said, renaming does fix this, but 1) it is unobvious that renaming would be the fix; 2) it is difficult even to spot that something needs to be fixed.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant