TestLoggerFactoryResetRule.java
package com.github.valfirst.slf4jtest;
import org.junit.rules.TestRule;
import org.junit.runner.Description;
import org.junit.runners.model.Statement;
/**
* A <a href="https://github.com/junit-team/junit/wiki">JUnit</a> rule that clears the ThreadLocal
* state of all the TestLoggers and the TestLoggerFactory.
*/
public class TestLoggerFactoryResetRule implements TestRule {
@Override
public Statement apply(final Statement base, final Description description) {
return new TestLoggerFactoryResettingStatement(base);
}
private static class TestLoggerFactoryResettingStatement extends Statement {
private final Statement base;
public TestLoggerFactoryResettingStatement(final Statement base) {
super();
this.base = base;
}
@Override
public void evaluate() throws Throwable {
TestLoggerFactory.clear();
try {
base.evaluate();
} finally {
TestLoggerFactory.clear();
}
}
}
}