Class Assertions
- java.lang.Object
-
- org.assertj.core.api.Assertions
-
- Direct Known Subclasses:
BDDAssertions
public class Assertions extends Object
Entry point for assertion methods for different types. Each method in this class is a static factory for a type-specific assertion object.For example:
This class only contains allint removed = employees.removeFired();assertThat(removed).isZero(); List<Employee> newEmployees = employees.hired(TODAY);assertThat(newEmployees).hasSize(6);assertThatmethods, if you have ambiguous method compilation error, use eitherAssertionsForClassTypesorAssertionsForInterfaceTypesand if you need both, fully qualify you assertThat method. Java 8 is picky when choosing the rightassertThatmethod if the object under test is generic and bounded, for example if foo is instance of T that extends Exception, java 8 will complain that it can't resolve the properassertThatmethod (normallyassertThat(Throwable)as foo might implement an interface like List, if that occurredassertThat(List)would also be a possible choice - thus confusing java 8.This why
Assertionshave been split inAssertionsForClassTypesandAssertionsForInterfaceTypes(see http://stackoverflow.com/questions/29499847/ambiguous-method-in-java-8-why).- Author:
- Alex Ruiz, Yvonne Wang, David DIDIER, Ted Young, Joel Costigliola, Matthieu Baechler, Mikhail Mazursky, Nicolas François, Julien Meddah, William Delanoue
-
-
Constructor Summary
Constructors Modifier Constructor Description protectedAssertions()Creates a newAssertions.
-
Method Summary
All Methods Static Methods Concrete Methods Modifier and Type Method Description static <T> Condition<T>allOf(Iterable<? extends Condition<? super T>> conditions)Creates a newAllOfstatic <T> Condition<T>allOf(Condition<? super T>... conditions)Creates a newAllOfstatic <T> Condition<T>anyOf(Iterable<? extends Condition<? super T>> conditions)Creates a newAnyOfstatic <T> Condition<T>anyOf(Condition<? super T>... conditions)Only delegate toAnyOf.anyOf(Condition...)so that Assertions offers a full feature entry point to all AssertJ features (but you can useAnyOfif you prefer).static AbstractBooleanAssert<?>assertThat(boolean actual)Creates a new instance of.BooleanAssertstatic AbstractBooleanArrayAssert<?>assertThat(boolean[] actual)Creates a new instance of.BooleanArrayAssertstatic AbstractByteAssert<?>assertThat(byte actual)Creates a new instance of.ByteAssertstatic AbstractByteArrayAssert<?>assertThat(byte[] actual)Creates a new instance of.ByteArrayAssertstatic AbstractCharacterAssert<?>assertThat(char actual)Creates a new instance of.CharacterAssertstatic AbstractCharArrayAssert<?>assertThat(char[] actual)Creates a new instance of.CharArrayAssertstatic AbstractDoubleAssert<?>assertThat(double actual)Creates a new instance of.DoubleAssertstatic AbstractDoubleArrayAssert<?>assertThat(double[] actual)Creates a new instance of.DoubleArrayAssertstatic AbstractFloatAssert<?>assertThat(float actual)Creates a new instance of.FloatAssertstatic AbstractFloatArrayAssert<?>assertThat(float[] actual)Creates a new instance of.FloatArrayAssertstatic AbstractIntegerAssert<?>assertThat(int actual)Creates a new instance of.IntegerAssertstatic AbstractIntArrayAssert<?>assertThat(int[] actual)Creates a new instance of.IntArrayAssertstatic AbstractLongAssert<?>assertThat(long actual)Creates a new instance of.LongAssertstatic AbstractLongArrayAssert<?>assertThat(long[] actual)Creates a new instance of.LongArrayAssertstatic AbstractShortAssert<?>assertThat(short actual)Creates a new instance of.ShortAssertstatic AbstractShortArrayAssert<?>assertThat(short[] actual)Creates a new instance of.ShortArrayAssertstatic <ACTUAL extends Iterable<? extends ELEMENT>,ELEMENT,ELEMENT_ASSERT extends AbstractAssert<ELEMENT_ASSERT,ELEMENT>>
ClassBasedNavigableIterableAssert<?,ACTUAL,ELEMENT,ELEMENT_ASSERT>assertThat(ACTUAL actual, Class<ELEMENT_ASSERT> assertClass)Creates a new instance ofallowing to navigate to anyClassBasedNavigableIterableAssertIterableelement in order to perform assertions on it.static AbstractFileAssert<?>assertThat(File actual)Creates a new instance of.FileAssertstatic AbstractInputStreamAssert<?,? extends InputStream>assertThat(InputStream actual)Creates a new instance of.InputStreamAssertstatic AbstractBooleanAssert<?>assertThat(Boolean actual)Creates a new instance of.BooleanAssertstatic AbstractByteAssert<?>assertThat(Byte actual)Creates a new instance of.ByteAssertstatic AbstractCharacterAssert<?>assertThat(Character actual)Creates a new instance of.CharacterAssertstatic AbstractCharSequenceAssert<?,? extends CharSequence>assertThat(CharSequence actual)Creates a new instance of.CharSequenceAssertstatic AbstractClassAssert<?>assertThat(Class<?> actual)Creates a new instance ofClassAssertstatic AbstractDoubleAssert<?>assertThat(Double actual)Creates a new instance of.DoubleAssertstatic AbstractFloatAssert<?>assertThat(Float actual)Creates a new instance of.FloatAssertstatic AbstractIntegerAssert<?>assertThat(Integer actual)Creates a new instance of.IntegerAssertstatic <ELEMENT> IterableAssert<ELEMENT>assertThat(Iterable<? extends ELEMENT> actual)Creates a new instance of.IterableAssertstatic <ACTUAL extends Iterable<? extends ELEMENT>,ELEMENT,ELEMENT_ASSERT extends AbstractAssert<ELEMENT_ASSERT,ELEMENT>>
FactoryBasedNavigableIterableAssert<?,ACTUAL,ELEMENT,ELEMENT_ASSERT>assertThat(Iterable<? extends ELEMENT> actual, AssertFactory<ELEMENT,ELEMENT_ASSERT> assertFactory)Creates a new instance ofallowing to navigate to anyFactoryBasedNavigableIterableAssertIterableelement in order to perform assertions on it.static AbstractLongAssert<?>assertThat(Long actual)Creates a new instance of.LongAssertstatic AbstractShortAssert<?>assertThat(Short actual)Creates a new instance of.ShortAssertstatic AbstractCharSequenceAssert<?,String>assertThat(String actual)Creates a new instance of.StringAssertstatic AbstractThrowableAssert<?,? extends Throwable>assertThat(Throwable actual)Creates a new instance of.ThrowableAssertstatic AbstractBigDecimalAssert<?>assertThat(BigDecimal actual)Creates a new instance of.BigDecimalAssertstatic AbstractBigIntegerAssert<?>assertThat(BigInteger actual)Creates a new instance of.BigIntegerAssertstatic AbstractUriAssert<?>assertThat(URI actual)Creates a new instance of.UriAssertstatic AbstractUrlAssert<?>assertThat(URL actual)Creates a new instance of.UrlAssertstatic AbstractPathAssert<?>assertThat(Path actual)Creates a new instance ofPathAssertstatic AbstractInstantAssert<?>assertThat(Instant actual)Creates a new instance of.InstantAssertstatic AbstractLocalDateAssert<?>assertThat(LocalDate actual)Creates a new instance of.LocalDateAssertstatic AbstractLocalDateTimeAssert<?>assertThat(LocalDateTime actual)Creates a new instance of.LocalDateTimeAssertstatic AbstractLocalTimeAssert<?>assertThat(LocalTime actual)Creates a new instance of.LocalTimeAssertstatic AbstractOffsetDateTimeAssert<?>assertThat(OffsetDateTime actual)Creates a new instance of.OffsetDateTimestatic AbstractOffsetTimeAssert<?>assertThat(OffsetTime actual)Create assertion forOffsetTime.static AbstractZonedDateTimeAssert<?>assertThat(ZonedDateTime actual)Creates a new instance of.ZonedDateTimeAssertstatic AtomicBooleanAssertassertThat(AtomicBoolean actual)Create assertion forAtomicBoolean.static AtomicIntegerAssertassertThat(AtomicInteger actual)Create assertion forAtomicInteger.static AtomicIntegerArrayAssertassertThat(AtomicIntegerArray actual)Create int[] assertion forAtomicIntegerArray.static <OBJECT> AtomicIntegerFieldUpdaterAssert<OBJECT>assertThat(AtomicIntegerFieldUpdater<OBJECT> actual)Create assertion forAtomicIntegerFieldUpdater.static AtomicLongAssertassertThat(AtomicLong actual)Create assertion forAtomicLong.static AtomicLongArrayAssertassertThat(AtomicLongArray actual)Create assertion forAtomicLongArray.static <OBJECT> AtomicLongFieldUpdaterAssert<OBJECT>assertThat(AtomicLongFieldUpdater<OBJECT> actual)Create assertion forAtomicLongFieldUpdater.static <VALUE> AtomicMarkableReferenceAssert<VALUE>assertThat(AtomicMarkableReference<VALUE> actual)Create assertion forAtomicMarkableReference.static <VALUE> AtomicReferenceAssert<VALUE>assertThat(AtomicReference<VALUE> actual)Create assertion forAtomicReference.static <ELEMENT> AtomicReferenceArrayAssert<ELEMENT>assertThat(AtomicReferenceArray<ELEMENT> actual)Create assertion forAtomicReferenceArray.static <FIELD,OBJECT>
AtomicReferenceFieldUpdaterAssert<FIELD,OBJECT>assertThat(AtomicReferenceFieldUpdater<OBJECT,FIELD> actual)Create assertion forAtomicReferenceFieldUpdater.static <VALUE> AtomicStampedReferenceAssert<VALUE>assertThat(AtomicStampedReference<VALUE> actual)Create assertion forAtomicStampedReference.static <RESULT> CompletableFutureAssert<RESULT>assertThat(CompletableFuture<RESULT> actual)Create assertion forCompletableFuture.static <RESULT> AbstractFutureAssert<?,? extends Future<? extends RESULT>,RESULT>assertThat(Future<RESULT> actual)Create assertion forFuture.static AbstractDateAssert<?>assertThat(Date actual)Creates a new instance of.DateAssertstatic DoublePredicateAssertassertThat(DoublePredicate actual)Create assertion forDoublePredicate.static IntPredicateAssertassertThat(IntPredicate actual)Create assertion forIntPredicate.static LongPredicateAssertassertThat(LongPredicate actual)Create assertion forLongPredicate.static <T> PredicateAssert<T>assertThat(Predicate<T> actual)Create assertion forPredicate.static <ELEMENT> IterableAssert<ELEMENT>assertThat(Iterator<? extends ELEMENT> actual)Creates a new instance of.IterableAssertstatic <ELEMENT> ListAssert<ELEMENT>assertThat(List<? extends ELEMENT> actual)Creates a new instance of.ListAssertstatic <ELEMENT,ACTUAL extends List<? extends ELEMENT>,ELEMENT_ASSERT extends AbstractAssert<ELEMENT_ASSERT,ELEMENT>>
ClassBasedNavigableListAssert<?,ACTUAL,ELEMENT,ELEMENT_ASSERT>assertThat(List<? extends ELEMENT> actual, Class<ELEMENT_ASSERT> assertClass)Creates a new instance oftallowing to navigate to anyClassBasedNavigableListAssertListelement in order to perform assertions on it.static <ACTUAL extends List<? extends ELEMENT>,ELEMENT,ELEMENT_ASSERT extends AbstractAssert<ELEMENT_ASSERT,ELEMENT>>
FactoryBasedNavigableListAssert<?,ACTUAL,ELEMENT,ELEMENT_ASSERT>assertThat(List<? extends ELEMENT> actual, AssertFactory<ELEMENT,ELEMENT_ASSERT> assertFactory)Creates a new instance ofallowing to navigate to anyFactoryBasedNavigableListAssertListelement in order to perform assertions on it.static <K,V>
MapAssert<K,V>assertThat(Map<K,V> actual)Creates a new instance of.MapAssertstatic <VALUE> OptionalAssert<VALUE>assertThat(Optional<VALUE> actual)Create assertion forOptional.static OptionalDoubleAssertassertThat(OptionalDouble actual)Create assertion forOptionalDouble.static OptionalIntAssertassertThat(OptionalInt actual)Create assertion forOptionalInt.static OptionalLongAssertassertThat(OptionalLong actual)Create assertion forOptionalInt.static <ELEMENT,STREAM extends BaseStream<ELEMENT,STREAM>>
AbstractListAssert<?,List<? extends ELEMENT>,ELEMENT,ObjectAssert<ELEMENT>>assertThat(BaseStream<? extends ELEMENT,STREAM> actual)Creates a new instance offrom the givenListAssertBaseStream.static <T> TassertThat(AssertProvider<T> component)Delegates the creation of theAssertto theAssertProvider.assertThat()of the given component.static <T> AbstractObjectAssert<?,T>assertThat(T actual)Creates a new instance of.ObjectAssertstatic <T> AbstractObjectArrayAssert<?,T>assertThat(T[] actual)Creates a new instance of.ObjectArrayAssertstatic AbstractThrowableAssert<?,? extends Throwable>assertThatCode(ThrowableAssert.ThrowingCallable shouldRaiseOrNotThrowable)Allows to capture and then assert on aThrowablemore easily when used with Java 8 lambdas.static <T extends Throwable>
ThrowableTypeAssert<T>assertThatExceptionOfType(Class<? extends T> exceptionType)Entry point to check that an exception of type T is thrown by a giventhrowingCallablewhich allows to chain assertions on the thrown exception.static ThrowableTypeAssert<IllegalArgumentException>assertThatIllegalArgumentException()Alias forassertThatExceptionOfType(Class)forIllegalArgumentException.static ThrowableTypeAssert<IllegalStateException>assertThatIllegalStateException()Alias forassertThatExceptionOfType(Class)forIllegalStateException.static ThrowableTypeAssert<IOException>assertThatIOException()Alias forassertThatExceptionOfType(Class)forIOException.static ThrowableTypeAssert<NullPointerException>assertThatNullPointerException()Alias forassertThatExceptionOfType(Class)forNullPointerException.static AbstractThrowableAssert<?,? extends Throwable>assertThatThrownBy(ThrowableAssert.ThrowingCallable shouldRaiseThrowable)Allows to capture and then assert on aThrowablemore easily when used with Java 8 lambdas.static IndexatIndex(int index)Only delegate toIndex.atIndex(int)so that Assertions offers a full feature entry point to all AssertJ features (but you can useIndexif you prefer).static TemporalUnitOffsetbyLessThan(long value, TemporalUnit unit)Assertions entry point forTemporalUnitOffsetwith strict less than condition to use withisCloseTotemporal assertions.static Offset<Byte>byLessThan(Byte value)Assertions entry point for ByteOffsetto use with isCloseTo assertions.static Offset<Double>byLessThan(Double value)Alias foroffset(Double)to use with isCloseTo assertions.static Offset<Float>byLessThan(Float value)Alias foroffset(Float)to use with isCloseTo assertions.static Offset<Integer>byLessThan(Integer value)Assertions entry point for IntegerOffsetto use with isCloseTo assertions.static Offset<Long>byLessThan(Long value)Assertions entry point for LongOffsetto use with isCloseTo assertions.static Offset<Short>byLessThan(Short value)Assertions entry point for ShortOffsetto use with isCloseTo assertions.static Offset<BigDecimal>byLessThan(BigDecimal value)Assertions entry point for BigDecimalOffsetto use with isCloseTo assertions.static Offset<BigInteger>byLessThan(BigInteger value)Assertions entry point for BigIntegerOffsetto use with isCloseTo assertions.static ThrowablecatchThrowable(ThrowableAssert.ThrowingCallable shouldRaiseThrowable)Allows to catch anThrowablemore easily when used with Java 8 lambdas.static StringcontentOf(File file)Loads the text content of a file with the default character set, so that it can be passed toassertThat(String).static StringcontentOf(File file, String charsetName)Loads the text content of a file, so that it can be passed toassertThat(String).static StringcontentOf(File file, Charset charset)Loads the text content of a file, so that it can be passed toassertThat(String).static StringcontentOf(URL url)Loads the text content of a URL with the default character set, so that it can be passed toassertThat(String).static StringcontentOf(URL url, String charsetName)Loads the text content of a URL, so that it can be passed toassertThat(String).static StringcontentOf(URL url, Charset charset)Loads the text content of a URL, so that it can be passed toassertThat(String).static <T> DoesNotHave<T>doesNotHave(Condition<? super T> condition)Creates a newDoesNotHave.static <K,V>
MapEntry<K,V>entry(K key, V value)Only delegate toMapEntry.entry(Object, Object)so that Assertions offers a full feature entry point to all AssertJ features (but you can useMapEntryif you prefer).static Properties<Object>extractProperty(String propertyName)Only delegate toProperties.extractProperty(String)so that Assertions offers a full feature entry point to all AssertJ features (but you can usePropertiesif you prefer).static <T> Properties<T>extractProperty(String propertyName, Class<T> propertyType)Only delegate toProperties.extractProperty(String)so that Assertions offers a full feature entry point to all AssertJ features (but you can usePropertiesif you prefer).static voidfail(String failureMessage)Throws anAssertionErrorwith the given message.static voidfail(String failureMessage, Object... args)Throws anAssertionErrorwith the given message built asString.format(String, Object...).static voidfail(String failureMessage, Throwable realCause)Throws anAssertionErrorwith the given message and with theThrowablethat caused the failure.static voidfailBecauseExceptionWasNotThrown(Class<? extends Throwable> throwableClass)Throws anAssertionErrorwith a message explaining that aThrowableof given class was expected to be thrown but had not been.static <E> Filters<E>filter(E[] array)Only delegate toFilters.filter(Object[])so that Assertions offers a full feature entry point to all AssertJ features (but you can useFiltersif you prefer).static <E> Filters<E>filter(Iterable<E> iterableToFilter)Only delegate toFilters.filter(Object[])so that Assertions offers a full feature entry point to all AssertJ features (but you can useFiltersif you prefer).static <F,T>
Function<F,T>from(Function<F,T> extractor)A syntax sugar to write fluent assertion usingAbstractObjectAssert.returns(Object, Function).static InFilterin(Object... values)Create aFilterOperatorto use infilteredOn(String, FilterOperation)to express a filter keeping all Iterable elements whose property/field value matches one of the given values.static List<String>linesOf(File file)Loads the text content of a file into a list of strings with the default charset, each string corresponding to a line.static List<String>linesOf(File file, String charsetName)Loads the text content of a file into a list of strings, each string corresponding to a line.static List<String>linesOf(File file, Charset charset)Loads the text content of a file into a list of strings, each string corresponding to a line.static List<String>linesOf(URL url)Loads the text content of a URL into a list of strings with the default charset, each string corresponding to a line.static List<String>linesOf(URL url, String charsetName)Loads the text content of a URL into a list of strings, each string corresponding to a line.static List<String>linesOf(URL url, Charset charset)Loads the text content of a URL into a list of strings, each string corresponding to a line.static NotFilternot(Object valueNotToMatch)Create aFilterOperatorto use infilteredOn(String, FilterOperation)to express a filter keeping all Iterable elements whose property/field value matches does not match the given value.static <T> Not<T>not(Condition<? super T> condition)Creates a newNot.static NotInFilternotIn(Object... valuesNotToMatch)Create aFilterOperatorto use infilteredOn(String, FilterOperation)to express a filter keeping all Iterable elements whose property/field value matches does not match any of the given values.static Offset<Double>offset(Double value)Assertions entry point for doubleOffset.static Offset<Float>offset(Float value)Assertions entry point for floatOffset.static voidregisterCustomDateFormat(String userCustomDateFormatPattern)Add the given date format to the ones used to parse date String in String based Date assertions likeAbstractDateAssert.isEqualTo(String).static voidregisterCustomDateFormat(DateFormat userCustomDateFormat)Add the given date format to the ones used to parse date String in String based Date assertions likeAbstractDateAssert.isEqualTo(String).static <T> voidregisterFormatterForType(Class<T> type, Function<T,String> formatter)Assertions error messages uses aRepresentationto format the different types involved, using this method you can control the formatting of a given type by providing a specific formatter.static voidsetAllowComparingPrivateFields(boolean allowComparingPrivateFields)Globally sets whether the use of private fields is allowed for comparison.static voidsetAllowExtractingPrivateFields(boolean allowExtractingPrivateFields)Globally sets whetherandIterableAssert#extracting(String)should be allowed to extract private fields, if not and they try it fails with exception.ObjectArrayAssert#extracting(String)static voidsetLenientDateParsing(boolean value)Instead of using default strict date/time parsing, it is possible to use lenient parsing mode for default date formats parser to interpret inputs that do not precisely match supported date formats (lenient parsing).static voidsetMaxElementsForPrinting(int maxElementsForPrinting)In error messages, sets the threshold for how many elements from one iterable/array/map will be included in the in the description.static voidsetMaxLengthForSingleLineDescription(int maxLengthForSingleLineDescription)In error messages, sets the threshold when iterable/array formatting will on one line (if their String description is less than this parameter) or it will be formatted with one element per line.static voidsetRemoveAssertJRelatedElementsFromStackTrace(boolean removeAssertJRelatedElementsFromStackTrace)Sets whether we remove elements related to AssertJ from assertion error stack trace.static voidshouldHaveThrown(Class<? extends Throwable> throwableClass)Throws anAssertionErrorwith a message explaining that aThrowableof given class was expected to be thrown but had not been.static Tupletuple(Object... values)Utility method to build nicely aTuplewhen working withAbstractIterableAssert.extracting(String...)orAbstractObjectArrayAssert.extracting(String...)static voiduseDefaultDateFormatsOnly()Remove all registered custom date formats => use only the defaults date formats to parse string as date.static voiduseDefaultRepresentation()Fallback to useStandardRepresentationto revert the effect of callinguseRepresentation(Representation).static voiduseRepresentation(Representation customRepresentation)Register aRepresentationthat will be used in all following assertions.static TemporalUnitOffsetwithin(long value, TemporalUnit unit)Assertions entry point forTemporalUnitOffsetwith with less than or equal condition to use with isCloseTo temporal assertions.static Offset<Byte>within(Byte value)Assertions entry point for ByteOffsetto use with isCloseTo assertions.static Offset<Double>within(Double value)Alias foroffset(Double)to use with isCloseTo assertions.static Offset<Float>within(Float value)Alias foroffset(Float)to use with isCloseTo assertions.static Offset<Integer>within(Integer value)Assertions entry point for IntegerOffsetto use with isCloseTo assertions.static Offset<Long>within(Long value)Assertions entry point for LongOffsetto use with isCloseTo assertions.static Offset<Short>within(Short value)Assertions entry point for ShortOffsetto use with isCloseTo assertions.static Offset<BigDecimal>within(BigDecimal value)Assertions entry point for BigDecimalOffsetto use with isCloseTo assertions.static Offset<BigInteger>within(BigInteger value)Assertions entry point for BigIntegerOffsetto use with isCloseTo assertions.static PercentagewithinPercentage(Double value)Assertions entry point for DoublePercentageto use with isCloseTo assertions for percentages.static PercentagewithinPercentage(Integer value)Assertions entry point for IntegerPercentageto use with isCloseTo assertions for percentages.static PercentagewithinPercentage(Long value)Assertions entry point for LongPercentageto use with isCloseTo assertions for percentages.static Offset<Double>withPrecision(Double value)Alias foroffset(Double)to use with real number assertions.static Offset<Float>withPrecision(Float value)Alias foroffset(Float)to use with real number assertions.
-
-
-
Constructor Detail
-
Assertions
protected Assertions()
Creates a newAssertions.
-
-
Method Detail
-
assertThat
public static <T> PredicateAssert<T> assertThat(Predicate<T> actual)
Create assertion forPredicate.- Type Parameters:
T- the type of the value contained in thePredicate.- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
- Since:
- 3.5.0
-
assertThat
public static IntPredicateAssert assertThat(IntPredicate actual)
Create assertion forIntPredicate.- Returns:
- the created assertion object.
- Since:
- 3.5.0
-
assertThat
public static LongPredicateAssert assertThat(LongPredicate actual)
Create assertion forLongPredicate.- Returns:
- the created assertion object.
- Since:
- 3.5.0
-
assertThat
public static DoublePredicateAssert assertThat(DoublePredicate actual)
Create assertion forDoublePredicate.- Returns:
- the created assertion object.
- Since:
- 3.5.0
-
assertThat
public static <RESULT> CompletableFutureAssert<RESULT> assertThat(CompletableFuture<RESULT> actual)
Create assertion forCompletableFuture.- Type Parameters:
RESULT- the type of the value contained in theCompletableFuture.- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static <VALUE> OptionalAssert<VALUE> assertThat(Optional<VALUE> actual)
Create assertion forOptional.- Type Parameters:
VALUE- the type of the value contained in theOptional.- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static OptionalDoubleAssert assertThat(OptionalDouble actual)
Create assertion forOptionalDouble.- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static OptionalIntAssert assertThat(OptionalInt actual)
Create assertion forOptionalInt.- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static OptionalLongAssert assertThat(OptionalLong actual)
Create assertion forOptionalInt.- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractBigDecimalAssert<?> assertThat(BigDecimal actual)
Creates a new instance of.BigDecimalAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractBigIntegerAssert<?> assertThat(BigInteger actual)
Creates a new instance of.BigIntegerAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
- Since:
- 2.7.0 / 3.7.0
-
assertThat
public static AbstractUriAssert<?> assertThat(URI actual)
Creates a new instance of.UriAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractUrlAssert<?> assertThat(URL actual)
Creates a new instance of.UrlAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractBooleanAssert<?> assertThat(boolean actual)
Creates a new instance of.BooleanAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractBooleanAssert<?> assertThat(Boolean actual)
Creates a new instance of.BooleanAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractBooleanArrayAssert<?> assertThat(boolean[] actual)
Creates a new instance of.BooleanArrayAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractByteAssert<?> assertThat(byte actual)
Creates a new instance of.ByteAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractByteAssert<?> assertThat(Byte actual)
Creates a new instance of.ByteAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractByteArrayAssert<?> assertThat(byte[] actual)
Creates a new instance of.ByteArrayAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractCharacterAssert<?> assertThat(char actual)
Creates a new instance of.CharacterAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractCharArrayAssert<?> assertThat(char[] actual)
Creates a new instance of.CharArrayAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractCharacterAssert<?> assertThat(Character actual)
Creates a new instance of.CharacterAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractClassAssert<?> assertThat(Class<?> actual)
Creates a new instance ofClassAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractDoubleAssert<?> assertThat(double actual)
Creates a new instance of.DoubleAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractDoubleAssert<?> assertThat(Double actual)
Creates a new instance of.DoubleAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractDoubleArrayAssert<?> assertThat(double[] actual)
Creates a new instance of.DoubleArrayAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractFileAssert<?> assertThat(File actual)
Creates a new instance of.FileAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static <RESULT> AbstractFutureAssert<?,? extends Future<? extends RESULT>,RESULT> assertThat(Future<RESULT> actual)
Create assertion forFuture.- Type Parameters:
RESULT- the type of the value contained in theFuture.- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
- Since:
- 2.7.0 / 3.7.0
-
assertThat
public static AbstractInputStreamAssert<?,? extends InputStream> assertThat(InputStream actual)
Creates a new instance of.InputStreamAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractFloatAssert<?> assertThat(float actual)
Creates a new instance of.FloatAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractFloatAssert<?> assertThat(Float actual)
Creates a new instance of.FloatAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractFloatArrayAssert<?> assertThat(float[] actual)
Creates a new instance of.FloatArrayAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractIntegerAssert<?> assertThat(int actual)
Creates a new instance of.IntegerAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractIntArrayAssert<?> assertThat(int[] actual)
Creates a new instance of.IntArrayAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractIntegerAssert<?> assertThat(Integer actual)
Creates a new instance of.IntegerAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static <ACTUAL extends Iterable<? extends ELEMENT>,ELEMENT,ELEMENT_ASSERT extends AbstractAssert<ELEMENT_ASSERT,ELEMENT>> FactoryBasedNavigableIterableAssert<?,ACTUAL,ELEMENT,ELEMENT_ASSERT> assertThat(Iterable<? extends ELEMENT> actual, AssertFactory<ELEMENT,ELEMENT_ASSERT> assertFactory)
Creates a new instance ofallowing to navigate to anyFactoryBasedNavigableIterableAssertIterableelement in order to perform assertions on it.Navigational methods provided:
The available assertions after navigating to an element depend on the
ELEMENT_ASSERTparameter of the givenAssertFactory<ELEMENT, ELEMENT_ASSERT>(AssertJ can't figure it out because of Java type erasure).Example with
Stringelement assertions:Iterable<String> hobbits = newHashSet("frodo", "sam", "pippin"); // build an AssertFactory for StringAssert (much nicer with Java 8 lambdas) AssertFactory<String, StringAssert> stringAssertFactory = new AssertFactory<String, StringAssert>() { @Override public StringAssert createAssert(String string) { return new StringAssert(string); } }; // assertion succeeds with String assertions chained after first() assertThat(hobbits, stringAssertFactory).first() .startsWith("fro") .endsWith("do");- Parameters:
actual- the actual value.assertFactory- the factory used to create the elements assert instance.- Returns:
- the created assertion object.
- Since:
- 2.5.0 / 3.5.0
-
assertThat
public static <ACTUAL extends Iterable<? extends ELEMENT>,ELEMENT,ELEMENT_ASSERT extends AbstractAssert<ELEMENT_ASSERT,ELEMENT>> ClassBasedNavigableIterableAssert<?,ACTUAL,ELEMENT,ELEMENT_ASSERT> assertThat(ACTUAL actual, Class<ELEMENT_ASSERT> assertClass)
Creates a new instance ofallowing to navigate to anyClassBasedNavigableIterableAssertIterableelement in order to perform assertions on it.Navigational methods provided:
The available assertions after navigating to an element depend on the given
assertClass(AssertJ can't find the element assert type by itself because of Java type erasure).Example with
Stringelement assertions:Iterable<String> hobbits = newHashSet("frodo", "sam", "pippin"); // assertion succeeds with String assertions chained after first() assertThat(hobbits, StringAssert.class).first() .startsWith("fro") .endsWith("do");- Parameters:
actual- the actual value.assertClass- the class used to create the elements assert instance.- Returns:
- the created assertion object.
- Since:
- 2.5.0 / 3.5.0
-
assertThat
public static <ACTUAL extends List<? extends ELEMENT>,ELEMENT,ELEMENT_ASSERT extends AbstractAssert<ELEMENT_ASSERT,ELEMENT>> FactoryBasedNavigableListAssert<?,ACTUAL,ELEMENT,ELEMENT_ASSERT> assertThat(List<? extends ELEMENT> actual, AssertFactory<ELEMENT,ELEMENT_ASSERT> assertFactory)
Creates a new instance ofallowing to navigate to anyFactoryBasedNavigableListAssertListelement in order to perform assertions on it.Navigational methods provided:
The available assertions after navigating to an element depend on the
ELEMENT_ASSERTparameter of the givenAssertFactory<ELEMENT, ELEMENT_ASSERT>(AssertJ can't figure it out because of Java type erasure).Example with
Stringelement assertions:List<String> hobbits = newArrayList("frodo", "sam", "pippin"); // build an AssertFactory for StringAssert (much nicer with Java 8 lambdas) AssertFactory<String, StringAssert> stringAssertFactory = new AssertFactory<String, StringAssert>() { @Override public StringAssert createAssert(String string) { return new StringAssert(string); } }; // assertion succeeds with String assertions chained after first() assertThat(hobbits, stringAssertFactory).first() .startsWith("fro") .endsWith("do");- Parameters:
actual- the actual value.assertFactory- the factory used to create the elements assert instance.- Returns:
- the created assertion object.
- Since:
- 2.5.0 / 3.5.0
-
assertThat
public static <ELEMENT,ACTUAL extends List<? extends ELEMENT>,ELEMENT_ASSERT extends AbstractAssert<ELEMENT_ASSERT,ELEMENT>> ClassBasedNavigableListAssert<?,ACTUAL,ELEMENT,ELEMENT_ASSERT> assertThat(List<? extends ELEMENT> actual, Class<ELEMENT_ASSERT> assertClass)
Creates a new instance oftallowing to navigate to anyClassBasedNavigableListAssertListelement in order to perform assertions on it.Navigational methods provided:
The available assertions after navigating to an element depend on the given
assertClass(AssertJ can't find the element assert type by itself because of Java type erasure).Example with
Stringelement assertions:List<String> hobbits = newArrayList("frodo", "sam", "pippin"); // assertion succeeds with String assertions chained after first() assertThat(hobbits, StringAssert.class).first() .startsWith("fro") .endsWith("do");- Parameters:
actual- the actual value.assertClass- the class used to create the elements assert instance.- Returns:
- the created assertion object.
- Since:
- 2.5.0 / 3.5.0
-
assertThat
public static AbstractLongAssert<?> assertThat(long actual)
Creates a new instance of.LongAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractLongAssert<?> assertThat(Long actual)
Creates a new instance of.LongAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractLongArrayAssert<?> assertThat(long[] actual)
Creates a new instance of.LongArrayAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static <T> AbstractObjectAssert<?,T> assertThat(T actual)
Creates a new instance of.ObjectAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static <T> AbstractObjectArrayAssert<?,T> assertThat(T[] actual)
Creates a new instance of.ObjectArrayAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractShortAssert<?> assertThat(short actual)
Creates a new instance of.ShortAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractShortAssert<?> assertThat(Short actual)
Creates a new instance of.ShortAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractShortArrayAssert<?> assertThat(short[] actual)
Creates a new instance of.ShortArrayAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractCharSequenceAssert<?,String> assertThat(String actual)
Creates a new instance of.StringAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractDateAssert<?> assertThat(Date actual)
Creates a new instance of.DateAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractZonedDateTimeAssert<?> assertThat(ZonedDateTime actual)
Creates a new instance of.ZonedDateTimeAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractLocalDateTimeAssert<?> assertThat(LocalDateTime actual)
Creates a new instance of.LocalDateTimeAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractOffsetDateTimeAssert<?> assertThat(OffsetDateTime actual)
Creates a new instance of.OffsetDateTime- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractOffsetTimeAssert<?> assertThat(OffsetTime actual)
Create assertion forOffsetTime.- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractLocalTimeAssert<?> assertThat(LocalTime actual)
Creates a new instance of.LocalTimeAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractLocalDateAssert<?> assertThat(LocalDate actual)
Creates a new instance of.LocalDateAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static AbstractInstantAssert<?> assertThat(Instant actual)
Creates a new instance of.InstantAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
- Since:
- 3.7.0
-
assertThat
public static AtomicBooleanAssert assertThat(AtomicBoolean actual)
Create assertion forAtomicBoolean.- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
- Since:
- 2.7.0 / 3.7.0
-
assertThat
public static AtomicIntegerAssert assertThat(AtomicInteger actual)
Create assertion forAtomicInteger.- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
- Since:
- 2.7.0 / 3.7.0
-
assertThat
public static AtomicIntegerArrayAssert assertThat(AtomicIntegerArray actual)
Create int[] assertion forAtomicIntegerArray.- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
- Since:
- 2.7.0 / 3.7.0
-
assertThat
public static <OBJECT> AtomicIntegerFieldUpdaterAssert<OBJECT> assertThat(AtomicIntegerFieldUpdater<OBJECT> actual)
Create assertion forAtomicIntegerFieldUpdater.- Type Parameters:
OBJECT- the type of the object holding the updatable field.- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
- Since:
- 2.7.0 / 3.7.0
-
assertThat
public static AtomicLongAssert assertThat(AtomicLong actual)
Create assertion forAtomicLong.- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
- Since:
- 2.7.0 / 3.7.0
-
assertThat
public static AtomicLongArrayAssert assertThat(AtomicLongArray actual)
Create assertion forAtomicLongArray.- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
- Since:
- 2.7.0 / 3.7.0
-
assertThat
public static <OBJECT> AtomicLongFieldUpdaterAssert<OBJECT> assertThat(AtomicLongFieldUpdater<OBJECT> actual)
Create assertion forAtomicLongFieldUpdater.- Type Parameters:
OBJECT- the type of the object holding the updatable field.- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
- Since:
- 2.7.0 / 3.7.0
-
assertThat
public static <VALUE> AtomicReferenceAssert<VALUE> assertThat(AtomicReference<VALUE> actual)
Create assertion forAtomicReference.- Type Parameters:
VALUE- the type of the value contained in theAtomicReference.- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
- Since:
- 2.7.0 / 3.7.0
-
assertThat
public static <ELEMENT> AtomicReferenceArrayAssert<ELEMENT> assertThat(AtomicReferenceArray<ELEMENT> actual)
Create assertion forAtomicReferenceArray.- Type Parameters:
ELEMENT- the type of the value contained in theAtomicReferenceArray.- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
- Since:
- 2.7.0 / 3.7.0
-
assertThat
public static <FIELD,OBJECT> AtomicReferenceFieldUpdaterAssert<FIELD,OBJECT> assertThat(AtomicReferenceFieldUpdater<OBJECT,FIELD> actual)
Create assertion forAtomicReferenceFieldUpdater.- Type Parameters:
FIELD- the type of the field which gets updated by theAtomicReferenceFieldUpdater.OBJECT- the type of the object holding the updatable field.- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
- Since:
- 2.7.0 / 3.7.0
-
assertThat
public static <VALUE> AtomicMarkableReferenceAssert<VALUE> assertThat(AtomicMarkableReference<VALUE> actual)
Create assertion forAtomicMarkableReference.- Type Parameters:
VALUE- the type of the value contained in theAtomicMarkableReference.- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
- Since:
- 2.7.0 / 3.7.0
-
assertThat
public static <VALUE> AtomicStampedReferenceAssert<VALUE> assertThat(AtomicStampedReference<VALUE> actual)
Create assertion forAtomicStampedReference.- Type Parameters:
VALUE- the type of the value contained in theAtomicStampedReference.- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
- Since:
- 2.7.0 / 3.7.0
-
assertThat
public static AbstractThrowableAssert<?,? extends Throwable> assertThat(Throwable actual)
Creates a new instance of.ThrowableAssert- Parameters:
actual- the actual value.- Returns:
- the created
ThrowableAssert.
-
assertThatThrownBy
public static AbstractThrowableAssert<?,? extends Throwable> assertThatThrownBy(ThrowableAssert.ThrowingCallable shouldRaiseThrowable)
Allows to capture and then assert on aThrowablemore easily when used with Java 8 lambdas.Example :
If the provided@Test public void testException() { assertThatThrownBy(() -> { throw new Exception("boom!"); }).isInstanceOf(Exception.class) .hasMessageContaining("boom"); }ThrowableAssert.ThrowingCallabledoes not raise an exception, an error is immediately raised, in that case the test description provided withas(String, Object...)is not honored. To use a test description, usecatchThrowable(ThrowableAssert.ThrowingCallable)as shown below.// assertion will fail but "display me" won't appear in the error assertThatThrownBy(() -> { // do nothing }).as("display me").isInstanceOf(Exception.class); // assertion will fail AND "display me" will appear in the error Throwable thrown = catchThrowable(() -> { // do nothing }); assertThat(thrown).as("display me").isInstanceOf(Exception.class);- Parameters:
shouldRaiseThrowable- TheThrowableAssert.ThrowingCallableor lambda with the code that should raise the throwable.- Returns:
- The captured exception or
nullif none was raised by the callable.
-
assertThatCode
public static AbstractThrowableAssert<?,? extends Throwable> assertThatCode(ThrowableAssert.ThrowingCallable shouldRaiseOrNotThrowable)
Allows to capture and then assert on aThrowablemore easily when used with Java 8 lambdas.Example :
If the providedThrowingCallable callable = () -> { throw new Exception("boom!"); }; // assertion succeeds assertThatCode(callable).isInstanceOf(Exception.class) .hasMessageContaining("boom"); // assertion fails assertThatCode(callable).doesNotThrowAnyException();ThrowableAssert.ThrowingCallabledoes not validate against next assertions, an error is immediately raised, in that case the test description provided withas(String, Object...)is not honored. To use a test description, usecatchThrowable(ThrowableAssert.ThrowingCallable)as shown below.ThrowingCallable doNothing = () -> { // do nothing }; // assertion fails and "display me" appears in the assertion error assertThatCode(doNothing).as("display me") .isInstanceOf(Exception.class); // assertion will fail AND "display me" will appear in the error Throwable thrown = catchThrowable(doNothing); assertThatCode(thrown).as("display me") .isInstanceOf(Exception.class);This method was not named
assertThatbecause the java compiler reported it ambiguous when used directly with a lambda :(- Parameters:
shouldRaiseOrNotThrowable- TheThrowableAssert.ThrowingCallableor lambda with the code that should raise the throwable.- Returns:
- The captured exception or
nullif none was raised by the callable. - Since:
- 3.7.0
-
catchThrowable
public static Throwable catchThrowable(ThrowableAssert.ThrowingCallable shouldRaiseThrowable)
Allows to catch anThrowablemore easily when used with Java 8 lambdas.This caught
Throwablecan then be asserted.Example:
@Test public void testException() { // when Throwable thrown = catchThrowable(() -> { throw new Exception("boom!"); }); // then assertThat(thrown).isInstanceOf(Exception.class) .hasMessageContaining("boom"); }- Parameters:
shouldRaiseThrowable- The lambda with the code that should raise the exception.- Returns:
- The captured exception or
nullif none was raised by the callable.
-
assertThatExceptionOfType
public static <T extends Throwable> ThrowableTypeAssert<T> assertThatExceptionOfType(Class<? extends T> exceptionType)
Entry point to check that an exception of type T is thrown by a giventhrowingCallablewhich allows to chain assertions on the thrown exception.Example:
This method is more or less the same ofassertThatExceptionOfType(IOException.class) .isThrownBy(() -> { throw new IOException("boom!"); }) .withMessage("boom!");assertThatThrownBy(ThrowableAssert.ThrowingCallable)but in a more natural way.- Parameters:
exceptionType- the exception type.- Returns:
- the created
ThrowableTypeAssert.
-
assertThatNullPointerException
public static ThrowableTypeAssert<NullPointerException> assertThatNullPointerException()
Alias forassertThatExceptionOfType(Class)forNullPointerException.- Returns:
- the created
ThrowableTypeAssert. - Since:
- 3.7.0
-
assertThatIllegalArgumentException
public static ThrowableTypeAssert<IllegalArgumentException> assertThatIllegalArgumentException()
Alias forassertThatExceptionOfType(Class)forIllegalArgumentException.- Returns:
- the created
ThrowableTypeAssert. - Since:
- 3.7.0
-
assertThatIOException
public static ThrowableTypeAssert<IOException> assertThatIOException()
Alias forassertThatExceptionOfType(Class)forIOException.- Returns:
- the created
ThrowableTypeAssert. - Since:
- 3.7.0
-
assertThatIllegalStateException
public static ThrowableTypeAssert<IllegalStateException> assertThatIllegalStateException()
Alias forassertThatExceptionOfType(Class)forIllegalStateException.- Returns:
- the created
ThrowableTypeAssert. - Since:
- 3.7.0
-
setRemoveAssertJRelatedElementsFromStackTrace
public static void setRemoveAssertJRelatedElementsFromStackTrace(boolean removeAssertJRelatedElementsFromStackTrace)
Sets whether we remove elements related to AssertJ from assertion error stack trace.- Parameters:
removeAssertJRelatedElementsFromStackTrace- flag.
-
fail
public static void fail(String failureMessage)
Throws anAssertionErrorwith the given message.- Parameters:
failureMessage- error message.- Throws:
AssertionError- with the given message.
-
fail
public static void fail(String failureMessage, Object... args)
Throws anAssertionErrorwith the given message built asString.format(String, Object...).- Parameters:
failureMessage- error message.args- Arguments referenced by the format specifiers in the format string.- Throws:
AssertionError- with the given built message.
-
fail
public static void fail(String failureMessage, Throwable realCause)
Throws anAssertionErrorwith the given message and with theThrowablethat caused the failure.- Parameters:
failureMessage- the description of the failed assertion. It can benull.realCause- cause of the error.- Throws:
AssertionError- with the given message and with theThrowablethat caused the failure.
-
failBecauseExceptionWasNotThrown
public static void failBecauseExceptionWasNotThrown(Class<? extends Throwable> throwableClass)
Throws anAssertionErrorwith a message explaining that aThrowableof given class was expected to be thrown but had not been.shouldHaveThrown(Class)can be used as a replacement.- Parameters:
throwableClass- the Throwable class that was expected to be thrown.- Throws:
AssertionError- with a message explaining that aThrowableof given class was expected to be thrown but had not been.
-
shouldHaveThrown
public static void shouldHaveThrown(Class<? extends Throwable> throwableClass)
Throws anAssertionErrorwith a message explaining that aThrowableof given class was expected to be thrown but had not been.- Parameters:
throwableClass- the Throwable class that was expected to be thrown.- Throws:
AssertionError- with a message explaining that aThrowableof given class was expected to be thrown but had not been.
-
setMaxLengthForSingleLineDescription
public static void setMaxLengthForSingleLineDescription(int maxLengthForSingleLineDescription)
In error messages, sets the threshold when iterable/array formatting will on one line (if their String description is less than this parameter) or it will be formatted with one element per line.The following array will be formatted on one line as its length < 80
whereas this array is formatted on multiple lines (one element per line)String[] greatBooks = array("A Game of Thrones", "The Lord of the Rings", "Assassin's Apprentice"); // formatted as: ["A Game of Thrones", "The Lord of the Rings", "Assassin's Apprentice"]String[] greatBooks = array("A Game of Thrones", "The Lord of the Rings", "Assassin's Apprentice", "Guards! Guards! (Discworld)"); // formatted as: ["A Game of Thrones", "The Lord of the Rings", "Assassin's Apprentice", "Guards! Guards! (Discworld)"]- Parameters:
maxLengthForSingleLineDescription- the maximum length for an iterable/array to be displayed on one line
-
setMaxElementsForPrinting
public static void setMaxElementsForPrinting(int maxElementsForPrinting)
In error messages, sets the threshold for how many elements from one iterable/array/map will be included in the in the description. E.q. When this method is called with a value of3.The following array will be formatted entirely as it's length is <= 3:
whereas this array is formatted only with it's first 3 elements, followed byString[] greatBooks = array("A Game of Thrones", "The Lord of the Rings", "Assassin's Apprentice"); // formatted as: ["A Game of Thrones", "The Lord of the Rings", "Assassin's Apprentice"]...:String[] greatBooks = array("A Game of Thrones", "The Lord of the Rings", "Assassin's Apprentice", "Guards! Guards!"); // formatted as: ["A Game of Thrones", "The Lord of the Rings", "Assassin's Apprentice", ...]- Parameters:
maxElementsForPrinting- the maximum elements that would be printed from one iterable/array/map- Since:
- 2.6.0 / 3.6.0
-
extractProperty
public static <T> Properties<T> extractProperty(String propertyName, Class<T> propertyType)
Only delegate toProperties.extractProperty(String)so that Assertions offers a full feature entry point to all AssertJ features (but you can usePropertiesif you prefer).Typical usage is to chain
extractPropertywithfrommethod, see examples below :// extract simple property values having a java standard type (here String) assertThat(extractProperty("name", String.class).from(fellowshipOfTheRing)) .contains("Boromir", "Gandalf", "Frodo", "Legolas") .doesNotContain("Sauron", "Elrond"); // extracting property works also with user's types (here Race) assertThat(extractProperty("race", String.class).from(fellowshipOfTheRing)) .contains(HOBBIT, ELF).doesNotContain(ORC); // extract nested property on Race assertThat(extractProperty("race.name", String.class).from(fellowshipOfTheRing)) .contains("Hobbit", "Elf") .doesNotContain("Orc");
-
extractProperty
public static Properties<Object> extractProperty(String propertyName)
Only delegate toProperties.extractProperty(String)so that Assertions offers a full feature entry point to all AssertJ features (but you can usePropertiesif you prefer).Typical usage is to chain
extractPropertywithfrommethod, see examples below :// extract simple property values, as no type has been defined the extracted property will be considered as Object // to define the real property type (here String) use extractProperty("name", String.class) instead. assertThat(extractProperty("name").from(fellowshipOfTheRing)) .contains("Boromir", "Gandalf", "Frodo", "Legolas") .doesNotContain("Sauron", "Elrond"); // extracting property works also with user's types (here Race), even though it will be considered as Object // to define the real property type (here String) use extractProperty("name", Race.class) instead. assertThat(extractProperty("race").from(fellowshipOfTheRing)).contains(HOBBIT, ELF).doesNotContain(ORC); // extract nested property on Race assertThat(extractProperty("race.name").from(fellowshipOfTheRing)).contains("Hobbit", "Elf").doesNotContain("Orc");
-
tuple
public static Tuple tuple(Object... values)
Utility method to build nicely aTuplewhen working withAbstractIterableAssert.extracting(String...)orAbstractObjectArrayAssert.extracting(String...)
-
setAllowExtractingPrivateFields
public static void setAllowExtractingPrivateFields(boolean allowExtractingPrivateFields)
Globally sets whetherandIterableAssert#extracting(String)should be allowed to extract private fields, if not and they try it fails with exception.ObjectArrayAssert#extracting(String)- Parameters:
allowExtractingPrivateFields- allow private fields extraction. Defaulttrue.
-
setAllowComparingPrivateFields
public static void setAllowComparingPrivateFields(boolean allowComparingPrivateFields)
Globally sets whether the use of private fields is allowed for comparison. The following (incomplete) list of methods will be impacted by this change :-
AbstractIterableAssert.usingElementComparatorOnFields(java.lang.String...) AbstractObjectAssert.isEqualToComparingFieldByField(Object)
falseand these methods try to compare private fields, it will fail with an exception.- Parameters:
allowComparingPrivateFields- allow private fields comparison. Defaulttrue.
-
-
entry
public static <K,V> MapEntry<K,V> entry(K key, V value)
Only delegate toMapEntry.entry(Object, Object)so that Assertions offers a full feature entry point to all AssertJ features (but you can useMapEntryif you prefer).Typical usage is to call
entryin MapAssertcontainsassertion, see examples below :MapringBearers = ... // init omitted assertThat(ringBearers).contains(entry(oneRing, frodo), entry(nenya, galadriel));
-
atIndex
public static Index atIndex(int index)
Only delegate toIndex.atIndex(int)so that Assertions offers a full feature entry point to all AssertJ features (but you can useIndexif you prefer).Typical usage :
List<Ring> elvesRings = newArrayList(vilya, nenya, narya); assertThat(elvesRings).contains(vilya, atIndex(0)).contains(nenya, atIndex(1)).contains(narya, atIndex(2));
-
offset
public static Offset<Double> offset(Double value)
Assertions entry point for doubleOffset.Typical usage :
assertThat(8.1).isEqualTo(8.0, offset(0.1));
-
offset
public static Offset<Float> offset(Float value)
Assertions entry point for floatOffset.Typical usage :
assertThat(8.2f).isCloseTo(8.0f, offset(0.2f));
-
within
public static Offset<Double> within(Double value)
Alias foroffset(Double)to use with isCloseTo assertions.Typical usage :
assertThat(8.1).isCloseTo(8.0, within(0.1));
-
withPrecision
public static Offset<Double> withPrecision(Double value)
Alias foroffset(Double)to use with real number assertions.Typical usage :
assertThat(8.1).isEqualTo(8.0, withPrecision(0.1));
-
within
public static Offset<Float> within(Float value)
Alias foroffset(Float)to use with isCloseTo assertions.Typical usage :
assertThat(8.2f).isCloseTo(8.0f, within(0.2f));
-
withPrecision
public static Offset<Float> withPrecision(Float value)
Alias foroffset(Float)to use with real number assertions.Typical usage :
assertThat(8.2f).isEqualTo(8.0f, withPrecision(0.2f));
-
within
public static Offset<BigDecimal> within(BigDecimal value)
Assertions entry point for BigDecimalOffsetto use with isCloseTo assertions.Typical usage :
assertThat(BigDecimal.TEN).isCloseTo(new BigDecimal("10.5"), within(BigDecimal.ONE));
-
within
public static Offset<BigInteger> within(BigInteger value)
Assertions entry point for BigIntegerOffsetto use with isCloseTo assertions.Typical usage :
assertThat(BigInteger.TEN).isCloseTo(new BigInteger("11"), within(new BigInteger("2")));- Since:
- 2.7.0 / 3.7.0
-
within
public static Offset<Byte> within(Byte value)
Assertions entry point for ByteOffsetto use with isCloseTo assertions.Typical usage :
assertThat((byte)10).isCloseTo((byte)11, within((byte)1));
-
within
public static Offset<Integer> within(Integer value)
Assertions entry point for IntegerOffsetto use with isCloseTo assertions.Typical usage :
assertThat(10).isCloseTo(11, within(1));
-
within
public static Offset<Short> within(Short value)
Assertions entry point for ShortOffsetto use with isCloseTo assertions.Typical usage :
assertThat(10).isCloseTo(11, within(1));
-
within
public static Offset<Long> within(Long value)
Assertions entry point for LongOffsetto use with isCloseTo assertions.Typical usage :
assertThat(5l).isCloseTo(7l, within(2l));
-
within
public static TemporalUnitOffset within(long value, TemporalUnit unit)
Assertions entry point forTemporalUnitOffsetwith with less than or equal condition to use with isCloseTo temporal assertions.Typical usage :
LocalTime _07_10 = LocalTime.of(7, 10); LocalTime _07_12 = LocalTime.of(7, 12); assertThat(_07_10).isCloseTo(_07_12, within(5, ChronoUnit.MINUTES));- Since:
- 3.7.0
-
withinPercentage
public static Percentage withinPercentage(Double value)
Assertions entry point for DoublePercentageto use with isCloseTo assertions for percentages.Typical usage :
assertThat(11.0).isCloseTo(10.0, withinPercentage(10.0));
-
withinPercentage
public static Percentage withinPercentage(Integer value)
Assertions entry point for IntegerPercentageto use with isCloseTo assertions for percentages.Typical usage :
assertThat(11).isCloseTo(10, withinPercentage(10));
-
withinPercentage
public static Percentage withinPercentage(Long value)
Assertions entry point for LongPercentageto use with isCloseTo assertions for percentages.Typical usage :
assertThat(11L).isCloseTo(10L, withinPercentage(10L));
-
byLessThan
public static Offset<Double> byLessThan(Double value)
Alias foroffset(Double)to use with isCloseTo assertions.Typical usage :
assertThat(8.1).isCloseTo(8.0, byLessThan(0.1));
-
byLessThan
public static Offset<Float> byLessThan(Float value)
Alias foroffset(Float)to use with isCloseTo assertions.Typical usage :
assertThat(8.2f).isCloseTo(8.0f, byLessThan(0.2f));
-
byLessThan
public static Offset<BigDecimal> byLessThan(BigDecimal value)
Assertions entry point for BigDecimalOffsetto use with isCloseTo assertions.Typical usage :
assertThat(BigDecimal.TEN).isCloseTo(new BigDecimal("10.5"), byLessThan(BigDecimal.ONE));
-
byLessThan
public static Offset<BigInteger> byLessThan(BigInteger value)
Assertions entry point for BigIntegerOffsetto use with isCloseTo assertions.Typical usage :
assertThat(BigInteger.TEN).isCloseTo(new BigInteger("11"), byLessThan(new BigInteger("2")));- Since:
- 2.7.0 / 3.7.0
-
byLessThan
public static Offset<Byte> byLessThan(Byte value)
Assertions entry point for ByteOffsetto use with isCloseTo assertions.Typical usage :
assertThat((byte)10).isCloseTo((byte)11, byLessThan((byte)1));
-
byLessThan
public static Offset<Integer> byLessThan(Integer value)
Assertions entry point for IntegerOffsetto use with isCloseTo assertions.Typical usage :
assertThat(10).isCloseTo(11, byLessThan(1));
-
byLessThan
public static Offset<Short> byLessThan(Short value)
Assertions entry point for ShortOffsetto use with isCloseTo assertions.Typical usage :
assertThat(10).isCloseTo(11, byLessThan(1));
-
byLessThan
public static Offset<Long> byLessThan(Long value)
Assertions entry point for LongOffsetto use with isCloseTo assertions.Typical usage :
assertThat(5l).isCloseTo(7l, byLessThan(2l));
-
byLessThan
public static TemporalUnitOffset byLessThan(long value, TemporalUnit unit)
Assertions entry point forTemporalUnitOffsetwith strict less than condition to use withisCloseTotemporal assertions.Typical usage :
LocalTime _07_10 = LocalTime.of(7, 10); LocalTime _07_12 = LocalTime.of(7, 12); assertThat(_07_10).isCloseTo(_07_12, byLessThan(5, ChronoUnit.MINUTES));- Since:
- 3.7.0
-
from
public static <F,T> Function<F,T> from(Function<F,T> extractor)
A syntax sugar to write fluent assertion usingAbstractObjectAssert.returns(Object, Function).Example:
Jedi yoda = new Jedi("Yoda", "Green"); assertThat(yoda).returns("Yoda", from(Jedi::getName)) .returns(2.4, from(Jedi::getHeight)) .returns(150, from(Jedi::getWeight));- Type Parameters:
F- Type of test subjectT- Type of the property under the assertion- Parameters:
extractor- A function to extract test subject's property- Returns:
- same instance of
extractor
-
allOf
@SafeVarargs public static <T> Condition<T> allOf(Condition<? super T>... conditions)
Creates a newAllOf- Type Parameters:
T- the type of object the given condition accept.- Parameters:
conditions- the conditions to evaluate.- Returns:
- the created
AnyOf. - Throws:
NullPointerException- if the given array isnull.NullPointerException- if any of the elements in the given array isnull.
-
allOf
public static <T> Condition<T> allOf(Iterable<? extends Condition<? super T>> conditions)
Creates a newAllOf- Type Parameters:
T- the type of object the given condition accept.- Parameters:
conditions- the conditions to evaluate.- Returns:
- the created
AnyOf. - Throws:
NullPointerException- if the given iterable isnull.NullPointerException- if any of the elements in the given iterable isnull.
-
anyOf
@SafeVarargs public static <T> Condition<T> anyOf(Condition<? super T>... conditions)
Only delegate toAnyOf.anyOf(Condition...)so that Assertions offers a full feature entry point to all AssertJ features (but you can useAnyOfif you prefer).Typical usage (
jediandsithareCondition) :assertThat("Vader").is(anyOf(jedi, sith));
-
anyOf
public static <T> Condition<T> anyOf(Iterable<? extends Condition<? super T>> conditions)
Creates a newAnyOf- Type Parameters:
T- the type of object the given condition accept.- Parameters:
conditions- the conditions to evaluate.- Returns:
- the created
AnyOf. - Throws:
NullPointerException- if the given iterable isnull.NullPointerException- if any of the elements in the given iterable isnull.
-
doesNotHave
public static <T> DoesNotHave<T> doesNotHave(Condition<? super T> condition)
Creates a newDoesNotHave.- Parameters:
condition- the condition to inverse.- Returns:
- The Not condition created.
-
not
public static <T> Not<T> not(Condition<? super T> condition)
Creates a newNot.- Parameters:
condition- the condition to inverse.- Returns:
- The Not condition created.
-
filter
public static <E> Filters<E> filter(E[] array)
Only delegate toFilters.filter(Object[])so that Assertions offers a full feature entry point to all AssertJ features (but you can useFiltersif you prefer).Note that the given array is not modified, the filters are performed on an
Iterablecopy of the array.Typical usage with
Condition:assertThat(filter(players).being(potentialMVP).get()).containsOnly(james, rose);and with filter language based on java bean property :
assertThat(filter(players).with("pointsPerGame").greaterThan(20).and("assistsPerGame").greaterThan(7).get()) .containsOnly(james, rose);
-
filter
public static <E> Filters<E> filter(Iterable<E> iterableToFilter)
Only delegate toFilters.filter(Object[])so that Assertions offers a full feature entry point to all AssertJ features (but you can useFiltersif you prefer).Note that the given
Iterableis not modified, the filters are performed on a copy.Typical usage with
Condition:assertThat(filter(players).being(potentialMVP).get()).containsOnly(james, rose);and with filter language based on java bean property :
assertThat(filter(players).with("pointsPerGame").greaterThan(20).and("assistsPerGame").greaterThan(7).get()) .containsOnly(james, rose);
-
in
public static InFilter in(Object... values)
Create aFilterOperatorto use infilteredOn(String, FilterOperation)to express a filter keeping all Iterable elements whose property/field value matches one of the given values.As often, an example helps:
Employee yoda = new Employee(1L, new Name("Yoda"), 800); Employee obiwan = new Employee(2L, new Name("Obiwan"), 800); Employee luke = new Employee(3L, new Name("Luke", "Skywalker"), 26); Employee noname = new Employee(4L, null, 50); List<Employee> employees = newArrayList(yoda, luke, obiwan, noname); assertThat(employees).filteredOn("age", in(800, 26)) .containsOnly(yoda, obiwan, luke);- Parameters:
values- values to match (one match is sufficient)- Returns:
- the created "in" filter
-
notIn
public static NotInFilter notIn(Object... valuesNotToMatch)
Create aFilterOperatorto use infilteredOn(String, FilterOperation)to express a filter keeping all Iterable elements whose property/field value matches does not match any of the given values.As often, an example helps:
Employee yoda = new Employee(1L, new Name("Yoda"), 800); Employee obiwan = new Employee(2L, new Name("Obiwan"), 800); Employee luke = new Employee(3L, new Name("Luke", "Skywalker"), 26); Employee noname = new Employee(4L, null, 50); List<Employee> employees = newArrayList(yoda, luke, obiwan, noname); assertThat(employees).filteredOn("age", notIn(800, 50)) .containsOnly(luke);- Parameters:
valuesNotToMatch- values not to match (none of the values must match)- Returns:
- the created "not in" filter
-
not
public static NotFilter not(Object valueNotToMatch)
Create aFilterOperatorto use infilteredOn(String, FilterOperation)to express a filter keeping all Iterable elements whose property/field value matches does not match the given value.As often, an example helps:
Employee yoda = new Employee(1L, new Name("Yoda"), 800); Employee obiwan = new Employee(2L, new Name("Obiwan"), 800); Employee luke = new Employee(3L, new Name("Luke", "Skywalker"), 26); Employee noname = new Employee(4L, null, 50); List<Employee> employees = newArrayList(yoda, luke, obiwan, noname); assertThat(employees).filteredOn("age", not(800)) .containsOnly(luke, noname);- Parameters:
valueNotToMatch- the value not to match- Returns:
- the created "not" filter
-
contentOf
public static String contentOf(File file, Charset charset)
Loads the text content of a file, so that it can be passed toassertThat(String).Note that this will load the entire file in memory; for larger files, there might be a more efficient alternative with
assertThat(File).- Parameters:
file- the file.charset- the character set to use.- Returns:
- the content of the file.
- Throws:
NullPointerException- if the given charset isnull.RuntimeIOException- if an I/O exception occurs.
-
contentOf
public static String contentOf(File file, String charsetName)
Loads the text content of a file, so that it can be passed toassertThat(String).Note that this will load the entire file in memory; for larger files, there might be a more efficient alternative with
assertThat(File).- Parameters:
file- the file.charsetName- the name of the character set to use.- Returns:
- the content of the file.
- Throws:
IllegalArgumentException- if the given character set is not supported on this platform.RuntimeIOException- if an I/O exception occurs.
-
contentOf
public static String contentOf(File file)
Loads the text content of a file with the default character set, so that it can be passed toassertThat(String).Note that this will load the entire file in memory; for larger files, there might be a more efficient alternative with
assertThat(File).- Parameters:
file- the file.- Returns:
- the content of the file.
- Throws:
RuntimeIOException- if an I/O exception occurs.
-
linesOf
public static List<String> linesOf(File file)
Loads the text content of a file into a list of strings with the default charset, each string corresponding to a line. The line endings are either \n, \r or \r\n.- Parameters:
file- the file.- Returns:
- the content of the file.
- Throws:
NullPointerException- if the given charset isnull.RuntimeIOException- if an I/O exception occurs.
-
linesOf
public static List<String> linesOf(File file, Charset charset)
Loads the text content of a file into a list of strings, each string corresponding to a line. The line endings are either \n, \r or \r\n.- Parameters:
file- the file.charset- the character set to use.- Returns:
- the content of the file.
- Throws:
NullPointerException- if the given charset isnull.RuntimeIOException- if an I/O exception occurs.
-
linesOf
public static List<String> linesOf(File file, String charsetName)
Loads the text content of a file into a list of strings, each string corresponding to a line. The line endings are either \n, \r or \r\n.- Parameters:
file- the file.charsetName- the name of the character set to use.- Returns:
- the content of the file.
- Throws:
NullPointerException- if the given charset isnull.RuntimeIOException- if an I/O exception occurs.
-
contentOf
public static String contentOf(URL url, Charset charset)
Loads the text content of a URL, so that it can be passed toassertThat(String).Note that this will load the entire contents in memory.
- Parameters:
url- the URL.charset- the character set to use.- Returns:
- the content of the URL.
- Throws:
NullPointerException- if the given charset isnull.RuntimeIOException- if an I/O exception occurs.
-
contentOf
public static String contentOf(URL url, String charsetName)
Loads the text content of a URL, so that it can be passed toassertThat(String).Note that this will load the entire contents in memory.
- Parameters:
url- the URL.charsetName- the name of the character set to use.- Returns:
- the content of the URL.
- Throws:
IllegalArgumentException- if the given character set is not supported on this platform.RuntimeIOException- if an I/O exception occurs.
-
contentOf
public static String contentOf(URL url)
Loads the text content of a URL with the default character set, so that it can be passed toassertThat(String).Note that this will load the entire file in memory; for larger files.
- Parameters:
url- the URL.- Returns:
- the content of the file.
- Throws:
RuntimeIOException- if an I/O exception occurs.
-
linesOf
public static List<String> linesOf(URL url)
Loads the text content of a URL into a list of strings with the default charset, each string corresponding to a line. The line endings are either \n, \r or \r\n.- Parameters:
url- the URL.- Returns:
- the content of the file.
- Throws:
NullPointerException- if the given charset isnull.RuntimeIOException- if an I/O exception occurs.
-
linesOf
public static List<String> linesOf(URL url, Charset charset)
Loads the text content of a URL into a list of strings, each string corresponding to a line. The line endings are either \n, \r or \r\n.- Parameters:
url- the URL.charset- the character set to use.- Returns:
- the content of the file.
- Throws:
NullPointerException- if the given charset isnull.RuntimeIOException- if an I/O exception occurs.
-
linesOf
public static List<String> linesOf(URL url, String charsetName)
Loads the text content of a URL into a list of strings, each string corresponding to a line. The line endings are either \n, \r or \r\n.- Parameters:
url- the URL.charsetName- the name of the character set to use.- Returns:
- the content of the file.
- Throws:
NullPointerException- if the given charset isnull.RuntimeIOException- if an I/O exception occurs.
-
setLenientDateParsing
public static void setLenientDateParsing(boolean value)
Instead of using default strict date/time parsing, it is possible to use lenient parsing mode for default date formats parser to interpret inputs that do not precisely match supported date formats (lenient parsing).With strict parsing, inputs must match exactly date/time format.
Example:
To revert to default strict date parsing, callfinal Date date = Dates.parse("2001-02-03"); final Date dateTime = parseDatetime("2001-02-03T04:05:06"); final Date dateTimeWithMs = parseDatetimeWithMs("2001-02-03T04:05:06.700"); Assertions.setLenientDateParsing(true); // assertions will pass assertThat(date).isEqualTo("2001-01-34"); assertThat(date).isEqualTo("2001-02-02T24:00:00"); assertThat(date).isEqualTo("2001-02-04T-24:00:00.000"); assertThat(dateTime).isEqualTo("2001-02-03T04:05:05.1000"); assertThat(dateTime).isEqualTo("2001-02-03T04:04:66"); assertThat(dateTimeWithMs).isEqualTo("2001-02-03T04:05:07.-300"); // assertions will fail assertThat(date).hasSameTimeAs("2001-02-04"); // different date assertThat(dateTime).hasSameTimeAs("2001-02-03 04:05:06"); // leniency does not help heresetLenientDateParsing(false).- Parameters:
value- whether lenient parsing mode should be enabled or not
-
registerCustomDateFormat
public static void registerCustomDateFormat(DateFormat userCustomDateFormat)
Add the given date format to the ones used to parse date String in String based Date assertions likeAbstractDateAssert.isEqualTo(String).User date formats are used before default ones in the order they have been registered (first registered, first used).
AssertJ is gonna use any date formats registered with one of these methods :
AbstractDateAssert.withDateFormat(String)AbstractDateAssert.withDateFormat(java.text.DateFormat)registerCustomDateFormat(java.text.DateFormat)registerCustomDateFormat(String)
Beware that AssertJ will use the newly registered format for all remaining Date assertions in the test suite
To revert to default formats only, call
useDefaultDateFormatsOnly()orAbstractDateAssert.withDefaultDateFormatsOnly().Code examples:
Date date = ... // set to 2003 April the 26th assertThat(date).isEqualTo("2003-04-26"); try { // date with a custom format : failure since the default formats don't match. assertThat(date).isEqualTo("2003/04/26"); } catch (AssertionError e) { assertThat(e).hasMessage("Failed to parse 2003/04/26 with any of these date formats: " + "[yyyy-MM-dd'T'HH:mm:ss.SSS, yyyy-MM-dd'T'HH:mm:ss, yyyy-MM-dd]"); } // registering a custom date format to make the assertion pass registerCustomDateFormat(new SimpleDateFormat("yyyy/MM/dd")); // registerCustomDateFormat("yyyy/MM/dd") would work to. assertThat(date).isEqualTo("2003/04/26"); // the default formats are still available and should work assertThat(date).isEqualTo("2003-04-26");- Parameters:
userCustomDateFormat- the new Date format used for String based Date assertions.
-
registerCustomDateFormat
public static void registerCustomDateFormat(String userCustomDateFormatPattern)
Add the given date format to the ones used to parse date String in String based Date assertions likeAbstractDateAssert.isEqualTo(String).User date formats are used before default ones in the order they have been registered (first registered, first used).
AssertJ is gonna use any date formats registered with one of these methods :
AbstractDateAssert.withDateFormat(String)AbstractDateAssert.withDateFormat(java.text.DateFormat)registerCustomDateFormat(java.text.DateFormat)registerCustomDateFormat(String)
Beware that AssertJ will use the newly registered format for all remaining Date assertions in the test suite.
To revert to default formats only, call
useDefaultDateFormatsOnly()orAbstractDateAssert.withDefaultDateFormatsOnly().Code examples:
Date date = ... // set to 2003 April the 26th assertThat(date).isEqualTo("2003-04-26"); try { // date with a custom format : failure since the default formats don't match. assertThat(date).isEqualTo("2003/04/26"); } catch (AssertionError e) { assertThat(e).hasMessage("Failed to parse 2003/04/26 with any of these date formats: " + "[yyyy-MM-dd'T'HH:mm:ss.SSS, yyyy-MM-dd'T'HH:mm:ss, yyyy-MM-dd]"); } // registering a custom date format to make the assertion pass registerCustomDateFormat("yyyy/MM/dd"); assertThat(date).isEqualTo("2003/04/26"); // the default formats are still available and should work assertThat(date).isEqualTo("2003-04-26");- Parameters:
userCustomDateFormatPattern- the new Date format pattern used for String based Date assertions.
-
useDefaultDateFormatsOnly
public static void useDefaultDateFormatsOnly()
Remove all registered custom date formats => use only the defaults date formats to parse string as date.Beware that the default formats are expressed in the current local timezone.
Defaults date format are:
yyyy-MM-dd'T'HH:mm:ss.SSSyyyy-MM-dd HH:mm:ss.SSS(forTimestampString representation support)yyyy-MM-dd'T'HH:mm:ssyyyy-MM-dd
Example of valid string date representations:
2003-04-26T03:01:02.9992003-04-26 03:01:02.9992003-04-26T13:01:022003-04-26
-
assertThat
public static <T> T assertThat(AssertProvider<T> component)
Delegates the creation of theAssertto theAssertProvider.assertThat()of the given component.Read the comments on
AssertProviderfor an example of its usage.- Parameters:
component- the component that creates its own assert- Returns:
- the associated
Assertof the given component
-
assertThat
public static AbstractCharSequenceAssert<?,? extends CharSequence> assertThat(CharSequence actual)
Creates a new instance of.CharSequenceAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static <ELEMENT> IterableAssert<ELEMENT> assertThat(Iterable<? extends ELEMENT> actual)
Creates a new instance of.IterableAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static <ELEMENT> IterableAssert<ELEMENT> assertThat(Iterator<? extends ELEMENT> actual)
Creates a new instance of.IterableAssertBe aware that calls to most methods on returned IterableAssert will consume Iterator so it won't be possible to iterate over it again. Calling multiple methods on returned IterableAssert is safe as Iterator's elements are cached by IterableAssert first time Iterator is consumed.
- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static <ELEMENT> ListAssert<ELEMENT> assertThat(List<? extends ELEMENT> actual)
Creates a new instance of.ListAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static <ELEMENT,STREAM extends BaseStream<ELEMENT,STREAM>> AbstractListAssert<?,List<? extends ELEMENT>,ELEMENT,ObjectAssert<ELEMENT>> assertThat(BaseStream<? extends ELEMENT,STREAM> actual)
Creates a new instance offrom the givenListAssertBaseStream.Be aware that to create the returned
ListAssertthe given theBaseStreamis consumed so it won't be possible to use it again. Calling multiple methods on the returnedListAssertis safe as it only interacts with theListbuilt from theBaseStream.This method accepts
Streamand primitive stream variantsIntStream,LongStreamandDoubleStream.- Parameters:
actual- the actualBaseStreamvalue.- Returns:
- the created assertion object.
-
assertThat
public static AbstractPathAssert<?> assertThat(Path actual)
Creates a new instance ofPathAssert- Parameters:
actual- the path to test- Returns:
- the created assertion object
-
assertThat
public static <K,V> MapAssert<K,V> assertThat(Map<K,V> actual)
Creates a new instance of.MapAssertReturned type is
MapAssertas it overrides method to annotate them withSafeVarargsavoiding annoying warnings.- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static <T extends Comparable<? super T>> AbstractComparableAssert<?,T> assertThat(T actual)
Creates a new instance ofwith standard comparison semantics.GenericComparableAssert- Parameters:
actual- the actual value.- Returns:
- the created assertion object.
-
assertThat
public static <T extends AssertDelegateTarget> T assertThat(T assertion)
Returns the given assertion. This method improves code readability by surrounding the given assertion withassertThat.Consider for example the following MyButton and MyButtonAssert classes:
As MyButtonAssert implements AssertDelegateTarget, you can usepublic class MyButton extends JButton { private boolean blinking; public boolean isBlinking() { return this.blinking; } public void setBlinking(boolean blink) { this.blinking = blink; } } private static class MyButtonAssert implements AssertDelegateTarget { private MyButton button; MyButtonAssert(MyButton button) { this.button = button; } void isBlinking() { // standard assertion from core Assertions.assertThat assertThat(button.isBlinking()).isTrue(); } void isNotBlinking() { // standard assertion from core Assertions.assertThat assertThat(button.isBlinking()).isFalse(); } }assertThat(buttonAssert).isBlinking();instead ofbuttonAssert.isBlinking();to have easier to read assertions:@Test public void AssertDelegateTarget_example() { MyButton button = new MyButton(); MyButtonAssert buttonAssert = new MyButtonAssert(button); // you can encapsulate MyButtonAssert assertions methods within assertThat assertThat(buttonAssert).isNotBlinking(); // same as : buttonAssert.isNotBlinking(); button.setBlinking(true); assertThat(buttonAssert).isBlinking(); // same as : buttonAssert.isBlinking(); }- Type Parameters:
T- the generic type of the user-defined assert.- Parameters:
assertion- the assertion to return.- Returns:
- the given assertion.
-
useRepresentation
public static void useRepresentation(Representation customRepresentation)
Register aRepresentationthat will be used in all following assertions.Representationare used to format types in assertions error messages.Example :
private class Example {} private class CustomRepresentation extends StandardRepresentation { // override needed to hook specific formatting @Override public String toStringOf(Object o) { if (o instanceof Example) return "Example"; // fallback to default formatting. return super.toStringOf(o); } // change String representation @Override protected String toStringOf(String s) { return "$" + s + "$"; } } Assertions.useRepresentation(new CustomRepresentation()); // this assertion fails ... assertThat(new Example()).isNull(); // ... with error : // "expected:<[null]> but was:<[Example]>" // this one fails ... assertThat("foo").startsWith("bar"); // ... with error : // Expecting: // <$foo$> // to start with: // <$bar$>- Since:
- 2.5.0 / 3.5.0
-
registerFormatterForType
public static <T> void registerFormatterForType(Class<T> type, Function<T,String> formatter)
Assertions error messages uses aRepresentationto format the different types involved, using this method you can control the formatting of a given type by providing a specific formatter.Registering a formatter makes it available for all AssertJ
Representation:Example :
// without specific formatter assertThat(STANDARD_REPRESENTATION.toStringOf(123L)).isEqualTo("123L"); // register a formatter for Long Assertions.registerFormatterForType(Long.class, value -> "$" + value + "$"); // now Long will be formatted between in $$ in error message. assertThat(STANDARD_REPRESENTATION.toStringOf(longNumber)).isEqualTo("$123$"); // fails with error : expected:<$456$> but was:<$123$> assertThat(123L).isEqualTo(456L);- Parameters:
type-formatter-- Since:
- 3.5.0
-
useDefaultRepresentation
public static void useDefaultRepresentation()
Fallback to useStandardRepresentationto revert the effect of callinguseRepresentation(Representation).- Since:
- 2.5.0 / 3.5.0
-
-