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

junit.framework.TestResult Maven / Gradle / Ivy

package junit.framework;

import java.util.ArrayList;
import java.util.Collections;
import java.util.Enumeration;
import java.util.List;

/**
 * A TestResult collects the results of executing
 * a test case. It is an instance of the Collecting Parameter pattern.
 * The test framework distinguishes between failures and errors.
 * A failure is anticipated and checked for with assertions. Errors are
 * unanticipated problems like an {@link ArrayIndexOutOfBoundsException}.
 *
 * @see Test
 */
public class TestResult extends Object
{
	protected List fFailures;
	protected List fErrors;
	protected List fListeners;
	protected int fRunTests;
	private boolean fStop;

	public TestResult()
	{
		fFailures= new ArrayList();
		fErrors= new ArrayList();
		fListeners= new ArrayList();
		fRunTests= 0;
		fStop= false;
	}

	/**
	 * Adds an error to the list of errors. The passed in exception
	 * caused the error.
	 */
	public synchronized void addError(Test test, Throwable t)
	{
		fErrors.add(new TestFailure(test, t));
		for (TestListener each : cloneListeners())
		{
			each.addError(test, t);
		}
	}

	/**
	 * Adds a failure to the list of failures. The passed in exception
	 * caused the failure.
	 */
	public synchronized void addFailure(Test test, AssertionFailedError t)
	{
		fFailures.add(new TestFailure(test, t));
		for (TestListener each : cloneListeners())
		{
			each.addFailure(test, t);
		}
	}

	/**
	 * Registers a TestListener
	 */
	public synchronized void addListener(TestListener listener)
	{
		fListeners.add(listener);
	}

	/**
	 * Unregisters a TestListener
	 */
	public synchronized void removeListener(TestListener listener)
	{
		fListeners.remove(listener);
	}

	/**
	 * Returns a copy of the listeners.
	 */
	private synchronized List cloneListeners()
	{
		List result= new ArrayList();
		result.addAll(fListeners);
		return result;
	}

	/**
	 * Informs the result that a test was completed.
	 */
	public void endTest(Test test)
	{
		for (TestListener each : cloneListeners())
		{
			each.endTest(test);
		}
	}

	/**
	 * Gets the number of detected errors.
	 */
	public synchronized int errorCount()
	{
		return fErrors.size();
	}

	/**
	 * Returns an Enumeration for the errors
	 */
	public synchronized Enumeration errors()
	{
		return Collections.enumeration(fErrors);
	}

	/**
	 * Gets the number of detected failures.
	 */
	public synchronized int failureCount()
	{
		return fFailures.size();
	}

	/**
	 * Returns an Enumeration for the failures
	 */
	public synchronized Enumeration failures()
	{
		return Collections.enumeration(fFailures);
	}

	/**
	 * Runs a TestCase.
	 */
	protected void run(final TestCase test)
	{
		startTest(test);
		Protectable p= new Protectable()
		{
			public void protect() throws Throwable
			{
				test.runBare();
			}
		};
		runProtected(test, p);

		endTest(test);
	}

	/**
	 * Gets the number of run tests.
	 */
	public synchronized int runCount()
	{
		return fRunTests;
	}

	/**
	 * Runs a TestCase.
	 */
	public void runProtected(final Test test, Protectable p)
	{
		try
		{
			p.protect();
		}
		catch (AssertionFailedError e)
		{
			addFailure(test, e);
		}
		catch (ThreadDeath e)
		{ // don't catch ThreadDeath by accident
			throw e;
		}
		catch (Throwable e)
		{
			addError(test, e);
		}
	}

	/**
	 * Checks whether the test run should stop
	 */
	public synchronized boolean shouldStop()
	{
		return fStop;
	}

	/**
	 * Informs the result that a test will be started.
	 */
	public void startTest(Test test)
	{
		final int count= test.countTestCases();
		synchronized (this)
		{
			fRunTests+= count;
		}
		for (TestListener each : cloneListeners())
		{
			each.startTest(test);
		}
	}

	/**
	 * Marks that the test run should stop.
	 */
	public synchronized void stop()
	{
		fStop= true;
	}

	/**
	 * Returns whether the entire test was successful or not.
	 */
	public synchronized boolean wasSuccessful()
	{
		return failureCount() == 0 && errorCount() == 0;
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy