summaryrefslogtreecommitdiff
path: root/src/Notepad/Infrastructure/Logging
diff options
context:
space:
mode:
Diffstat (limited to 'src/Notepad/Infrastructure/Logging')
-rw-r--r--src/Notepad/Infrastructure/Logging/ILogFactory.cs7
-rw-r--r--src/Notepad/Infrastructure/Logging/ILogger.cs8
-rw-r--r--src/Notepad/Infrastructure/Logging/Log.cs15
-rw-r--r--src/Notepad/Infrastructure/Logging/Log4NetLogging/Log4NetLogFactory.cs20
-rw-r--r--src/Notepad/Infrastructure/Logging/Log4NetLogging/Log4NetLogger.cs20
-rw-r--r--src/Notepad/Infrastructure/Logging/LogSpecs.cs40
6 files changed, 110 insertions, 0 deletions
diff --git a/src/Notepad/Infrastructure/Logging/ILogFactory.cs b/src/Notepad/Infrastructure/Logging/ILogFactory.cs
new file mode 100644
index 0000000..ce1d2e1
--- /dev/null
+++ b/src/Notepad/Infrastructure/Logging/ILogFactory.cs
@@ -0,0 +1,7 @@
+using System;
+
+namespace Notepad.Infrastructure.Logging {
+ public interface ILogFactory {
+ ILogger CreateFor(Type typeToCreateLoggerFor);
+ }
+} \ No newline at end of file
diff --git a/src/Notepad/Infrastructure/Logging/ILogger.cs b/src/Notepad/Infrastructure/Logging/ILogger.cs
new file mode 100644
index 0000000..ac7dd6f
--- /dev/null
+++ b/src/Notepad/Infrastructure/Logging/ILogger.cs
@@ -0,0 +1,8 @@
+using System;
+
+namespace Notepad.Infrastructure.Logging {
+ public interface ILogger {
+ void Informational(string formattedString, params object[] arguments);
+ void Error(Exception e);
+ }
+} \ No newline at end of file
diff --git a/src/Notepad/Infrastructure/Logging/Log.cs b/src/Notepad/Infrastructure/Logging/Log.cs
new file mode 100644
index 0000000..e8a3b4c
--- /dev/null
+++ b/src/Notepad/Infrastructure/Logging/Log.cs
@@ -0,0 +1,15 @@
+using Notepad.Infrastructure.Container;
+using Notepad.Infrastructure.Logging.Log4NetLogging;
+
+namespace Notepad.Infrastructure.Logging {
+ public static class Log {
+ public static ILogger For<T>(T typeToCreateLoggerFor) {
+ try {
+ return Resolve.DependencyFor<ILogFactory>().CreateFor(typeof (T));
+ }
+ catch {
+ return new Log4NetLogFactory().CreateFor(typeof (T));
+ }
+ }
+ }
+} \ No newline at end of file
diff --git a/src/Notepad/Infrastructure/Logging/Log4NetLogging/Log4NetLogFactory.cs b/src/Notepad/Infrastructure/Logging/Log4NetLogging/Log4NetLogFactory.cs
new file mode 100644
index 0000000..0784a13
--- /dev/null
+++ b/src/Notepad/Infrastructure/Logging/Log4NetLogging/Log4NetLogFactory.cs
@@ -0,0 +1,20 @@
+using System;
+using System.IO;
+using log4net;
+using log4net.Config;
+
+namespace Notepad.Infrastructure.Logging.Log4NetLogging {
+ public class Log4NetLogFactory : ILogFactory {
+ public Log4NetLogFactory() {
+ XmlConfigurator.Configure(PathToConfigFile());
+ }
+
+ public ILogger CreateFor(Type typeToCreateLoggerFor) {
+ return new Log4NetLogger(LogManager.GetLogger(typeToCreateLoggerFor));
+ }
+
+ private FileInfo PathToConfigFile() {
+ return new FileInfo(Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "log4net.config.xml"));
+ }
+ }
+} \ No newline at end of file
diff --git a/src/Notepad/Infrastructure/Logging/Log4NetLogging/Log4NetLogger.cs b/src/Notepad/Infrastructure/Logging/Log4NetLogging/Log4NetLogger.cs
new file mode 100644
index 0000000..5111622
--- /dev/null
+++ b/src/Notepad/Infrastructure/Logging/Log4NetLogging/Log4NetLogger.cs
@@ -0,0 +1,20 @@
+using System;
+using log4net;
+
+namespace Notepad.Infrastructure.Logging.Log4NetLogging {
+ public class Log4NetLogger : ILogger {
+ private readonly ILog log;
+
+ public Log4NetLogger(ILog log) {
+ this.log = log;
+ }
+
+ public void Informational(string formattedString, params object[] arguments) {
+ log.InfoFormat(formattedString, arguments);
+ }
+
+ public void Error(Exception e) {
+ log.Error(e.ToString());
+ }
+ }
+} \ No newline at end of file
diff --git a/src/Notepad/Infrastructure/Logging/LogSpecs.cs b/src/Notepad/Infrastructure/Logging/LogSpecs.cs
new file mode 100644
index 0000000..3e6aead
--- /dev/null
+++ b/src/Notepad/Infrastructure/Logging/LogSpecs.cs
@@ -0,0 +1,40 @@
+using MbUnit.Framework;
+using Notepad.Infrastructure.Container;
+using Rhino.Mocks;
+
+namespace Notepad.Infrastructure.Logging {
+ public class LogSpecs {}
+
+ [TestFixture]
+ public class when_creating_a_logger_for_a_particular_type_ {
+ private MockRepository mockery;
+ private ILogFactory factory;
+
+ [SetUp]
+ public void SetUp() {
+ mockery = new MockRepository();
+ factory = mockery.DynamicMock<ILogFactory>();
+
+ var resolver = mockery.DynamicMock<IDependencyRegistry>();
+ SetupResult.For(resolver.FindAnImplementationOf<ILogFactory>()).Return(factory);
+
+ Resolve.InitializeWith(resolver);
+ }
+
+ [Test]
+ public void should_leverage_the_log_factory_to_create_a_logger_for_the_given_type() {
+ var logger = mockery.DynamicMock<ILogger>();
+ using (mockery.Record()) {
+ Expect
+ .Call(factory.CreateFor(GetType()))
+ .Return(logger)
+ .Repeat
+ .AtLeastOnce();
+ }
+
+ using (mockery.Playback()) {
+ Log.For(this);
+ }
+ }
+ }
+} \ No newline at end of file