Reputation: 13115
I'm new to JUnit and Hamcrest and would like best-practice advice so I can decided which documentation to study first.
For starters, which of these assertThat
methods is better?
According to one person last year, "JUnit has the assertThat method, but hamcrest has its own assertThat method that does the same thing.".
According to someone earlier this year, Hamcrest "could potentially give better error messages because the matcher is called to describe the mismatch".
It's hard to tell which versions of Junit and Hamcrest were compared in those posts. So I'd like a recommendation based on the most current released versions.
Upvotes: 22
Views: 15528
Reputation: 3841
In junit 4.13 the method org.junit.Assert.assertThat()
is marked deprecated and the usage of org.hamcrest.MatcherAssert.assertThat()
is recommended.
So better use hamcrest right away even when you use an older version of junit.
Upvotes: 3
Reputation: 31648
It's almost the exact same thing.
Recent versions of JUnit now include hamcrest.
In fact, org.junit.Assert.assertThat 's method signature is
public static <T> void assertThat(T actual,
org.hamcrest.Matcher<T> matcher)
which you will notice uses hamcrest matchers.
You may still want to include your own version of hamcrest because JUnit isn't updated very often and may not always use the latest version of hamcrest.
According to the maven pom, JUnit 4.11 uses hamcrest 1.3 which I believe is the most current as of this writing.
EDIT
I've just read your second article http://blog.code-cop.org/2014/02/assert-or-matcherassert.html and it describes 2 slight differences in the hamcrest assertThat
that make it more useful:
describeMismatch()
.assertThat
signature is different in hamcrest using T actual, Matcher<? super T> matcher
which allows matchers to be super types (like Matcher to compare Integers and Doubles). This usually doesn't matter but when you need it this is a nice feature to have. So use org.hamcrest.MatcherAssert.assertThat
.
Upvotes: 27
Reputation: 943
An excerpt from JUnit 5's User Guide:
However, JUnit Jupiter’s
org.junit.jupiter.Assertions
class does not provide anassertThat()
method like the one found in JUnit 4’sorg.junit.Assert
class which accepts a HamcrestMatcher
. Instead, developers are encouraged to use the built-in support for matchers provided by third-party assertion libraries.
I think for JUnit 4, Hamcrest's assertThat
is (officially) preferred.
Upvotes: 7