Merge pull request #799 from kebby/master
[mono.git] / mcs / class / Microsoft.Build / Test / Microsoft.Build.Logging / ConsoleLoggerTest.cs
1
2 using System;
3 using System.IO;
4 using Microsoft.Build.Framework;
5 using Microsoft.Build.Logging;
6 using NUnit.Framework;
7
8 namespace MonoTests.Microsoft.Build.Logging
9 {
10         [TestFixture]
11         public class ConsoleLoggerTest
12         {
13                 [Test]
14                 public void BasicLoggerUsage ()
15                 {
16                         string expected = @"file : cat error code: msg
17
18 file : cat warning code: msg
19
20 __________________________________________________
21
22 Project ""project.txt"" (target target(s)):
23
24
25
26 Build started 2013/01/01 00:00:00.
27
28 Target ""target"" in file ""target.txt"":
29
30   start task
31
32   finished task
33
34 finished target
35
36
37
38 finished project
39
40
41
42 finished build
43
44
45
46 Time Elapsed 00:00:00.01
47
48 ".Replace ("\r\n", "\n");
49                         var sw = new StringWriter();
50                         var e = new ConsoleLogger(LoggerVerbosity.Diagnostic, msg => sw.WriteLine(msg), c => {}, () => {});
51                         e.Verbosity = LoggerVerbosity.Diagnostic;
52                         e.ErrorHandler (null, new BuildErrorEventArgs ("cat", "code", "file", 0, 0, 0, 0, "msg", "help", "sender"));
53                         e.WarningHandler (null, new BuildWarningEventArgs ("cat", "code", "file", 0, 0, 0, 0, "msg", "help", "sender"));
54                         e.ProjectStartedHandler (null, new ProjectStartedEventArgs ("start project", "HELPME", "project.txt", "target", null, null));
55                         e.BuildStartedHandler (null, new BuildStartedEventArgs ("start build", "HELPME", new DateTime (2013, 1, 1)));
56                         e.TargetStartedHandler (null, new TargetStartedEventArgs ("start target", "HELPME", "target", "project.txt", "target.txt"/*, "parent"*/));
57                         e.TaskStartedHandler (null, new TaskStartedEventArgs ("start task", "HELPME", "project.txt", "task.txt", "task"));
58                         e.TaskFinishedHandler (null, new TaskFinishedEventArgs ("finished task", "HELPME", "project.txt", "task.txt", "task", false));
59                         e.TargetFinishedHandler (null, new TargetFinishedEventArgs ("finished target", "HELPME", "target", "project.txt", "target.txt", false));
60                         e.ProjectFinishedHandler (null, new ProjectFinishedEventArgs ("finished project", "HELPME", "project.txt", false));
61                         e.BuildFinishedHandler (null, new BuildFinishedEventArgs ("finished build", "HELPME", false, new DateTime (2013, 1, 1).AddMilliseconds (1)));
62
63                         e.CustomEventHandler(null, new MyCustomBuildEventArgs ());
64                         Assert.AreEqual (expected, sw.ToString ().Replace ("\r\n", "\n"), "#1");
65                 }
66         }
67         
68         class MyCustomBuildEventArgs : CustomBuildEventArgs
69         {
70         }
71 }
72