// **************************************************************** // This is free software licensed under the NUnit license. You // may obtain a copy of the license as well as information regarding // copyright ownership at http://nunit.org/?p=license&r=2.4. // **************************************************************** namespace NUnit.Core { using System; using System.Collections; using System.IO; /// /// DelegatingTestRUnner is the abstract base for core TestRunner /// implementations that operate by controlling a downstream /// TestRunner. All calls are simply passed on to the /// TestRunner that is provided to the constructor. /// /// Although the class is abstract, it has no abstract /// methods specified because each implementation will /// need to override different methods. All methods are /// specified using interface syntax and the derived class /// must explicitly implement TestRunner in order to /// redefine the selected methods. /// public abstract class DelegatingTestRunner : MarshalByRefObject, TestRunner { #region Instance Variables /// /// Our runner ID /// protected int runnerID; /// /// The downstream TestRunner /// private TestRunner testRunner; /// /// The event listener for the currently running test /// protected EventListener listener; #endregion #region Construction public DelegatingTestRunner(TestRunner testRunner) { this.testRunner = testRunner; this.runnerID = testRunner.ID; } /// /// Protected constructor for runners that delay creation /// of their downstream runner. /// protected DelegatingTestRunner( int runnerID ) { this.runnerID = runnerID; } #endregion #region Properties public virtual int ID { get { return runnerID; } } public virtual bool Running { get { return testRunner != null && testRunner.Running; } } public virtual IList AssemblyInfo { get { return testRunner == null ? null : testRunner.AssemblyInfo; } } public virtual ITest Test { get { return testRunner == null ? null : testRunner.Test; } } public virtual TestResult TestResult { get { return testRunner == null ? null : testRunner.TestResult; } } /// /// Protected property copies any settings to the downstream test runner /// when it is set. Derived runners overriding this should call the base /// or copy the settings themselves. /// protected virtual TestRunner TestRunner { get { return testRunner; } set { testRunner = value; } } #endregion #region Load and Unload Methods public virtual bool Load( TestPackage package ) { return this.testRunner.Load( package ); } public virtual void Unload() { if ( this.testRunner != null ) this.testRunner.Unload(); } #endregion #region CountTestCases public virtual int CountTestCases( ITestFilter filter ) { return this.testRunner.CountTestCases( filter ); } #endregion #region Methods for Running Tests public virtual TestResult Run(EventListener listener) { // Save active listener for derived classes this.listener = listener; return this.testRunner.Run(listener); } public virtual TestResult Run(EventListener listener, ITestFilter filter) { // Save active listener for derived classes this.listener = listener; return this.testRunner.Run(listener, filter); } public virtual void BeginRun( EventListener listener ) { // Save active listener for derived classes this.listener = listener; this.testRunner.BeginRun( listener ); } public virtual void BeginRun( EventListener listener, ITestFilter filter ) { // Save active listener for derived classes this.listener = listener; this.testRunner.BeginRun( listener, filter ); } public virtual TestResult EndRun() { return this.testRunner.EndRun(); } public virtual void CancelRun() { this.testRunner.CancelRun(); } public virtual void Wait() { this.testRunner.Wait(); } #endregion #region InitializeLifetimeService Override public override object InitializeLifetimeService() { return null; } #endregion } }