forked from nhibernate/nhibernate-core
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathLogSpy.cs
76 lines (64 loc) · 1.98 KB
/
LogSpy.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
using System;
using System.Collections.Generic;
using System.Text;
using log4net;
using log4net.Appender;
using log4net.Core;
using log4net.Repository.Hierarchy;
namespace NHibernate.Test
{
public class LogSpy : IDisposable
{
private readonly MemoryAppender appender;
private readonly Logger logger;
private readonly Level prevLogLevel;
public LogSpy(ILog log, Level level)
{
logger = log.Logger as Logger;
if (logger == null)
{
throw new Exception("Unable to get the logger");
}
// Change the log level to DEBUG and temporarily save the previous log level
prevLogLevel = logger.Level;
logger.Level = level;
// Add a new MemoryAppender to the logger.
appender = new MemoryAppender();
logger.AddAppender(appender);
}
public LogSpy(ILog log, bool disable)
: this(log, disable ? Level.Off : Level.Debug)
{
}
public LogSpy(ILog log) : this(log, false) { }
public LogSpy(System.Type loggerType) : this(LogManager.GetLogger(loggerType), false) { }
public LogSpy(System.Type loggerType, bool disable) : this(LogManager.GetLogger(loggerType), disable) { }
public LogSpy(string loggerName) : this(LogManager.GetLogger(loggerName), false) { }
public LogSpy(string loggerName, bool disable) : this(LogManager.GetLogger(loggerName), disable) { }
public MemoryAppender Appender
{
get { return appender; }
}
public virtual string GetWholeLog()
{
var wholeMessage = new StringBuilder();
foreach (LoggingEvent loggingEvent in Appender.GetEvents())
{
wholeMessage
.Append(loggingEvent.LoggerName)
.Append(" ")
.Append(loggingEvent.RenderedMessage)
.AppendLine();
}
return wholeMessage.ToString();
}
#region IDisposable Members
public void Dispose()
{
// Restore the previous log level of the SQL logger and remove the MemoryAppender
logger.Level = prevLogLevel;
logger.RemoveAppender(appender);
}
#endregion
}
}