| 
									
										
										
										
											2014-08-13 10:39:27 +01:00
										 |  |  | // | 
					
						
							|  |  |  | // 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 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-13 10:44:36 +00:00
										 |  |  | #define TRACE | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-08-13 10:39:27 +01:00
										 |  |  | 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 | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2015-01-13 10:44:36 +00:00
										 |  |  | 		internal TraceSource traceSource { get; set; } | 
					
						
							|  |  |  | 		internal TestTextWriterTraceListener txtTraceListener; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-08-13 10:39:27 +01:00
										 |  |  | 		[Test] | 
					
						
							|  |  |  | 		public void ConstructorNullName () | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			SourceSwitch s = new SourceSwitch (null); | 
					
						
							| 
									
										
										
										
											2015-01-13 10:44:36 +00:00
										 |  |  | 			Assert.IsEmpty (s.DisplayName); | 
					
						
							| 
									
										
										
										
											2014-08-13 10:39:27 +01:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		[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"); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2015-01-13 10:44:36 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		[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 (); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2014-08-13 10:39:27 +01:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif |