You've already forked linux-packaging-mono
150 lines
5.1 KiB
C#
150 lines
5.1 KiB
C#
// ***********************************************************************
|
|
// Copyright (c) 2007 Charlie Poole
|
|
//
|
|
// Permission is hereby granted, free of charge, to any person obtaining
|
|
// a copy of this software and associated documentation files (the
|
|
// "Software"), to deal in the Software without restriction, including
|
|
// without limitation the rights to use, copy, modify, merge, publish,
|
|
// distribute, sublicense, and/or sell copies of the Software, and to
|
|
// permit persons to whom the Software is furnished to do so, subject to
|
|
// the following conditions:
|
|
//
|
|
// The above copyright notice and this permission notice shall be
|
|
// included in all copies or substantial portions of the Software.
|
|
//
|
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
|
// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
|
// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
// ***********************************************************************
|
|
|
|
namespace NUnit.Framework.Api
|
|
{
|
|
/// <summary>
|
|
/// The ResultState class represents the outcome of running a test.
|
|
/// It contains two pieces of information. The Status of the test
|
|
/// is an enum indicating whether the test passed, failed, was
|
|
/// skipped or was inconclusive. The Label provides a more
|
|
/// detailed breakdown for use by client runners.
|
|
/// </summary>
|
|
[System.Serializable]
|
|
public class ResultState
|
|
{
|
|
private readonly TestStatus status;
|
|
private readonly string label;
|
|
|
|
#region Constructors
|
|
|
|
/// <summary>
|
|
/// Initializes a new instance of the <see cref="ResultState"/> class.
|
|
/// </summary>
|
|
/// <param name="status">The TestStatus.</param>
|
|
public ResultState(TestStatus status) : this (status, string.Empty)
|
|
{
|
|
}
|
|
|
|
/// <summary>
|
|
/// Initializes a new instance of the <see cref="ResultState"/> class.
|
|
/// </summary>
|
|
/// <param name="status">The TestStatus.</param>
|
|
/// <param name="label">The label.</param>
|
|
public ResultState(TestStatus status, string label)
|
|
{
|
|
this.status = status;
|
|
this.label = label == null ? string.Empty : label;
|
|
}
|
|
|
|
#endregion
|
|
|
|
#region Predefined ResultStates
|
|
|
|
/// <summary>
|
|
/// The result is inconclusive
|
|
/// </summary>
|
|
public readonly static ResultState Inconclusive = new ResultState(TestStatus.Inconclusive);
|
|
|
|
/// <summary>
|
|
/// The test was not runnable.
|
|
/// </summary>
|
|
public readonly static ResultState NotRunnable = new ResultState(TestStatus.Skipped, "Invalid");
|
|
|
|
/// <summary>
|
|
/// The test has been skipped.
|
|
/// </summary>
|
|
public readonly static ResultState Skipped = new ResultState(TestStatus.Skipped);
|
|
|
|
/// <summary>
|
|
/// The test has been ignored.
|
|
/// </summary>
|
|
public readonly static ResultState Ignored = new ResultState(TestStatus.Skipped, "Ignored");
|
|
|
|
/// <summary>
|
|
/// The test succeeded
|
|
/// </summary>
|
|
public readonly static ResultState Success = new ResultState(TestStatus.Passed);
|
|
|
|
/// <summary>
|
|
/// The test failed
|
|
/// </summary>
|
|
public readonly static ResultState Failure = new ResultState(TestStatus.Failed);
|
|
|
|
/// <summary>
|
|
/// The test encountered an unexpected exception
|
|
/// </summary>
|
|
public readonly static ResultState Error = new ResultState(TestStatus.Failed, "Error");
|
|
|
|
/// <summary>
|
|
/// The test was cancelled by the user
|
|
/// </summary>
|
|
public readonly static ResultState Cancelled = new ResultState(TestStatus.Failed, "Cancelled");
|
|
|
|
#endregion
|
|
|
|
#region Properties
|
|
|
|
/// <summary>
|
|
/// Gets the TestStatus for the test.
|
|
/// </summary>
|
|
/// <value>The status.</value>
|
|
public TestStatus Status
|
|
{
|
|
get { return status; }
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets the label under which this test resullt is
|
|
/// categorized, if any.
|
|
/// </summary>
|
|
public string Label
|
|
{
|
|
get { return label; }
|
|
}
|
|
|
|
#endregion
|
|
|
|
/// <summary>
|
|
/// Returns a <see cref="System.String"/> that represents this instance.
|
|
/// </summary>
|
|
/// <returns>
|
|
/// A <see cref="System.String"/> that represents this instance.
|
|
/// </returns>
|
|
public override string ToString()
|
|
{
|
|
string s = status.ToString();
|
|
return label == null || label.Length == 0 ? s : string.Format("{0}:{1}", s, label);
|
|
}
|
|
|
|
public override bool Equals (object o)
|
|
{
|
|
if (!(o is ResultState that))
|
|
return false;
|
|
|
|
return that.status.Equals(this.status)
|
|
&& that.label.Equals (this.label);
|
|
}
|
|
}
|
|
}
|