140 lines
5.9 KiB
C#
140 lines
5.9 KiB
C#
|
// ****************************************************************
|
||
|
// Copyright 2007, Charlie Poole
|
||
|
// This is free software licensed under the NUnit license. You may
|
||
|
// obtain a copy of the license at http://nunit.org/?p=license&r=2.4
|
||
|
// ****************************************************************
|
||
|
|
||
|
using System;
|
||
|
using System.IO;
|
||
|
using System.Collections;
|
||
|
using NUnit.Framework.Constraints;
|
||
|
|
||
|
namespace NUnit.Framework
|
||
|
{
|
||
|
/// <summary>
|
||
|
/// MessageWriter is the abstract base for classes that write
|
||
|
/// constraint descriptions and messages in some form. The
|
||
|
/// class has separate methods for writing various components
|
||
|
/// of a message, allowing implementations to tailor the
|
||
|
/// presentation as needed.
|
||
|
/// </summary>
|
||
|
public abstract class MessageWriter : StringWriter
|
||
|
{
|
||
|
|
||
|
/// <summary>
|
||
|
/// Construct a MessageWriter given a culture
|
||
|
/// </summary>
|
||
|
public MessageWriter() : base( System.Globalization.CultureInfo.InvariantCulture ) { }
|
||
|
|
||
|
/// <summary>
|
||
|
/// Abstract method to get the max line length
|
||
|
/// </summary>
|
||
|
public abstract int MaxLineLength { get; set; }
|
||
|
|
||
|
/// <summary>
|
||
|
/// Method to write single line message with optional args, usually
|
||
|
/// written to precede the general failure message.
|
||
|
/// </summary>
|
||
|
/// <param name="message">The message to be written</param>
|
||
|
/// <param name="args">Any arguments used in formatting the message</param>
|
||
|
public void WriteMessageLine(string message, params object[] args)
|
||
|
{
|
||
|
WriteMessageLine(0, message, args);
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Method to write single line message with optional args, usually
|
||
|
/// written to precede the general failure message, at a givel
|
||
|
/// indentation level.
|
||
|
/// </summary>
|
||
|
/// <param name="level">The indentation level of the message</param>
|
||
|
/// <param name="message">The message to be written</param>
|
||
|
/// <param name="args">Any arguments used in formatting the message</param>
|
||
|
public abstract void WriteMessageLine(int level, string message, params object[] args);
|
||
|
|
||
|
/// <summary>
|
||
|
/// Display Expected and Actual lines for a constraint. This
|
||
|
/// is called by MessageWriter's default implementation of
|
||
|
/// WriteMessageTo and provides the generic two-line display.
|
||
|
/// </summary>
|
||
|
/// <param name="constraint">The constraint that failed</param>
|
||
|
public abstract void DisplayDifferences(Constraint constraint);
|
||
|
|
||
|
/// <summary>
|
||
|
/// Display Expected and Actual lines for given values. This
|
||
|
/// method may be called by constraints that need more control over
|
||
|
/// the display of actual and expected values than is provided
|
||
|
/// by the default implementation.
|
||
|
/// </summary>
|
||
|
/// <param name="expected">The expected value</param>
|
||
|
/// <param name="actual">The actual value causing the failure</param>
|
||
|
public abstract void DisplayDifferences(object expected, object actual);
|
||
|
|
||
|
/// <summary>
|
||
|
/// Display Expected and Actual lines for given values, including
|
||
|
/// a tolerance value on the Expected line.
|
||
|
/// </summary>
|
||
|
/// <param name="expected">The expected value</param>
|
||
|
/// <param name="actual">The actual value causing the failure</param>
|
||
|
/// <param name="tolerance">The tolerance within which the test was made</param>
|
||
|
public abstract void DisplayDifferences(object expected, object actual, object tolerance);
|
||
|
|
||
|
/// <summary>
|
||
|
/// Display the expected and actual string values on separate lines.
|
||
|
/// If the mismatch parameter is >=0, an additional line is displayed
|
||
|
/// line containing a caret that points to the mismatch point.
|
||
|
/// </summary>
|
||
|
/// <param name="expected">The expected string value</param>
|
||
|
/// <param name="actual">The actual string value</param>
|
||
|
/// <param name="mismatch">The point at which the strings don't match or -1</param>
|
||
|
/// <param name="ignoreCase">If true, case is ignored in locating the point where the strings differ</param>
|
||
|
/// <param name="clipping">If true, the strings should be clipped to fit the line</param>
|
||
|
public abstract void DisplayStringDifferences(string expected, string actual, int mismatch, bool ignoreCase, bool clipping);
|
||
|
|
||
|
/// <summary>
|
||
|
/// Writes the text for a connector.
|
||
|
/// </summary>
|
||
|
/// <param name="connector">The connector.</param>
|
||
|
public abstract void WriteConnector(string connector);
|
||
|
|
||
|
/// <summary>
|
||
|
/// Writes the text for a predicate.
|
||
|
/// </summary>
|
||
|
/// <param name="predicate">The predicate.</param>
|
||
|
public abstract void WritePredicate(string predicate);
|
||
|
|
||
|
/// <summary>
|
||
|
/// Writes the text for an expected value.
|
||
|
/// </summary>
|
||
|
/// <param name="expected">The expected value.</param>
|
||
|
public abstract void WriteExpectedValue(object expected);
|
||
|
|
||
|
/// <summary>
|
||
|
/// Writes the text for a modifier
|
||
|
/// </summary>
|
||
|
/// <param name="modifier">The modifier.</param>
|
||
|
public abstract void WriteModifier(string modifier);
|
||
|
|
||
|
/// <summary>
|
||
|
/// Writes the text for an actual value.
|
||
|
/// </summary>
|
||
|
/// <param name="actual">The actual value.</param>
|
||
|
public abstract void WriteActualValue(object actual);
|
||
|
|
||
|
/// <summary>
|
||
|
/// Writes the text for a generalized value.
|
||
|
/// </summary>
|
||
|
/// <param name="val">The value.</param>
|
||
|
public abstract void WriteValue(object val);
|
||
|
|
||
|
/// <summary>
|
||
|
/// Writes the text for a collection value,
|
||
|
/// starting at a particular point, to a max length
|
||
|
/// </summary>
|
||
|
/// <param name="collection">The collection containing elements to write.</param>
|
||
|
/// <param name="start">The starting point of the elements to write</param>
|
||
|
/// <param name="max">The maximum number of elements to write</param>
|
||
|
public abstract void WriteCollectionElements(ICollection collection, int start, int max);
|
||
|
}
|
||
|
}
|