Polish "Add testing for AbstractFailureAnalyzer.findCause"

See gh-27862
This commit is contained in:
Stephane Nicoll 2021-09-21 10:05:15 +02:00
parent a2eed676a2
commit d68b6bb2f1
2 changed files with 42 additions and 25 deletions

View File

@ -1,5 +1,5 @@
/*
* Copyright 2012-2019 the original author or authors.
* Copyright 2012-2021 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
@ -31,7 +31,6 @@ public abstract class AbstractFailureAnalyzer<T extends Throwable> implements Fa
@Override
public FailureAnalysis analyze(Throwable failure) {
T cause = findCause(failure, getCauseType());
return (cause != null) ? analyze(failure, cause) : null;
}

View File

@ -16,44 +16,66 @@
package org.springframework.boot.diagnostics;
import org.junit.jupiter.api.BeforeEach;
import java.io.IOException;
import org.junit.jupiter.api.Test;
import static org.assertj.core.api.Assertions.assertThat;
/**
* Tests for {@link AbstractFailureAnalyzer}.
*
* @author Kim Jung Bin
* @author Stephane Nicoll
*/
class AbstractFailureAnalyzerTests {
private FailureAnalyzerConcrete failureAnalyzerConcrete;
private final TestFailureAnalyzer failureAnalyzer = new TestFailureAnalyzer();
@BeforeEach
void configureFailureAnalyzer() {
this.failureAnalyzerConcrete = new FailureAnalyzerConcrete();
@Test
void findCauseWithNullException() {
assertThat(this.failureAnalyzer.findCause(null, Throwable.class)).isNull();
}
@Test
void findCauseExtendsThrowable() {
ThrowableExtendsException ex = new ThrowableExtendsException();
assertThat(this.failureAnalyzerConcrete.findCause(ex, Throwable.class).getClass()).isNotNull();
void findCauseWithDirectExactMatch() {
TestException ex = new TestException();
assertThat(this.failureAnalyzer.findCause(ex, TestException.class)).isEqualTo(ex);
}
@Test
void findCauseExtendsOtherException() {
ExtendsThrowableExtendsException ex = new ExtendsThrowableExtendsException();
assertThat(this.failureAnalyzerConcrete.findCause(ex, ThrowableExtendsException.class).getClass()).isNotNull();
void findCauseWithDirectSubClass() {
SpecificTestException ex = new SpecificTestException();
assertThat(this.failureAnalyzer.findCause(ex, TestException.class)).isEqualTo(ex);
}
@Test
void findCauseOtherException() {
ThrowableExtendsException ex = new ThrowableExtendsException();
assertThat(this.failureAnalyzerConcrete.findCause(ex, OtherException.class)).isNull();
void findCauseWitNestedAndExactMatch() {
TestException ex = new TestException();
assertThat(this.failureAnalyzer.findCause(new IllegalArgumentException(new IllegalStateException(ex)),
TestException.class)).isEqualTo(ex);
}
@Test
void findCauseNullObject() {
assertThat(this.failureAnalyzerConcrete.findCause(null, Throwable.class)).isNull();
void findCauseWitNestedAndSubClass() {
SpecificTestException ex = new SpecificTestException();
assertThat(this.failureAnalyzer.findCause(new IOException(new IllegalStateException(ex)), TestException.class))
.isEqualTo(ex);
}
static class FailureAnalyzerConcrete extends AbstractFailureAnalyzer<Throwable> {
@Test
void findCauseWithUnrelatedException() {
IOException ex = new IOException();
assertThat(this.failureAnalyzer.findCause(ex, TestException.class)).isNull();
}
@Test
void findCauseWithMoreSpecificException() {
TestException ex = new TestException();
assertThat(this.failureAnalyzer.findCause(ex, SpecificTestException.class)).isNull();
}
static class TestFailureAnalyzer extends AbstractFailureAnalyzer<Throwable> {
@Override
protected FailureAnalysis analyze(Throwable rootFailure, Throwable cause) {
@ -62,15 +84,11 @@ class AbstractFailureAnalyzerTests {
}
static class ThrowableExtendsException extends Throwable {
static class TestException extends Exception {
}
static class ExtendsThrowableExtendsException extends ThrowableExtendsException {
}
static class OtherException extends Throwable {
static class SpecificTestException extends TestException {
}