Skip to content

Commit

Permalink
Document benefits of messageSupplier in Assertions
Browse files Browse the repository at this point in the history
 Issue: #3153
  • Loading branch information
chris-carneiro committed Aug 28, 2024
1 parent d85dd9b commit a625349
Show file tree
Hide file tree
Showing 2 changed files with 11 additions and 2 deletions.
8 changes: 8 additions & 0 deletions documentation/src/docs/asciidoc/user-guide/writing-tests.adoc
Original file line number Diff line number Diff line change
Expand Up @@ -293,6 +293,14 @@ JUnit Jupiter comes with many of the assertion methods that JUnit 4 has and adds
that lend themselves well to being used with Java 8 lambdas. All JUnit Jupiter assertions
are `static` methods in the `{Assertions}` class.

Assertion methods can accept an optional third parameter, which can be either a `String` or a `Supplier<String>`.
When using a `Supplier<String>` (e.g., a lambda expression) as the message supplier,
the message is evaluated lazily.

Lazily evaluating the assertion message can provide a performance benefit,
especially if the message construction is complex or time-consuming,
as it is only evaluated when the assertion fails.

[source,java,indent=0]
----
include::{testDir}/example/AssertionsDemo.java[tags=user_guide]
Expand Down
5 changes: 3 additions & 2 deletions documentation/src/test/java/example/AssertionsDemo.java
Original file line number Diff line number Diff line change
Expand Up @@ -41,8 +41,9 @@ void standardAssertions() {
assertEquals(2, calculator.add(1, 1));
assertEquals(4, calculator.multiply(2, 2),
"The optional failure message is now the last parameter");
assertTrue('a' < 'b', () -> "Assertion messages can be lazily evaluated -- "
+ "to avoid constructing complex messages unnecessarily.");

// Lazily evaluates generateFailureMessage('a','b').
assertTrue('a' < 'b', () -> generateFailureMessage('a','b'));
}

@Test
Expand Down

0 comments on commit a625349

Please sign in to comment.