You've already forked linux-packaging-mono
							
							
		
			
				
	
	
		
			210 lines
		
	
	
		
			6.6 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			210 lines
		
	
	
		
			6.6 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.IO;
 | |
| using System.Collections;
 | |
| 
 | |
| namespace NUnit.Framework.Constraints
 | |
| {
 | |
| 	/// <summary>
 | |
| 	/// The Constraint class is the base of all built-in or
 | |
| 	/// user-defined constraints in NUnit. It provides the operator
 | |
| 	/// overloads used to combine constraints.
 | |
| 	/// </summary>
 | |
|     public abstract class Constraint
 | |
|     {
 | |
|         #region UnsetObject Class
 | |
|         /// <summary>
 | |
|         /// Class used to detect any derived constraints
 | |
|         /// that fail to set the actual value in their
 | |
|         /// Matches override.
 | |
|         /// </summary>
 | |
|         private class UnsetObject
 | |
|         {
 | |
|             public override string ToString()
 | |
|             {
 | |
|                 return "UNSET";
 | |
|             }
 | |
|         }
 | |
|         #endregion
 | |
| 
 | |
| 		#region Static and Instance Fields
 | |
|         /// <summary>
 | |
|         /// Static UnsetObject used to detect derived constraints
 | |
|         /// failing to set the actual value.
 | |
|         /// </summary>
 | |
|         protected static object UNSET = new UnsetObject();
 | |
| 
 | |
| 		/// <summary>
 | |
| 		/// If true, all string comparisons will ignore case
 | |
| 		/// </summary>
 | |
| 		protected bool caseInsensitive;
 | |
| 
 | |
|         /// <summary>
 | |
|         /// If true, strings in error messages will be clipped
 | |
|         /// </summary>
 | |
|         protected bool clipStrings = true;
 | |
| 
 | |
| 		/// <summary>
 | |
| 		/// If true, arrays will be treated as collections, allowing
 | |
| 		/// those of different dimensions to be compared
 | |
| 		/// </summary>
 | |
| 		protected bool compareAsCollection;
 | |
| 
 | |
| 		/// <summary>
 | |
| 		/// If non-zero, equality comparisons within the specified 
 | |
| 		/// tolerance will succeed.
 | |
| 		/// </summary>
 | |
| 		protected object tolerance;
 | |
| 
 | |
|         /// <summary>
 | |
|         /// IComparer object used in comparisons for some constraints.
 | |
|         /// </summary>
 | |
|         protected IComparer compareWith;
 | |
| 
 | |
| 		/// <summary>
 | |
|         /// The actual value being tested against a constraint
 | |
|         /// </summary>
 | |
|         protected object actual = UNSET;
 | |
|         #endregion
 | |
| 
 | |
|         #region Properties
 | |
|         /// <summary>
 | |
| 		/// Flag the constraint to ignore case and return self.
 | |
| 		/// </summary>
 | |
| 		public virtual Constraint IgnoreCase
 | |
| 		{
 | |
| 			get
 | |
| 			{
 | |
| 				caseInsensitive = true;
 | |
| 				return this;
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Flag the constraint to suppress string clipping 
 | |
|         /// and return self.
 | |
|         /// </summary>
 | |
|         public Constraint NoClip
 | |
|         {
 | |
|             get
 | |
|             {
 | |
|                 clipStrings = false;
 | |
|                 return this;
 | |
|             }
 | |
|         }
 | |
| 
 | |
| 		/// <summary>
 | |
| 		/// Flag the constraint to compare arrays as collections
 | |
| 		/// and return self.
 | |
| 		/// </summary>
 | |
| 		public Constraint AsCollection
 | |
| 		{
 | |
| 			get
 | |
| 			{
 | |
| 				compareAsCollection = true;
 | |
| 				return this;
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Flag the constraint to use a tolerance when determining equality.
 | |
|         /// Currently only used for doubles and floats.
 | |
|         /// </summary>
 | |
|         /// <param name="tolerance">Tolerance to be used</param>
 | |
|         /// <returns>Self.</returns>
 | |
|         public Constraint Within(object tolerance)
 | |
| 		{
 | |
| 			this.tolerance = tolerance;
 | |
| 			return this;
 | |
| 		}
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Flag the constraint to use the supplied IComparer object.
 | |
|         /// </summary>
 | |
|         /// <param name="comparer">The IComparer object to use.</param>
 | |
|         /// <returns>Self.</returns>
 | |
|         public Constraint Comparer(IComparer comparer)
 | |
|         {
 | |
|             this.compareWith = comparer;
 | |
|             return this;
 | |
|         }
 | |
| 		#endregion
 | |
| 
 | |
| 		#region Public Methods
 | |
|         /// <summary>
 | |
|         /// Write the failure message to the MessageWriter provided
 | |
|         /// as an argument. The default implementation simply passes
 | |
|         /// the constraint and the actual value to the writer, which
 | |
|         /// then displays the constraint description and the value.
 | |
|         /// 
 | |
|         /// Constraints that need to provide additional details,
 | |
|         /// such as where the error occured can override this.
 | |
|         /// </summary>
 | |
|         /// <param name="writer">The MessageWriter on which to display the message</param>
 | |
|         public virtual void WriteMessageTo(MessageWriter writer)
 | |
|         {
 | |
|             writer.DisplayDifferences(this);
 | |
|         }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Test whether the constraint is satisfied by a given value
 | |
|         /// </summary>
 | |
|         /// <param name="actual">The value to be tested</param>
 | |
|         /// <returns>True for success, false for failure</returns>
 | |
|         public abstract bool Matches(object actual);
 | |
| 
 | |
|         /// <summary>
 | |
|         /// Write the constraint description to a MessageWriter
 | |
|         /// </summary>
 | |
|         /// <param name="writer">The writer on which the description is displayed</param>
 | |
|         public abstract void WriteDescriptionTo(MessageWriter writer);
 | |
| 
 | |
| 		/// <summary>
 | |
| 		/// Write the actual value for a failing constraint test to a
 | |
| 		/// MessageWriter. The default implementation simply writes
 | |
| 		/// the raw value of actual, leaving it to the writer to
 | |
| 		/// perform any formatting.
 | |
| 		/// </summary>
 | |
| 		/// <param name="writer">The writer on which the actual value is displayed</param>
 | |
| 		public virtual void WriteActualValueTo(MessageWriter writer)
 | |
| 		{
 | |
| 			writer.WriteActualValue( actual );
 | |
| 		}
 | |
| 		#endregion
 | |
| 
 | |
|         #region Operator Overloads
 | |
|         /// <summary>
 | |
|         /// This operator creates a constraint that is satisfied only if both 
 | |
|         /// argument constraints are satisfied.
 | |
|         /// </summary>
 | |
|         public static Constraint operator &(Constraint left, Constraint right)
 | |
|         {
 | |
|             return new AndConstraint(left, right);
 | |
|         }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// This operator creates a constraint that is satisfied if either 
 | |
|         /// of the argument constraints is satisfied.
 | |
|         /// </summary>
 | |
|         public static Constraint operator |(Constraint left, Constraint right)
 | |
|         {
 | |
|             return new OrConstraint(left, right);
 | |
|         }
 | |
| 
 | |
|         /// <summary>
 | |
|         /// This operator creates a constraint that is satisfied if the 
 | |
|         /// argument constraint is not satisfied.
 | |
|         /// </summary>
 | |
|         public static Constraint operator !(Constraint m)
 | |
|         {
 | |
|             return new NotConstraint(m == null ? new EqualConstraint(null) : m);
 | |
|         }
 | |
|         #endregion
 | |
| 	}
 | |
| }
 |