Reputation: 15879
I use the following code at the moment to assert on a boolean
value, however the method org.hamcrest.Matchers.is()
is deprecated.
assertThat(someValue, is(false));
Is there a simple alternative syntax to test for boolean values without resorting to assertTrue()
which gives you poor failure messages like "java.lang.AssertionError"
Edit after receiving comments/answers
My initial concerns were raised because Eclipse shows the following import statement as deprecated
On viewing the Hamcrest API docs there are 3 overloaded variations of the is()
method, only one of which is deprecated.
Therefore, to clarify the comment from @mark and the answer from @matt, the use of is()
that I have posted above is valid and not deprecated.
Upvotes: 63
Views: 51137
Reputation: 163
This is deprecated:
import static org.junit.Assert.assertThat;
We can use this instead:
import static org.hamcrest.MatcherAssert.assertThat;
Upvotes: 7
Reputation: 6658
This is what worked for me in Jan 2022
import static org.hamcrest.CoreMatchers.*;
Upvotes: 1
Reputation: 393
It is said, use instanceOf
for class matcher in the document.
http://junit.org/javadoc/latest/org/hamcrest/core/Is.html#isA(java.lang.Class)
is(IOException.class);
will be
is(instanceOf(IOException.class));
for example.
Upvotes: 3
Reputation: 36532
I had thought this was a transitive dependency issue, but it's really just a display issue in Eclipse where it marks the import as deprecated because one overloaded form is. The code should compile fine since the import will expose all forms.
The deprecated form has been removed from the source and will not exist in the next release (1.4).
Original Answer
The problem is that JUnit includes a set of Hamcrest classes in its JAR. You can use junit-dep.jar
for now, but newer versions (4.9 and 4.10 so far) of JUnit omit them.
Upvotes: 10
Reputation: 139921
Have you tried equalTo(T)
?
assertThat(someValue, equalTo(false));
I don't see that is(T)
is deprecated - is(Class) is deprecated however.
Upvotes: 53