250 lines
6.1 KiB
C#
250 lines
6.1 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.Collections;
|
||
|
using System.Collections.Specialized;
|
||
|
|
||
|
namespace NUnit.Core
|
||
|
{
|
||
|
/// <summary>
|
||
|
/// TestInfo holds common info about a test. It represents only
|
||
|
/// a single test or a suite and contains no references to other
|
||
|
/// tests. Since it is informational only, it can easily be passed
|
||
|
/// around using .Net remoting.
|
||
|
///
|
||
|
/// TestInfo is used directly in all EventListener events and in
|
||
|
/// TestResults. It contains an ID, which can be used by a
|
||
|
/// runner to locate the actual test.
|
||
|
///
|
||
|
/// TestInfo also serves as the base class for TestNode, which
|
||
|
/// adds hierarchical information and is used in client code to
|
||
|
/// maintain a visible image of the structure of the tests.
|
||
|
/// </summary>
|
||
|
[Serializable]
|
||
|
public class TestInfo : ITest
|
||
|
{
|
||
|
#region Instance Variables
|
||
|
/// <summary>
|
||
|
/// TestName that identifies this test
|
||
|
/// </summary>
|
||
|
private TestName testName;
|
||
|
|
||
|
private string testType;
|
||
|
|
||
|
private RunState runState;
|
||
|
|
||
|
/// <summary>
|
||
|
/// Reason for not running the test
|
||
|
/// </summary>
|
||
|
private string ignoreReason;
|
||
|
|
||
|
/// <summary>
|
||
|
/// Number of test cases in this test or suite
|
||
|
/// </summary>
|
||
|
private int testCaseCount;
|
||
|
|
||
|
/// <summary>
|
||
|
/// True if this is a suite
|
||
|
/// </summary>
|
||
|
private bool isSuite;
|
||
|
|
||
|
/// <summary>
|
||
|
/// The test description
|
||
|
/// </summary>
|
||
|
private string description;
|
||
|
|
||
|
/// <summary>
|
||
|
/// A list of all the categories assigned to a test
|
||
|
/// </summary>
|
||
|
private ArrayList categories = new ArrayList();
|
||
|
|
||
|
/// <summary>
|
||
|
/// A dictionary of properties, used to add information
|
||
|
/// to tests without requiring the class to change.
|
||
|
/// </summary>
|
||
|
private ListDictionary properties = new ListDictionary();
|
||
|
|
||
|
#endregion
|
||
|
|
||
|
#region Constructors
|
||
|
/// <summary>
|
||
|
/// Construct from an ITest
|
||
|
/// </summary>
|
||
|
/// <param name="test">Test from which a TestNode is to be constructed</param>
|
||
|
public TestInfo( ITest test )
|
||
|
{
|
||
|
this.testName = (TestName)test.TestName.Clone();
|
||
|
this.testType = test.TestType;
|
||
|
|
||
|
this.runState = test.RunState;
|
||
|
this.ignoreReason = test.IgnoreReason;
|
||
|
this.description = test.Description;
|
||
|
this.isSuite = test.IsSuite;
|
||
|
|
||
|
if (test.Categories != null)
|
||
|
this.categories.AddRange(test.Categories);
|
||
|
if (test.Properties != null)
|
||
|
{
|
||
|
this.properties = new ListDictionary();
|
||
|
foreach( DictionaryEntry entry in test.Properties )
|
||
|
this.properties.Add( entry.Key, entry.Value );
|
||
|
}
|
||
|
|
||
|
this.testCaseCount = test.TestCount;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Construct as a parent to multiple tests.
|
||
|
/// </summary>
|
||
|
/// <param name="testName">The name to use for the new test</param>
|
||
|
/// <param name="tests">An array of child tests</param>
|
||
|
public TestInfo( TestName testName, ITest[] tests )
|
||
|
{
|
||
|
this.testName = testName;
|
||
|
this.testType = "Test Project";
|
||
|
|
||
|
this.runState = RunState.Runnable;
|
||
|
this.ignoreReason = null;
|
||
|
this.description = null;
|
||
|
this.isSuite = true;
|
||
|
|
||
|
foreach( ITest test in tests )
|
||
|
{
|
||
|
this.testCaseCount += test.TestCount;
|
||
|
}
|
||
|
}
|
||
|
#endregion
|
||
|
|
||
|
#region Properties
|
||
|
/// <summary>
|
||
|
/// Gets the completely specified name of the test
|
||
|
/// encapsulated in a TestName object.
|
||
|
/// </summary>
|
||
|
public TestName TestName
|
||
|
{
|
||
|
get { return testName; }
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Gets a string representing the kind of test this
|
||
|
/// object represents for display purposes.
|
||
|
/// </summary>
|
||
|
public string TestType
|
||
|
{
|
||
|
get { return testType; }
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// The test description
|
||
|
/// </summary>
|
||
|
public string Description
|
||
|
{
|
||
|
get { return description; }
|
||
|
set { description = value; }
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Gets the RunState for this test
|
||
|
/// </summary>
|
||
|
public RunState RunState
|
||
|
{
|
||
|
get { return runState; }
|
||
|
set { runState = value; }
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// The reason for ignoring a test
|
||
|
/// </summary>
|
||
|
public string IgnoreReason
|
||
|
{
|
||
|
get { return ignoreReason; }
|
||
|
set { ignoreReason = value; }
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Count of test cases in this test.
|
||
|
/// </summary>
|
||
|
public int TestCount
|
||
|
{
|
||
|
get { return testCaseCount; }
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Gets the parent test of this test
|
||
|
/// </summary>
|
||
|
public virtual ITest Parent
|
||
|
{
|
||
|
get { return null; }
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Gets a list of the categories applied to this test
|
||
|
/// </summary>
|
||
|
public IList Categories
|
||
|
{
|
||
|
get { return categories; }
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Gets a list of any child tests
|
||
|
/// </summary>
|
||
|
public virtual IList Tests
|
||
|
{
|
||
|
get { return null; }
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// True if this is a suite, false if a test case
|
||
|
/// </summary>
|
||
|
public bool IsSuite
|
||
|
{
|
||
|
get { return isSuite; }
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Gets the Properties dictionary for this test
|
||
|
/// </summary>
|
||
|
public IDictionary Properties
|
||
|
{
|
||
|
get
|
||
|
{
|
||
|
if ( properties == null )
|
||
|
properties = new ListDictionary();
|
||
|
|
||
|
return properties;
|
||
|
}
|
||
|
}
|
||
|
#endregion
|
||
|
|
||
|
#region Methods
|
||
|
/// <summary>
|
||
|
/// Counts the test cases that would be run if this
|
||
|
/// test were executed using the provided filter.
|
||
|
/// </summary>
|
||
|
/// <param name="filter">The filter to apply</param>
|
||
|
/// <returns>A count of test cases</returns>
|
||
|
public virtual int CountTestCases(ITestFilter filter)
|
||
|
{
|
||
|
if (filter.IsEmpty)
|
||
|
return TestCount;
|
||
|
|
||
|
if (!isSuite)
|
||
|
return filter.Pass(this) ? 1 : 0;
|
||
|
|
||
|
int count = 0;
|
||
|
if (filter.Pass(this))
|
||
|
{
|
||
|
foreach (ITest test in Tests)
|
||
|
{
|
||
|
count += test.CountTestCases(filter);
|
||
|
}
|
||
|
}
|
||
|
return count;
|
||
|
}
|
||
|
#endregion
|
||
|
}
|
||
|
}
|