2019-03-10 18:19:46 +01:00
|
|
|
# Cajon - Concise AssertJ Optimizing Nitpicker
|
|
|
|
|
2019-03-31 15:15:06 +02:00
|
|
|
Cajon is an IntelliJ IDEA Plugin for shortening and optimizing AssertJ assertions.
|
2019-03-10 18:19:46 +01:00
|
|
|
|
|
|
|
## Why?
|
|
|
|
|
2019-03-24 09:15:07 +01:00
|
|
|
First, code is easier to read, when it is concise and reflects the intention clearly.
|
|
|
|
AssertJ has plenty of different convenience methods that describing various intentions precisely.
|
2019-03-10 18:19:46 +01:00
|
|
|
Why write longer, more complex code that can be expressed in brevity?
|
|
|
|
|
|
|
|
Second, AssertJ is able to output more meaningful descriptions when an assertion fails.
|
2019-03-24 09:15:07 +01:00
|
|
|
This makes finding bugs and fixing failed tests more efficient.
|
|
|
|
|
|
|
|
For example:
|
|
|
|
|
2019-03-31 15:15:06 +02:00
|
|
|
```
|
|
|
|
assertThat(collection.size()).isEqualTo(5);
|
|
|
|
```
|
2019-03-24 09:15:07 +01:00
|
|
|
|
|
|
|
If the collection has more or less than 5 elements, the assertion will fail, but will not
|
|
|
|
tell you about the contents, making it hard to guess what went wrong.
|
|
|
|
|
|
|
|
Instead, if you wrote the same assertion the following way:
|
|
|
|
|
2019-03-31 15:15:06 +02:00
|
|
|
```
|
|
|
|
assertThat(collection).hasSize(5);
|
|
|
|
```
|
2019-03-24 09:15:07 +01:00
|
|
|
|
|
|
|
Then AssertJ would tell you the contents of the collection on failure.
|
2019-03-10 18:19:46 +01:00
|
|
|
|
2019-03-31 15:15:06 +02:00
|
|
|
## Conversion of JUnit assertions to AssertJ
|
|
|
|
|
|
|
|
The plugin also supports the conversion of the most common JUnit 4 assertions to AssertJ.
|
|
|
|
|
2019-03-31 20:44:52 +02:00
|
|
|
## Implemented inspections
|
2019-03-10 18:19:46 +01:00
|
|
|
|
2019-04-06 17:41:32 +02:00
|
|
|
- AssertThatObjectIsNullOrNotNull
|
2019-03-31 15:15:06 +02:00
|
|
|
```
|
|
|
|
from: assertThat(object).isEqualTo(null);
|
|
|
|
to: assertThat(object).isNull();
|
2019-04-06 17:41:32 +02:00
|
|
|
|
2019-03-31 15:15:06 +02:00
|
|
|
from: assertThat(object).isNotEqualTo(null);
|
|
|
|
to: assertThat(object).isNotNull();
|
|
|
|
```
|
2019-03-10 18:19:46 +01:00
|
|
|
- AssertThatBooleanIsTrueOrFalse
|
2019-03-31 15:15:06 +02:00
|
|
|
```
|
|
|
|
from: assertThat(booleanValue).isEqualTo(true/false/Boolean.TRUE/Boolean.FALSE);
|
|
|
|
to: assertThat(booleanValue).isTrue()/isFalse();
|
|
|
|
```
|
2019-03-23 22:44:22 +01:00
|
|
|
- AssertThatStringIsEmpty
|
2019-03-31 15:15:06 +02:00
|
|
|
```
|
|
|
|
from: assertThat(charSequence/string).isEqualTo("");
|
|
|
|
from: assertThat(charSequence/string).hasSize(0);
|
|
|
|
to: assertThat(charSequence/string).isEmpty();
|
|
|
|
```
|
2019-03-24 14:42:02 +01:00
|
|
|
- AssertThatEnumerableIsEmpty
|
2019-03-31 15:15:06 +02:00
|
|
|
```
|
|
|
|
from: assertThat(enumerable).hasSize(0);
|
|
|
|
to: assertThat(enumerable).isEmpty();
|
2019-03-31 20:44:52 +02:00
|
|
|
```
|
|
|
|
- AssertThatSize
|
|
|
|
```
|
|
|
|
from: assertThat(array.length).isEqualTo(0);
|
|
|
|
from: assertThat(array.length).isLessThanOrEqualTo(0);
|
|
|
|
from: assertThat(array.length).isLessThan(1);
|
|
|
|
from: assertThat(array.length).isZero();
|
|
|
|
to: assertThat(array).isEmpty();
|
|
|
|
|
|
|
|
from: assertThat(array.length).isGreaterThan(0);
|
|
|
|
from: assertThat(array.length).isGreaterThanOrEqualTo(1);
|
|
|
|
from: assertThat(array.length).isNotZero();
|
|
|
|
to: assertThat(array).isNotEmpty();
|
|
|
|
|
|
|
|
from: assertThat(array.length).isEqualTo(anotherArray.length);
|
|
|
|
to: assertThat(array).hasSameSizeAs(anotherArray);
|
|
|
|
```
|
|
|
|
|
2019-04-06 16:53:20 +02:00
|
|
|
with AssertJ 13.2.0 or higher
|
|
|
|
|
|
|
|
```
|
|
|
|
from: assertThat(array.length).isLessThanOrEqualTo(expression);
|
|
|
|
to: assertThat(array).hasSizeLessThanOrEqualTo(expression);
|
|
|
|
|
|
|
|
from: assertThat(array.length).isLessThan(expression);
|
|
|
|
to: assertThat(array).hasSizeLessThan(expression);
|
|
|
|
|
|
|
|
from: assertThat(array.length).isGreaterThan(expression);
|
|
|
|
to: assertThat(array).hasSizeGreaterThan(expression);
|
|
|
|
|
|
|
|
from: assertThat(array.length).isGreaterThanOrEqualTo(expression);
|
|
|
|
to: assertThat(array).hasSizeGreaterThanOrEqualTo(expression);
|
|
|
|
```
|
|
|
|
|
2019-03-31 20:44:52 +02:00
|
|
|
and analogously for collections...
|
|
|
|
|
2019-04-07 11:29:07 +02:00
|
|
|
- AssertThatBinaryExpressionIsTrueOrFalse
|
|
|
|
```
|
|
|
|
from: assertThat(primActual == primExpected).isTrue();
|
|
|
|
to: assertThat(primActual).isEqualTo(primExpected);
|
|
|
|
|
|
|
|
from: assertThat(10 < primActual).isNotEqualTo(false);
|
|
|
|
to: assertThat(primActual).isGreaterThan(primExpected);
|
|
|
|
|
|
|
|
from: assertThat(objActual != objExpected).isEqualTo(true);
|
|
|
|
to: assertThat(objActual).isNotSameAs(objExpected);
|
|
|
|
|
|
|
|
from: assertThat(null == objActual).isFalse();
|
|
|
|
to: assertThat(objActual).isNotNull();
|
|
|
|
```
|
|
|
|
and many, many more combinations (more than 150).
|
|
|
|
|
2019-03-31 15:15:06 +02:00
|
|
|
- JUnitAssertToAssertJ
|
|
|
|
```
|
|
|
|
assertTrue(condition);
|
|
|
|
assertTrue(message, condition);
|
|
|
|
assertFalse(condition);
|
|
|
|
assertFalse(message, condition);
|
|
|
|
assertNull(object);
|
|
|
|
assertNull(message, object);
|
|
|
|
assertNonNull(object);
|
|
|
|
assertNonNull(message, object);
|
|
|
|
assertEquals(expected, actual);
|
|
|
|
assertEquals(message, expected, actual);
|
|
|
|
assertEquals(expectedDoubleOrFloat, actualDoubleOrFloat, delta);
|
|
|
|
assertEquals(message, expectedDoubleOrFloat, actualDoubleOrFloat, delta);
|
|
|
|
assertNotEquals(unexpected, actual);
|
|
|
|
assertNotEquals(message, unexpected, actual);
|
|
|
|
assertNotEquals(unexpectedDoubleOrFloat, actualDoubleOrFloat, delta);
|
|
|
|
assertNotEquals(message, unexpectedDoubleOrFloat, actualDoubleOrFloat, delta);
|
|
|
|
assertSame(expected, actual);
|
|
|
|
assertSame(message, expected, actual);
|
|
|
|
assertNotSame(unexpected, actual);
|
|
|
|
assertNotSame(message, unexpected, actual);
|
|
|
|
assertArrayEquals(expected, actual);
|
|
|
|
assertArrayEquals(message, expectedArray, actualArray);
|
|
|
|
assertArrayEquals(expectedDoubleOrFloatArray, actualDoubleOrFloatArray, delta);
|
|
|
|
assertArrayEquals(message, expectedDoubleOrFloatArray, actualDoubleOrFloatArray, delta);
|
|
|
|
```
|
2019-03-24 09:15:07 +01:00
|
|
|
|
2019-04-06 16:53:20 +02:00
|
|
|
## Development notice
|
|
|
|
|
|
|
|
Cajon is probably the only plugin that uses JUnit 5 Jupiter for unit testing so far (or at least the only one that I'm aware of ;) ).
|
|
|
|
The IntelliJ framework actually uses the JUnit 3 TestCase for plugin testing and I took me quite a while to make it work with JUnit 5.
|
|
|
|
Feel free to use the code (in package de.platon42.intellij.jupiter) for your projects (with attribution).
|
|
|
|
|
2019-03-24 09:15:07 +01:00
|
|
|
## TODO
|
2019-04-06 16:53:20 +02:00
|
|
|
- AssertThatBinaryExpressionIsTrueOrFalse
|
|
|
|
```
|
|
|
|
from: assertThat(actual == expected).isTrue();
|
|
|
|
to: assertThat(actual).isEqualTo(expected); (for primitive types)
|
|
|
|
to: assertThat(actual).isSameAs(expected); (for objects)
|
|
|
|
|
|
|
|
from: assertThat(actual != expected).isFalse();
|
|
|
|
to: assertThat(actual).isNotEqualTo(expected); (for primitive types)
|
|
|
|
to: assertThat(actual).isNotSameAs(expected); (for objects)
|
|
|
|
```
|
|
|
|
- AssertThatJava8OptionalContains
|
|
|
|
```
|
|
|
|
from: assertThat(Optional.of("foo").get()).isEqualTo("foo");
|
|
|
|
to: assertThat(Optional.of("foo")).contains("foo");
|
|
|
|
```
|
|
|
|
- AssertThatJava8OptionalIsPresentOrAbsent
|
|
|
|
```
|
|
|
|
from: assertThat(Optional.of("foo").isPresent()).isEqualTo(true);
|
|
|
|
from: assertThat(!Optional.of("foo").isPresent()).isEqualTo(false);
|
|
|
|
from: assertThat(Optional.of("foo").isPresent()).isTrue();
|
|
|
|
from: assertThat(!Optional.of("foo").isPresent()).isFalse();
|
|
|
|
to: assertThat(Optional.of("foo")).isPresent();
|
|
|
|
|
|
|
|
from: assertThat(Optional.of("foo").isPresent()).isEqualTo(false);
|
|
|
|
from: assertThat(!Optional.of("foo").isPresent()).isEqualTo(true);
|
|
|
|
from: assertThat(Optional.of("foo").isPresent()).isFalse();
|
|
|
|
from: assertThat(!Optional.of("foo").isPresent()).isTrue();
|
|
|
|
to: assertThat(Optional.of("foo")).isNotPresent();
|
|
|
|
```
|
2019-03-31 20:44:52 +02:00
|
|
|
- AssertThatGuavaOptionalContains
|
2019-04-06 16:53:20 +02:00
|
|
|
```
|
|
|
|
from: assertThat(Optional.of("foo").get()).isEqualTo("foo");
|
|
|
|
to: assertThat(Optional.of("foo")).contains("foo");
|
|
|
|
```
|
|
|
|
- AssertThatGuavaOptionalIsPresentOrAbsent
|
|
|
|
```
|
|
|
|
from: assertThat(Optional.of("foo").isPresent()).isEqualTo(true);
|
|
|
|
from: assertThat(!Optional.of("foo").isPresent()).isEqualTo(false);
|
|
|
|
from: assertThat(Optional.of("foo").isPresent()).isTrue();
|
|
|
|
from: assertThat(!Optional.of("foo").isPresent()).isFalse();
|
|
|
|
to: assertThat(Optional.of("foo")).isPresent();
|
|
|
|
|
|
|
|
from: assertThat(Optional.of("foo").isPresent()).isEqualTo(false);
|
|
|
|
from: assertThat(!Optional.of("foo").isPresent()).isEqualTo(true);
|
|
|
|
from: assertThat(Optional.of("foo").isPresent()).isFalse();
|
|
|
|
from: assertThat(!Optional.of("foo").isPresent()).isTrue();
|
|
|
|
to: assertThat(Optional.of("foo")).isAbsent();
|
|
|
|
```
|
|
|
|
- Referencing string properties inside extracting()
|
|
|
|
- Extraction with property names to lambda with Java 8
|
|
|
|
```
|
|
|
|
from: assertThat(object).extracting("propOne", "propNoGetter", "propTwo.innerProp")...
|
|
|
|
to: assertThat(object).extracting(type::getPropOne, it -> it.propNoGetter, it -> it.getPropTwo().getInnerProp())...
|
|
|
|
```
|
2019-04-07 11:29:07 +02:00
|
|
|
- Kotlin support
|