2007-04-19 Atsushi Enomoto <atsushi@ximian.com>
[mono.git] / mcs / class / System / Test / System.Diagnostics / TraceListenerTest.cs
1 //
2 // TraceListenerTest.cs
3 //
4 // Author:
5 //      Atsushi Enomoto  <atsushi@ximian.com>
6 //
7 // Copyright (C) 2007 Novell, Inc.
8 //
9
10 //
11 // Permission is hereby granted, free of charge, to any person obtaining
12 // a copy of this software and associated documentation files (the
13 // "Software"), to deal in the Software without restriction, including
14 // without limitation the rights to use, copy, modify, merge, publish,
15 // distribute, sublicense, and/or sell copies of the Software, and to
16 // permit persons to whom the Software is furnished to do so, subject to
17 // the following conditions:
18 // 
19 // The above copyright notice and this permission notice shall be
20 // included in all copies or substantial portions of the Software.
21 // 
22 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
23 // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
24 // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
25 // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
26 // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
27 // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
28 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
29 //
30
31 using NUnit.Framework;
32 using System;
33 using System.IO;
34 using System.Diagnostics;
35 using System.Threading;
36
37 namespace MonoTests.System.Diagnostics
38 {
39         [TestFixture]
40         public class TraceListenerTest
41         {
42 #if NET_2_0
43                 [Test]
44                 public void TraceEventAndTraceData ()
45                 {
46                         StringWriter sw = new StringWriter ();
47                         TextWriterTraceListener t = new TextWriterTraceListener (sw);
48                         t.TraceEvent (null, null, TraceEventType.Error, 0, null);
49                         t.TraceEvent (null, "bulldog", TraceEventType.Error, 0);
50                         TraceEventCache cc = new TraceEventCache ();
51                         t.TraceData (cc, null, TraceEventType.Error, 0);
52                         t.TraceData (cc, null, TraceEventType.Error, 0);
53                         t.TraceTransfer (null, "bulldog", 0, "hoge", Guid.Empty);
54                         t.Close ();
55                         string expected = @" Error: 0 : 
56 bulldog Error: 0 : 
57  Error: 0 : 
58  Error: 0 : 
59 bulldog Transfer: 0 : hoge, relatedActivityId=00000000-0000-0000-0000-000000000000
60 ";
61                         Assert.AreEqual (expected, sw.ToString ().Replace ("\r\n", "\n"));
62                 }
63 #endif
64         }
65 }
66