All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.thucydides.junit.spring.RunAfterTestMethodCallbacks Maven / Gradle / Ivy

The newest version!
package net.thucydides.junit.spring;

import org.junit.internal.runners.model.MultipleFailureException;
import org.junit.runners.model.Statement;
import org.springframework.test.context.TestContextManager;

import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.List;

/**
 * RunAfterTestMethodCallbacks is a custom JUnit 4.5+
 * {@link Statement} which allows the Spring TestContext Framework to
 * be plugged into the JUnit execution chain by calling afterTestMethod()}
 * on the supplied {@link TestContextManager}.
 * (This is a Spring 3.0 class back-ported into Thucydides to ensure compatibliity with Spring 2.5.x).
 *
 * @see #evaluate()
 * @see RunAfterTestMethodCallbacks
 * @author Sam Brannen
 * @since 3.0
 */
public class RunAfterTestMethodCallbacks extends Statement {

	private final Statement next;

	private final Object testInstance;

	private final Method testMethod;

	private final TestContextManager testContextManager;


	/**
	 * Constructs a new RunAfterTestMethodCallbacks statement.
	 *
	 * @param next the next Statement in the execution chain
	 * @param testInstance the current test instance (never null)
	 * @param testMethod the test method which has just been executed on the
	 * test instance
	 * @param testContextManager the TestContextManager upon which to call
	 * afterTestMethod()
	 */
	public RunAfterTestMethodCallbacks(Statement next, Object testInstance, Method testMethod,
			TestContextManager testContextManager) {
		this.next = next;
		this.testInstance = testInstance;
		this.testMethod = testMethod;
		this.testContextManager = testContextManager;
	}

	/**
	 * Invokes the next {@link Statement} in the execution chain (typically an
	 * instance of {@link org.junit.internal.runners.statements.RunAfters
	 * RunAfters}), catching any exceptions thrown, and then calls afterTestMethod(Object, Method)} with the first
	 * caught exception (if any). If the call to afterTestMethod()
	 * throws an exception, it will also be tracked. Multiple exceptions will be
	 * combined into a {@link MultipleFailureException}.
	 */
	@Override
	public void evaluate() throws Throwable {
		Throwable testException = null;
		List errors = new ArrayList();
		try {
			this.next.evaluate();
		}
		catch (Throwable e) {
			testException = e;
			errors.add(e);
		}

		try {
			this.testContextManager.afterTestMethod(this.testInstance, this.testMethod, testException);
		}
		catch (Exception e) {
			errors.add(e);
		}

		if (errors.isEmpty()) {
			return;
		}
		if (errors.size() == 1) {
			throw errors.get(0);
		}
		throw new MultipleFailureException(errors);
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy