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

Support org.apache.commons.lang3.StringUtils.isNotEmpty #932

Closed
ilopezv opened this issue Mar 13, 2024 · 5 comments · Fixed by #1062
Closed

Support org.apache.commons.lang3.StringUtils.isNotEmpty #932

ilopezv opened this issue Mar 13, 2024 · 5 comments · Fixed by #1062

Comments

@ilopezv
Copy link

ilopezv commented Mar 13, 2024

Add method support for org.apache.commons.lang3.StringUtils.isNotEmpty

Following code rise a exception with all versions of nullaway including 0.10.24
image-nullaway

[75,103] [NullAway] dereferenced expression this.properties.username() is @Nullable
ERROR    (see http://t.uber.com/nullaway )
ERROR   Did you mean '@SuppressWarnings("NullAway") @Override'?
[76,40] [NullAway] dereferenced expression this.properties.password() is @Nullable
ERROR   (see http://t.uber.com/nullaway )
ERROR   Did you mean '@SuppressWarnings("NullAway") @Override'?

Also I tried to use the following config but it not worked

-XepOpt:NullAway:CheckOptionalEmptiness=true \
-XepOpt:NullAway:KnownInitializers=org.apache.commons.lang3.StringUtils.isNotEmpty

same happens with org.springframework.util.StringUtils

@msridhar
Copy link
Collaborator

The issue is that you call this.properties.username() (and password()) inside a lambda body. NullAway doesn't know when the lambda function will be invoked, and it does not assume that username() and password() will remain non-null until that point. If you store this.properties.username() and password() in local variables and do both the isNotEmpty() checks and the uses with those locals, everything will work (since the value of the local variables cannot change).

@ilopezv
Copy link
Author

ilopezv commented Mar 13, 2024

I know that the issue is closed, but it is not a similar case?
There is no lambda and nullpointer checks have been made at line 43.

image

KnownInitializers has been configured with org.apache.commons.collections4.isNotEmpty

-XepOpt:NullAway:KnownInitializers=org.springframework.util.Assert.notNull,org.apache.commons.collections4.isNotEmpty \
-XepOpt:NullAway:CheckOptionalEmptiness=true \ 

And the error still appears at line 45

[ERROR] /C:/santalucia/workspace/ams-spring-data/ams-spring-data-rest/src/main/java/com/santalucia/arq/ams/data/rest/config/repository/AmsRepositoryRestConfigurer.java:[45,52] [NullAway] dereferenced expression properties.exposeIdsFor() is @Nullable
[ERROR]     (see http://t.uber.com/nullaway )
[ERROR]   Did you mean '@SuppressWarnings("NullAway") @Override'?

@msridhar
Copy link
Collaborator

This is a different case. I don't think the KnownInitializers flag is being used correctly; that flag is for (most likely inherited) methods that behave like constructors almost and run before other methods in the class:

https://github.com/uber/NullAway/wiki/Configuration#known-initializers

For this case, we seem to be missing a model for the relevant CollectionUtils.isNotEmpty() method. That would be added around here:

.put(methodRef("spark.utils.CollectionUtils", "isNotEmpty(java.util.Collection<?>)"), 0)

A PR with a fix would be welcome!

@pochopsp
Copy link
Contributor

Hello @msridhar . Would it just be sufficient to add a
.put(methodRef("org.apache.commons.collections4.CollectionUtils", "isNotEmpty(java.util.Collection<?>)"), 0)
?
P.S. I noticed that apache had a previous version with a different package name org.apache.commons.collections.CollectionUtils . Do we need to support this too ?

@msridhar
Copy link
Collaborator

@pochopsp something like that should be sufficient, but we should write a test to be sure. And yeah I'm fine with supporting org.apache.commons.collections.CollectionUtils also.

@msridhar msridhar linked a pull request Oct 28, 2024 that will close this issue
3 tasks
msridhar pushed a commit that referenced this issue Oct 28, 2024
#1062)

Thank you for contributing to NullAway!

Please note that once you click "Create Pull Request" you will be asked
to sign our [Uber Contributor License
Agreement](https://cla-assistant.io/uber/NullAway) via [CLA
assistant](https://cla-assistant.io/).

Before pressing the "Create Pull Request" button, please provide the
following:

- [ ] Added library model for Apache Commons CollectionUtils.isNotEmpty

  - [ ] related to issue #932 

- [ ] `void apacheCollectionsCollectionUtilsIsNotEmpty()` and `void
apacheCollectionsCollectionUtilsIsNotEmpty()` tests have been added to
`FrameworkTests.java`
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants