89 lines
2.5 KiB
C#
Raw Normal View History

// ****************************************************************
// 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;
namespace NUnit.Core
{
/// <summary>
/// TestNode represents a single test or suite in the test hierarchy.
/// TestNode holds common info needed about a test and represents a
/// single node - either a test or a suite - in the hierarchy of tests.
///
/// TestNode extends TestInfo, which holds all the information with
/// the exception of the list of child classes. When constructed from
/// a Test, TestNodes are always fully populated with child TestNodes.
///
/// Like TestInfo, TestNode is purely a data class, and is not able
/// to execute tests.
///
/// </summary>
[Serializable]
public class TestNode : TestInfo
{
#region Instance Variables
private ITest parent;
/// <summary>
/// For a test suite, the child tests or suites
/// Null if this is not a test suite
/// </summary>
private ArrayList tests;
#endregion
#region Constructors
/// <summary>
/// Construct from an ITest
/// </summary>
/// <param name="test">Test from which a TestNode is to be constructed</param>
public TestNode ( ITest test ) : base( test )
{
if ( test.IsSuite )
{
this.tests = new ArrayList();
foreach( ITest child in test.Tests )
{
TestNode node = new TestNode( child );
this.Tests.Add( node );
node.parent = this;
}
}
}
/// <summary>
/// Construct a TestNode given a TestName and an
/// array of child tests.
/// </summary>
/// <param name="testName">The TestName of the new test</param>
/// <param name="tests">An array of tests to be added as children of the new test</param>
public TestNode ( TestName testName, ITest[] tests ) : base( testName, tests )
{
this.tests = new ArrayList();
this.tests.AddRange( tests );
}
#endregion
#region Properties
/// <summary>
/// Gets the parent test of the current test
/// </summary>
public override ITest Parent
{
get { return parent; }
}
/// <summary>
/// Array of child tests, null if this is a test case.
/// </summary>
public override IList Tests
{
get { return tests; }
}
#endregion
}
}