1 // ***********************************************************************
2 // Copyright (c) 2015 Charlie Poole
4 // Permission is hereby granted, free of charge, to any person obtaining
5 // a copy of this software and associated documentation files (the
6 // "Software"), to deal in the Software without restriction, including
7 // without limitation the rights to use, copy, modify, merge, publish,
8 // distribute, sublicense, and/or sell copies of the Software, and to
9 // permit persons to whom the Software is furnished to do so, subject to
10 // the following conditions:
12 // The above copyright notice and this permission notice shall be
13 // included in all copies or substantial portions of the Software.
15 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
16 // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
17 // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
18 // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
19 // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
20 // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
21 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
22 // ***********************************************************************
25 #define NUNIT_FRAMEWORK
30 using System.Collections.Generic;
31 using NUnit.Framework.Interfaces;
33 namespace NUnit.Framework.Internal.Filters
36 /// A base class for multi-part filters
38 public abstract class CompositeFilter : TestFilter
41 /// Constructs an empty CompositeFilter
43 public CompositeFilter()
45 Filters = new List<ITestFilter>();
49 /// Constructs a CompositeFilter from an array of filters
51 /// <param name="filters"></param>
52 public CompositeFilter( params ITestFilter[] filters )
54 Filters = new List<ITestFilter>(filters);
58 /// Adds a filter to the list of filters
60 /// <param name="filter">The filter to be added</param>
61 public void Add(ITestFilter filter)
67 /// Return a list of the composing filters.
69 public IList<ITestFilter> Filters { get; private set; }
72 /// Checks whether the CompositeFilter is matched by a test.
74 /// <param name="test">The test to be matched</param>
75 public abstract override bool Pass(ITest test);
78 /// Checks whether the CompositeFilter is matched by a test.
80 /// <param name="test">The test to be matched</param>
81 public abstract override bool Match(ITest test);
84 /// Checks whether the CompositeFilter is explicit matched by a test.
86 /// <param name="test">The test to be matched</param>
87 public abstract override bool IsExplicitMatch(ITest test);
92 /// <param name="parentNode">Parent node</param>
93 /// <param name="recursive">True if recursive</param>
94 /// <returns>The added XML node</returns>
95 public override TNode AddToXml(TNode parentNode, bool recursive)
97 TNode result = parentNode.AddElement(ElementName);
100 foreach (ITestFilter filter in Filters)
101 filter.AddToXml(result, true);
107 /// Gets the element name
109 /// <value>Element name</value>
110 protected abstract string ElementName { get; }