I´m running pure JUnit4 java tests over my pure java files on my project but I can't find a way to use @VisibleForTesting clearly without making the thing manually public.
Ex:
@VisibleForTesting
public Address getAddress() {
return mAddress;
}
The method has to be public
to let it be "public" to tests, but in that case the annotation doesn't make sense right? why not just use a comment if the annotation will not do nothing?
@VisibleForTesting annotation is used in package-methods in Guava, and does not part of JUnit API. The annotation is just a tag to indicate the method can be tested. It even doesn't be loaded in JVM.
Make the method package-private and the test will be able to see it, if the test is in the corresponding test package (same package name as the production code).
Also consider refactoring your code so you don't need to explicitly test a private method, try testing the behaviour of a public interface. Code that is hard to test can be an indication that improvements can be made to production code.
The point of an annotation is that its convention and could be used in static code analysis, whereas a comment could not.
According to Android docs:
Example:
@VisibleForTesting(otherwise = VisibleForTesting.PRIVATE) public Address getAddress()
The Tag itself helps with the linter to identify unwanted access.
To lower the risk of use it directly, add this methods as
internal
in Kotlin orprotected
in Java instead ofpublic
and with that only the tests or classes that are in the same package will be able to access that method.Java:
Kotlin: