Ignoring fields

By default, EqualsVerifier assumes that all (non-static) fields of your class participate in equals and hashCode.

This is great, because it ensures that if you add a field, you can’t forget to update your equals and hashCode methods. If you do, EqualsVerifier will fail the test.

Ignoring fields

Sometimes you don’t want this, though. In that case, you can configure EqualsVerifier to ignore certain fields, like this:

EqualsVerifier.forClass(Foo.class)
    .withIgnoredFields("bar", "baz")
    .verify();

It accepts a varargs argument, so you can specify as many fields as you like. If you specify a field that doesn’t exist on the class, EqualsVerifier throws an exception. This is done to avoid bugs caused by rename refactorings, since the fields have to be specified as strings.

If you do this, EqualsVerifier assumes that the fields bar and baz don’t participate in equals. If EqualsVerifier now notices that they do participate, EqualsVerifier will fail the test.

Including fields

If your class has a lot of fields, but it determines equality based on only a few of them, you can also turn it around and specify precisely the fields you want:

EqualsVerifier.forClass(Foo.class)
    .withOnlyTheseFields("bar", "baz")
    .verify();

Now only bar and baz can participate in equals. EqualsVerifier fails the test if any other field participates in equals, or if bar or baz somehow don’t participate. It will also fail the test if no field called bar or baz exists in the class.

Like withIgnoredFields, withOnlyTheseFields accepts a varargs argument, so you can specify as few or as many fields as you need. Again, EqualsVerifier throws an exception if any of the fields doesn’t exist.

Transient fields

Java has the transient keyword to exclude fields from serialization, and JPA has the @Transient annotation to exclude fields from being persisted. In both cases, these fields should not participate in equals. EqualsVerifier acknowledges this, and will ignore these fields. This means you don’t have to call withIgnoredFields for these fields.

If these fields do participate in equals, EqualsVerifier fails the test. This behavior can be avoided by suppressing Warning.TRANSIENT_FIELDS.

Non-final fields

If the state of your class is defined by final fields, and you also have one or more non-final fields in your class (for instance because you need to cache something), you can tell EqualsVerifier to ignore the non-final fields:

EqualsVerifier.forClass(Foo.class)
    .suppress(Warning.ALL_NONFINAL_FIELDS_SHOULD_BE_USED)
    .verify();

Disable it all

If you don’t care whether all fields are used in equals or not, you can also disable the checks altogether:

EqualsVerifier.forClass(Foo.class)
    .suppress(Warning.ALL_FIELDS_SHOULD_BE_USED)
    .verify();

Updated: