The TestWatcher API was introduced here:
Use it as follows:
- Implement
TestWatcher
class (org.junit.jupiter.api.extension.TestWatcher)
- Add
@ExtendWith(<Your class>.class)
to your tests classes (I personally use a base test class which I extend in every test) (https://junit.org/junit5/docs/current/user-guide/#extensions)
TestWatcher provides you with the following methods to do something on test abort, failed, success and disabled:
testAborted?(ExtensionContext context, Throwable cause)
testDisabled?(ExtensionContext context, Optional<String> reason)
testFailed?(ExtensionContext context, Throwable cause)
testSuccessful?(ExtensionContext context)
https://junit.org/junit5/docs/current/api/org/junit/jupiter/api/extension/TestWatcher.html
Sample TestWatcher implementation:
import java.util.Optional;
import org.junit.jupiter.api.extension.ExtensionContext;
import org.junit.jupiter.api.extension.TestWatcher;
public class MyTestWatcher implements TestWatcher {
@Override
public void testAborted(ExtensionContext extensionContext, Throwable throwable) {
// do something
}
@Override
public void testDisabled(ExtensionContext extensionContext, Optional<String> optional) {
// do something
}
@Override
public void testFailed(ExtensionContext extensionContext, Throwable throwable) {
// do something
}
@Override
public void testSuccessful(ExtensionContext extensionContext) {
// do something
}
}
Then you just put this on your tests:
@ExtendWith(MyTestWatcher.class)
public class TestSomethingSomething {
...
与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…