Polish "Add testing for AbstractFailureAnalyzer.findCause"
See gh-27862
This commit is contained in:
parent
a2eed676a2
commit
d68b6bb2f1
|
@ -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;
|
||||
}
|
||||
|
||||
|
|
|
@ -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 {
|
||||
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue