You've already forked linux-packaging-mono
							
							
		
			
				
	
	
		
			185 lines
		
	
	
		
			6.1 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			185 lines
		
	
	
		
			6.1 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| //
 | |
| // SourceSwitchTest.cs
 | |
| //
 | |
| // Author:
 | |
| //	Atsushi Enomoto  <atsushi@ximian.com>
 | |
| //
 | |
| // Copyright (C) 2007 Novell, Inc.
 | |
| //
 | |
| 
 | |
| //
 | |
| // Permission is hereby granted, free of charge, to any person obtaining
 | |
| // a copy of this software and associated documentation files (the
 | |
| // "Software"), to deal in the Software without restriction, including
 | |
| // without limitation the rights to use, copy, modify, merge, publish,
 | |
| // distribute, sublicense, and/or sell copies of the Software, and to
 | |
| // permit persons to whom the Software is furnished to do so, subject to
 | |
| // the following conditions:
 | |
| // 
 | |
| // The above copyright notice and this permission notice shall be
 | |
| // included in all copies or substantial portions of the Software.
 | |
| // 
 | |
| // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
 | |
| // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
 | |
| // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
 | |
| // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
 | |
| // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
 | |
| // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
 | |
| // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 | |
| //
 | |
| 
 | |
| 
 | |
| #if !MOBILE
 | |
| 
 | |
| #define TRACE
 | |
| 
 | |
| using NUnit.Framework;
 | |
| using System;
 | |
| using System.Text;
 | |
| using System.Collections;
 | |
| using System.Configuration;
 | |
| using System.Diagnostics;
 | |
| 
 | |
| namespace MonoTests.System.Diagnostics
 | |
| {
 | |
| 	[TestFixture]
 | |
| 	public class SourceSwitchTest
 | |
| 	{
 | |
| 		internal TraceSource traceSource { get; set; }
 | |
| 		internal TestTextWriterTraceListener txtTraceListener;
 | |
| 
 | |
| 
 | |
| 		[Test]
 | |
| 		public void ConstructorNullName ()
 | |
| 		{
 | |
| 			SourceSwitch s = new SourceSwitch (null);
 | |
| 			AssertHelper.IsEmpty (s.DisplayName);
 | |
| 		}
 | |
| 
 | |
| 		[Test]
 | |
| 		public void ConstructorNullDefaultValue ()
 | |
| 		{
 | |
| 			SourceSwitch s = new SourceSwitch ("foo", null);
 | |
| 		}
 | |
| 
 | |
| 		[Test]
 | |
| 		public void ConstructorDefault ()
 | |
| 		{
 | |
| 			SourceSwitch s = new SourceSwitch ("foo");
 | |
| 			Assert.AreEqual ("foo", s.DisplayName, "#1");
 | |
| 			Assert.AreEqual (SourceLevels.Off, s.Level, "#2");
 | |
| 			Assert.AreEqual (0, s.Attributes.Count, "#3");
 | |
| 		}
 | |
| 
 | |
| 		[Test]
 | |
| 		public void ShouldTrace ()
 | |
| 		{
 | |
| 			SourceSwitch s = new SourceSwitch ("foo");
 | |
| 			s.Level = SourceLevels.Verbose;
 | |
| 			Assert.IsTrue (s.ShouldTrace (TraceEventType.Critical), "#1");
 | |
| 			Assert.IsTrue (s.ShouldTrace (TraceEventType.Error), "#2");
 | |
| 			Assert.IsTrue (s.ShouldTrace (TraceEventType.Warning), "#3");
 | |
| 			Assert.IsTrue (s.ShouldTrace (TraceEventType.Information), "#4");
 | |
| 			Assert.IsTrue (s.ShouldTrace (TraceEventType.Verbose), "#5");
 | |
| 			Assert.IsFalse (s.ShouldTrace (TraceEventType.Start), "#6");
 | |
| 			Assert.IsFalse (s.ShouldTrace (TraceEventType.Stop), "#7");
 | |
| 			Assert.IsFalse (s.ShouldTrace (TraceEventType.Suspend), "#8");
 | |
| 			Assert.IsFalse (s.ShouldTrace (TraceEventType.Resume), "#9");
 | |
| 			Assert.IsFalse (s.ShouldTrace (TraceEventType.Transfer), "#10");
 | |
| 		}
 | |
| 
 | |
| 		[Test]
 | |
| 		public void ShouldTrace2 ()
 | |
| 		{
 | |
| 			SourceSwitch s = new SourceSwitch ("foo");
 | |
| 			s.Level = SourceLevels.ActivityTracing;
 | |
| 			Assert.IsFalse (s.ShouldTrace (TraceEventType.Critical), "#1");
 | |
| 			Assert.IsFalse (s.ShouldTrace (TraceEventType.Error), "#2");
 | |
| 			Assert.IsFalse (s.ShouldTrace (TraceEventType.Warning), "#3");
 | |
| 			Assert.IsFalse (s.ShouldTrace (TraceEventType.Information), "#4");
 | |
| 			Assert.IsFalse (s.ShouldTrace (TraceEventType.Verbose), "#5");
 | |
| 			Assert.IsTrue (s.ShouldTrace (TraceEventType.Start), "#6");
 | |
| 			Assert.IsTrue (s.ShouldTrace (TraceEventType.Stop), "#7");
 | |
| 			Assert.IsTrue (s.ShouldTrace (TraceEventType.Suspend), "#8");
 | |
| 			Assert.IsTrue (s.ShouldTrace (TraceEventType.Resume), "#9");
 | |
| 			Assert.IsTrue (s.ShouldTrace (TraceEventType.Transfer), "#10");
 | |
| 		}
 | |
| 
 | |
| 
 | |
| 		[SetUp]						
 | |
| 		public void InitalizeSourceSwitchTest()
 | |
| 		{
 | |
| 			// Initializing the TraceSource instance
 | |
| 			traceSource = new TraceSource ("LoggingTraceSource");
 | |
| 			traceSource.Listeners.Remove("Default");
 | |
| 			traceSource.Switch = new SourceSwitch ("MySwitch");
 | |
| 
 | |
| 			// Initializing the TraceListener instance
 | |
| 			txtTraceListener = new TestTextWriterTraceListener (Console.Out);
 | |
| 			traceSource.Listeners.Add (txtTraceListener); 
 | |
| 		}
 | |
| 
 | |
| 		[Test]						
 | |
| 		public void setSwitchToCritical()
 | |
| 		{
 | |
| 			traceSource.Switch.Level = SourceLevels.Critical;
 | |
| 			LogAllTraceLevels ();
 | |
| 			// Switch.Level is Critical so it should log Critical
 | |
| 			Assert.AreEqual (1, txtTraceListener.TotalMessageCount);
 | |
| 			Assert.AreEqual (1, txtTraceListener.CritialMessageCount);
 | |
| 		}
 | |
| 			
 | |
| 		[Test]						
 | |
| 		public void setSwitchToError()
 | |
| 		{
 | |
| 			traceSource.Switch.Level = SourceLevels.Error;
 | |
| 			LogAllTraceLevels ();
 | |
| 			// Switch.Level is Error so it should log Critical, Error
 | |
| 			Assert.AreEqual (2, txtTraceListener.TotalMessageCount);
 | |
| 			Assert.AreEqual (1, txtTraceListener.ErrorMessageCount);
 | |
| 		}
 | |
| 
 | |
| 		[Test]						
 | |
| 		public void setSwitchToWarning()
 | |
| 		{
 | |
| 			traceSource.Switch.Level = SourceLevels.Warning;
 | |
| 			LogAllTraceLevels ();
 | |
| 			// Switch.Level is Warning so it should log Critical, Error, Warning
 | |
| 			Assert.AreEqual (3, txtTraceListener.TotalMessageCount);
 | |
| 			Assert.AreEqual (1, txtTraceListener.WarningMessageCount);
 | |
| 		}
 | |
| 
 | |
| 		[Test]						
 | |
| 		public void setSwitchToInfo()
 | |
| 		{
 | |
| 			traceSource.Switch.Level = SourceLevels.Information;
 | |
| 			LogAllTraceLevels ();
 | |
| 			// Switch.Level is Information so it should log Critical, Error, Warning, Information
 | |
| 			Assert.AreEqual (4, txtTraceListener.TotalMessageCount);
 | |
| 			Assert.AreEqual (1, txtTraceListener.InfoMessageCount);
 | |
| 		}
 | |
| 
 | |
| 		[Test]						
 | |
| 		public void setSwitchToVerbose()
 | |
| 		{
 | |
| 			traceSource.Switch.Level = SourceLevels.Verbose;
 | |
| 			LogAllTraceLevels ();
 | |
| 			// Switch.Level is Verbose so it should log Critical, Error, Warning, Information, Verbose
 | |
| 			Assert.AreEqual (5, txtTraceListener.TotalMessageCount);
 | |
| 			Assert.AreEqual (1, txtTraceListener.VerboseMessageCount);
 | |
| 		}
 | |
| 
 | |
| 		void LogAllTraceLevels ()
 | |
| 		{
 | |
| 			traceSource.TraceEvent (TraceEventType.Critical, 123, "Critical Level message.");
 | |
| 			traceSource.TraceEvent (TraceEventType.Error, 123, "Error Level message.");
 | |
| 			traceSource.TraceEvent (TraceEventType.Warning, 123, "Warning Level message.");
 | |
| 			traceSource.TraceEvent (TraceEventType.Information, 123, "Information Level message.");
 | |
| 			traceSource.TraceEvent (TraceEventType.Verbose, 123, "Verbose Level message.");
 | |
| 			traceSource.Flush ();
 | |
| 		}
 | |
| 	}
 | |
| }
 | |
| 
 | |
| #endif
 |