diff --git a/NzbDrone.Core.Test/EpisodeProviderTest.cs b/NzbDrone.Core.Test/EpisodeProviderTest.cs
index 91caa7b55..d4fa50f60 100644
--- a/NzbDrone.Core.Test/EpisodeProviderTest.cs
+++ b/NzbDrone.Core.Test/EpisodeProviderTest.cs
@@ -8,6 +8,7 @@
namespace NzbDrone.Core.Test
{
[TestFixture]
+ // ReSharper disable InconsistentNaming
public class EpisodeProviderTest
{
diff --git a/NzbDrone.Core.Test/NzbDrone.Core.Test.csproj b/NzbDrone.Core.Test/NzbDrone.Core.Test.csproj
index 39440695a..357ecb3b9 100644
--- a/NzbDrone.Core.Test/NzbDrone.Core.Test.csproj
+++ b/NzbDrone.Core.Test/NzbDrone.Core.Test.csproj
@@ -74,6 +74,7 @@
+
diff --git a/NzbDrone.Core.Test/QualityProfileTest.cs b/NzbDrone.Core.Test/QualityProfileTest.cs
index 9e3d0e47f..921162da2 100644
--- a/NzbDrone.Core.Test/QualityProfileTest.cs
+++ b/NzbDrone.Core.Test/QualityProfileTest.cs
@@ -7,6 +7,8 @@
namespace NzbDrone.Core.Test
{
[TestFixture]
+ // ReSharper disable InconsistentNaming
+
public class QualityProfileTest
{
///
diff --git a/NzbDrone.Core.Test/RepoTest.cs b/NzbDrone.Core.Test/RepoTest.cs
new file mode 100644
index 000000000..f5a0d742c
--- /dev/null
+++ b/NzbDrone.Core.Test/RepoTest.cs
@@ -0,0 +1,59 @@
+using System;
+using System.Collections.Generic;
+using System.Linq;
+using System.Text;
+using FizzWare.NBuilder;
+using Gallio.Framework;
+using MbUnit.Framework;
+using MbUnit.Framework.ContractVerifiers;
+using NzbDrone.Core.Repository;
+using NzbDrone.Core.Repository.Episode;
+
+namespace NzbDrone.Core.Test
+{
+ [TestFixture]
+ // ReSharper disable InconsistentNaming
+ public class RepoTest
+ {
+ [Test]
+ public void to_many__series_to_episode()
+ {
+ //Arrange
+ var fakeSeries = Builder.CreateNew().With(s => s.SeriesId = 69).Build();
+ var fakeEpisode = Builder.CreateNew().With(c => c.SeriesId = 69).Build();
+
+ //Act
+ var repo = MockLib.GetEmptyRepository();
+ repo.Add(fakeSeries);
+ repo.Add(fakeEpisode);
+ var fetchedSeries = repo.Single(fakeSeries.SeriesId);
+
+ //Assert
+ Assert.AreEqual(fakeSeries.SeriesId, fetchedSeries.SeriesId);
+ Assert.AreEqual(fakeSeries.Title, fetchedSeries.Title);
+
+ Assert.IsNotEmpty(fetchedSeries.Episodes);
+ Assert.AreEqual(fetchedSeries.Episodes[0].EpisodeId, fakeEpisode.EpisodeId);
+ Assert.AreEqual(fetchedSeries.Episodes[0].SeriesId, fakeEpisode.SeriesId);
+ Assert.AreEqual(fetchedSeries.Episodes[0].Title, fakeEpisode.Title);
+ }
+
+ [Test]
+ [Description("This test confirms that the tvdb id stored in the db is preserved rather than being replaced by an auto incrementing value")]
+ public void tvdbid_is_preserved([RandomNumbers(Minimum = 100, Maximum = 999, Count = 1)] int tvdbId)
+ {
+ //Arrange
+ var sonicRepo = MockLib.GetEmptyRepository();
+ var series = Builder.CreateNew().With(c => c.SeriesId = tvdbId).Build();
+
+ //Act
+ var addId = sonicRepo.Add(series);
+
+ //Assert
+ Assert.AreEqual(tvdbId, addId);
+ var allSeries = sonicRepo.All();
+ Assert.IsNotEmpty(allSeries);
+ Assert.AreEqual(tvdbId, allSeries.First().SeriesId);
+ }
+ }
+}
diff --git a/NzbDrone.Core.Test/SabControllerTest.cs b/NzbDrone.Core.Test/SabControllerTest.cs
index 62bf4e57d..f7525eac8 100644
--- a/NzbDrone.Core.Test/SabControllerTest.cs
+++ b/NzbDrone.Core.Test/SabControllerTest.cs
@@ -14,6 +14,7 @@
namespace NzbDrone.Core.Test
{
[TestFixture]
+ // ReSharper disable InconsistentNaming
public class SabControllerTest
{
[Test]
diff --git a/NzbDrone.Core.Test/SeriesProviderTest.cs b/NzbDrone.Core.Test/SeriesProviderTest.cs
index 19a91ebf2..1249e75ba 100644
--- a/NzbDrone.Core.Test/SeriesProviderTest.cs
+++ b/NzbDrone.Core.Test/SeriesProviderTest.cs
@@ -21,6 +21,7 @@
namespace NzbDrone.Core.Test
{
[TestFixture]
+ // ReSharper disable InconsistentNaming
public class SeriesProviderTest
{
[Test]
@@ -65,26 +66,6 @@ public void Test_Parse_Success(string postTitle, string title)
Assert.AreEqual(title, result, postTitle);
}
-
-
- [Test]
- [Description("This test confirms that the tvdb id stored in the db is preserved rather than being replaced by an auto incrementing value")]
- public void tvdbid_is_preserved([RandomNumbers(Minimum = 100, Maximum = 999, Count = 1)] int tvdbId)
- {
- //Arrange
- var sonicRepo = MockLib.GetEmptyRepository();
- var series = Builder.CreateNew().With(c => c.SeriesId = tvdbId).Build();
-
- //Act
- var addId = sonicRepo.Add(series);
-
- //Assert
- Assert.AreEqual(tvdbId, addId);
- var allSeries = sonicRepo.All();
- Assert.IsNotEmpty(allSeries);
- Assert.AreEqual(tvdbId, allSeries.First().SeriesId);
- }
-
[Test]
public void get_unmapped()
{
@@ -104,21 +85,6 @@ public void get_unmapped()
Assert.AreElementsEqualIgnoringOrder(MockLib.StandardSeries, unmappedFolder);
}
- [Test]
- public void get_episode_test()
- {
- var fakeSeries = Builder.CreateNew().Build();
- var fakeEpisode = Builder.CreateNew().With(c => c.SeriesId).Build();
-
- Console.WriteLine("test");
-
- var repo = MockLib.GetEmptyRepository();
- repo.Add(fakeSeries);
- repo.Add(fakeEpisode);
-
- var fetchedSeries = repo.Single(fakeSeries.SeriesId);
-
- Assert.IsNotEmpty(fetchedSeries.Episodes);
- }
+
}
}
diff --git a/NzbDrone.Core.Test/TvDbControllerTest.cs b/NzbDrone.Core.Test/TvDbControllerTest.cs
index 82447975c..bfd85912f 100644
--- a/NzbDrone.Core.Test/TvDbControllerTest.cs
+++ b/NzbDrone.Core.Test/TvDbControllerTest.cs
@@ -9,6 +9,7 @@
namespace NzbDrone.Core.Test
{
[TestFixture]
+ // ReSharper disable InconsistentNaming
public class TvDbControllerTest
{
[Test]
diff --git a/NzbDrone.Core/CentralDispatch.cs b/NzbDrone.Core/CentralDispatch.cs
index 8bd4ae1f5..c5e63cc3e 100644
--- a/NzbDrone.Core/CentralDispatch.cs
+++ b/NzbDrone.Core/CentralDispatch.cs
@@ -3,6 +3,7 @@
using System.Web;
using Ninject;
using NLog.Config;
+using NLog.Layouts;
using NLog.Targets;
using NzbDrone.Core.Providers;
using NzbDrone.Core.Repository;
@@ -15,11 +16,13 @@ namespace NzbDrone.Core
{
public static class CentralDispatch
{
+ private static readonly Logger Logger = LogManager.GetLogger("DB");
+
public static void BindKernel(IKernel kernel)
{
string connectionString = String.Format("Data Source={0};Version=3;", Path.Combine(AppPath, "nzbdrone.db"));
var provider = ProviderFactory.GetProvider(connectionString, "System.Data.SQLite");
-
+ provider.Log = new SonicTrace();
kernel.Bind().To();
kernel.Bind().To();
kernel.Bind().To();
@@ -50,42 +53,52 @@ public static void ConfigureNlog()
// Step 1. Create configuration object
var config = new LoggingConfiguration();
- // Step 2. Create targets and add them to the configuration
- var consoleTarget = new DebuggerTarget();
- config.AddTarget("console", consoleTarget);
+ string callSight = "${callsite:className=false:fileName=true:includeSourcePath=false:methodName=true}";
- FileTarget fileTarget = new FileTarget();
- config.AddTarget("file", fileTarget);
+ // Step 2. Create targets and add them to the configuration
+ var debuggerTarget = new DebuggerTarget
+ {
+ Layout = callSight + "- ${logger}: ${message}"
+ };
+
+
+ var consoleTarget = new ColoredConsoleTarget
+ {
+ Layout = callSight + ": ${message}"
+ };
+
+
+ var fileTarget = new FileTarget
+ {
+ FileName = "${basedir}/test.log",
+ Layout = "${message}"
+ };
+
+ config.AddTarget("debugger", debuggerTarget);
+ config.AddTarget("console", consoleTarget);
+ //config.AddTarget("file", fileTarget);
// Step 3. Set target properties
- consoleTarget.Layout = "${logger} ${message}";
- fileTarget.FileName = "${basedir}/test.log";
- fileTarget.Layout = "${message}";
+
+
// Step 4. Define rules
- LoggingRule rule1 = new LoggingRule("*", LogLevel.Trace, consoleTarget);
- config.LoggingRules.Add(rule1);
+ LoggingRule debugRule = new LoggingRule("*", LogLevel.Trace, debuggerTarget);
+ LoggingRule fileRule = new LoggingRule("*", LogLevel.Trace, fileTarget);
+ LoggingRule consoleRule = new LoggingRule("*", LogLevel.Trace, consoleTarget);
- LoggingRule rule2 = new LoggingRule("*", LogLevel.Trace, fileTarget);
- config.LoggingRules.Add(rule2);
+ //config.LoggingRules.Add(fileRule);
+ config.LoggingRules.Add(debugRule);
+ config.LoggingRules.Add(consoleRule);
// Step 5. Activate the configuration
- NLog.LogManager.Configuration = config;
-
- Logger logger = LogManager.GetCurrentClassLogger();
- logger.Trace("trace log message");
- logger.Debug("debug log message");
- logger.Info("info log message");
- logger.Warn("warn log message");
- logger.Error("error log message");
- logger.Fatal("fatal log message");
+ LogManager.Configuration = config;
}
private static void ForceMigration(IRepository repository)
{
repository.GetPaged(0, 1);
repository.GetPaged(0, 1);
- repository.GetPaged(0, 1);
}
}
}
\ No newline at end of file
diff --git a/NzbDrone.Core/NzbDrone.Core.csproj b/NzbDrone.Core/NzbDrone.Core.csproj
index e6616b95b..8a951de46 100644
--- a/NzbDrone.Core/NzbDrone.Core.csproj
+++ b/NzbDrone.Core/NzbDrone.Core.csproj
@@ -146,6 +146,7 @@
+
diff --git a/NzbDrone.Core/Providers/EpisodeProvider.cs b/NzbDrone.Core/Providers/EpisodeProvider.cs
index 13a63a227..05a18a409 100644
--- a/NzbDrone.Core/Providers/EpisodeProvider.cs
+++ b/NzbDrone.Core/Providers/EpisodeProvider.cs
@@ -32,7 +32,7 @@ public class EpisodeProvider : IEpisodeProvider
private readonly ISeriesProvider _series;
private readonly ISeasonProvider _seasons;
private readonly ITvDbProvider _tvDb;
- private static readonly Logger Logger = NLog.LogManager.GetCurrentClassLogger();
+ private static readonly Logger Logger = LogManager.GetCurrentClassLogger();
public EpisodeProvider(IRepository sonicRepo, ISeriesProvider seriesProvider, ISeasonProvider seasonProvider, ITvDbProvider tvDbProvider)
diff --git a/NzbDrone.Core/Providers/SeasonProvider.cs b/NzbDrone.Core/Providers/SeasonProvider.cs
index 481207758..a48c440f8 100644
--- a/NzbDrone.Core/Providers/SeasonProvider.cs
+++ b/NzbDrone.Core/Providers/SeasonProvider.cs
@@ -31,7 +31,7 @@ public void EnsureSeason(int seriesId, int seasonId, int seasonNumber)
if (_sonicRepo.Exists(s => s.SeasonId == seasonId))
return;
//TODO: Calculate Season Folder
- Logger.Debug("Creating Season. SeriesID:{0} SeasonID:{1} SeasonNumber:{2} Folder:{3}", seriesId, seasonId, seasonNumber, string.Empty);
+ Logger.Debug("Adding Season To DB. [SeriesID:{0} SeasonID:{1} SeasonNumber:{2} Folder:{3}]", seriesId, seasonId, seasonNumber, "????");
var newSeason = new Season()
{
diff --git a/NzbDrone.Core/SonicTrace.cs b/NzbDrone.Core/SonicTrace.cs
new file mode 100644
index 000000000..74fdf78d0
--- /dev/null
+++ b/NzbDrone.Core/SonicTrace.cs
@@ -0,0 +1,39 @@
+/*
+ *Source:http://stackoverflow.com/questions/1520945/nlog-to-output-db-out
+ *DamienG
+ */
+
+using System;
+using System.IO;
+using System.Text;
+using NLog;
+
+namespace NzbDrone.Core
+{
+ class SonicTrace : TextWriter
+ {
+ private static readonly Logger Logger = LogManager.GetLogger("DB");
+
+
+ public override void Write(char[] buffer, int index, int count)
+ {
+ Write(new string(buffer, index, count));
+ }
+
+ public override void Write(string value)
+ {
+ DbAction(value);
+ }
+
+ private static void DbAction(string value)
+ {
+ Logger.Trace(value);
+ }
+
+ public override Encoding Encoding
+ {
+ get { return Encoding.Default; }
+ }
+ }
+
+}
\ No newline at end of file
diff --git a/NzbDrone/NzbDrone.csproj b/NzbDrone/NzbDrone.csproj
index 4ecfd9d0c..1aad08cd6 100644
--- a/NzbDrone/NzbDrone.csproj
+++ b/NzbDrone/NzbDrone.csproj
@@ -34,6 +34,10 @@
4
+
+ False
+ ..\NzbDrone.Core\Libraries\NLog.dll
+
diff --git a/NzbDrone/Program.cs b/NzbDrone/Program.cs
index 57e5c987d..986ce9016 100644
--- a/NzbDrone/Program.cs
+++ b/NzbDrone/Program.cs
@@ -3,18 +3,24 @@
using System.Linq;
using System.Net;
using System.Text;
+using NLog;
+using NzbDrone.Core;
namespace NzbDrone.Console
{
class Program
{
+
+ private static readonly Logger Logger = LogManager.GetCurrentClassLogger();
static void Main(string[] args)
{
+ CentralDispatch.ConfigureNlog();
+ Logger.Info("Starting NZBDrone WebUI");
var server = new CassiniDev.Server(@"D:\My Dropbox\Git\NzbDrone\NzbDrone.Web");
server.Start();
System.Diagnostics.Process.Start(server.RootUrl);
- System.Console.WriteLine(server.RootUrl);
+ Logger.Info("Server available at: " + server.RootUrl);
System.Console.ReadLine();
}