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

junit.textui.ResultPrinter Maven / Gradle / Ivy

package junit.textui;

import java.io.PrintStream;
import java.text.NumberFormat;
import java.util.Enumeration;

import junit.framework.AssertionFailedError;
import junit.framework.Test;
import junit.framework.TestFailure;
import junit.framework.TestListener;
import junit.framework.TestResult;
import junit.runner.BaseTestRunner;

public class ResultPrinter implements TestListener
{
	PrintStream fWriter;
	int fColumn= 0;

	public ResultPrinter(PrintStream writer)
	{
		fWriter= writer;
	}

	/* API for use by textui.TestRunner */

	synchronized void print(TestResult result, long runTime)
	{
		printHeader(runTime);
		printErrors(result);
		printFailures(result);
		printFooter(result);
	}

	void printWaitPrompt()
	{
		getWriter().println();
		getWriter().println(" to continue");
	}

	/* Internal methods */

	protected void printHeader(long runTime)
	{
		getWriter().println();
		getWriter().println("Time: " + elapsedTimeAsString(runTime));
	}

	protected void printErrors(TestResult result)
	{
		printDefects(result.errors(), result.errorCount(), "error");
	}

	protected void printFailures(TestResult result)
	{
		printDefects(result.failures(), result.failureCount(), "failure");
	}

	protected void printDefects(Enumeration booBoos, int count, String type)
	{
		if (count == 0)
			return;
		if (count == 1)
		{
			getWriter().println("There was " + count + " " + type + ":");
		}
		else
		{
			getWriter().println("There were " + count + " " + type + "s:");
		}
		for (int i= 1; booBoos.hasMoreElements(); i++)
		{
			printDefect(booBoos.nextElement(), i);
		}
	}

	public void printDefect(TestFailure booBoo, int count)
	{ // only public for testing purposes
		printDefectHeader(booBoo, count);
		printDefectTrace(booBoo);
	}

	protected void printDefectHeader(TestFailure booBoo, int count)
	{
		// I feel like making this a println, then adding a line giving the throwable a chance to print something
		// before we get to the stack trace.
		getWriter().print(count + ") " + booBoo.failedTest());
	}

	protected void printDefectTrace(TestFailure booBoo)
	{
		getWriter().print(BaseTestRunner.getFilteredTrace(booBoo.trace()));
	}

	protected void printFooter(TestResult result)
	{
		if (result.wasSuccessful())
		{
			getWriter().println();
			getWriter().print("OK");
			getWriter().println(" (" + result.runCount() + " test" + (result.runCount() == 1 ? "" : "s") + ")");

		}
		else
		{
			getWriter().println();
			getWriter().println("FAILURES!!!");
			getWriter().println("Tests run: " + result.runCount() + ",  Failures: " + result.failureCount() + ",  Errors: " + result.errorCount());
		}
		getWriter().println();
	}

	/**
	 * Returns the formatted string of the elapsed time.
	 * Duplicated from BaseTestRunner. Fix it.
	 */
	protected String elapsedTimeAsString(long runTime)
	{
		return NumberFormat.getInstance().format((double) runTime / 1000);
	}

	public PrintStream getWriter()
	{
		return fWriter;
	}

	/**
	 * @see junit.framework.TestListener#addError(Test, Throwable)
	 */
	public void addError(Test test, Throwable t)
	{
		getWriter().print("E");
	}

	/**
	 * @see junit.framework.TestListener#addFailure(Test, AssertionFailedError)
	 */
	public void addFailure(Test test, AssertionFailedError t)
	{
		getWriter().print("F");
	}

	/**
	 * @see junit.framework.TestListener#endTest(Test)
	 */
	public void endTest(Test test)
	{
	}

	/**
	 * @see junit.framework.TestListener#startTest(Test)
	 */
	public void startTest(Test test)
	{
		getWriter().print(".");
		if (fColumn++ >= 40)
		{
			getWriter().println();
			fColumn= 0;
		}
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy