diff options
| author | mo <mo.khan@gmail.com> | 2018-11-04 15:22:16 -0700 |
|---|---|---|
| committer | mo <mo.khan@gmail.com> | 2018-11-04 15:22:16 -0700 |
| commit | 5ee1f55497a4e30322a56f133f897ecde1612967 (patch) | |
| tree | bf544e0879234c3623869627d8786776cb19b8e9 /src/Notepad/Infrastructure/Logging | |
Diffstat (limited to 'src/Notepad/Infrastructure/Logging')
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 |
