2011-05-30 06:47:11 +00:00
|
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Diagnostics;
|
|
|
|
|
using System.Threading;
|
2011-11-14 00:22:18 +00:00
|
|
|
|
|
2011-05-30 06:47:11 +00:00
|
|
|
|
using FizzWare.NBuilder;
|
2011-06-04 01:56:53 +00:00
|
|
|
|
using FluentAssertions;
|
2011-06-02 21:06:46 +00:00
|
|
|
|
using NUnit.Framework;
|
2013-02-19 06:01:03 +00:00
|
|
|
|
using NzbDrone.Core.Tv;
|
2011-06-04 01:56:53 +00:00
|
|
|
|
using NzbDrone.Core.Providers;
|
2011-05-30 06:47:11 +00:00
|
|
|
|
using NzbDrone.Core.Repository;
|
2011-06-19 18:56:32 +00:00
|
|
|
|
using NzbDrone.Core.Repository.Quality;
|
2011-05-30 06:47:11 +00:00
|
|
|
|
using NzbDrone.Core.Test.Framework;
|
2011-11-14 00:22:18 +00:00
|
|
|
|
using NzbDrone.Test.Common.AutoMoq;
|
2011-06-19 18:56:32 +00:00
|
|
|
|
using PetaPoco;
|
2011-05-30 06:47:11 +00:00
|
|
|
|
|
|
|
|
|
namespace NzbDrone.Core.Test
|
|
|
|
|
{
|
|
|
|
|
[TestFixture]
|
2011-11-03 23:23:54 +00:00
|
|
|
|
[Explicit]
|
2011-10-17 02:03:54 +00:00
|
|
|
|
[Category("Benchmark")]
|
2011-05-30 06:47:11 +00:00
|
|
|
|
// ReSharper disable InconsistentNaming
|
2013-02-02 20:54:03 +00:00
|
|
|
|
public class DbBenchmark : SqlCeTest
|
2011-05-30 06:47:11 +00:00
|
|
|
|
{
|
2011-06-04 01:56:53 +00:00
|
|
|
|
const int Episodes_Per_Season = 20;
|
2011-06-05 06:02:31 +00:00
|
|
|
|
private readonly List<int> seasonsNumbers = new List<int> { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
|
|
|
|
|
private readonly List<int> seriesIds = new List<int> { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14 };
|
2011-06-04 01:56:53 +00:00
|
|
|
|
private readonly List<Episode> episodes = new List<Episode>();
|
|
|
|
|
private readonly List<EpisodeFile> files = new List<EpisodeFile>();
|
2011-06-19 18:56:32 +00:00
|
|
|
|
private IDatabase db;
|
2011-06-18 01:46:22 +00:00
|
|
|
|
|
2011-06-04 01:56:53 +00:00
|
|
|
|
|
|
|
|
|
[TestFixtureSetUp]
|
2011-10-24 05:54:09 +00:00
|
|
|
|
public void Setup()
|
2011-05-30 06:47:11 +00:00
|
|
|
|
{
|
2013-01-19 23:55:58 +00:00
|
|
|
|
WithRealDb();
|
|
|
|
|
|
2011-06-05 07:25:50 +00:00
|
|
|
|
int currentFileId = 0;
|
2011-05-30 06:47:11 +00:00
|
|
|
|
|
2011-06-19 18:56:32 +00:00
|
|
|
|
|
|
|
|
|
var qulityProfile = new QualityProfile
|
|
|
|
|
{
|
|
|
|
|
Name = "TestProfile",
|
|
|
|
|
Allowed = new List<QualityTypes> { QualityTypes.DVD, QualityTypes.Bluray1080p },
|
|
|
|
|
Cutoff = QualityTypes.DVD
|
|
|
|
|
};
|
2013-01-19 23:55:58 +00:00
|
|
|
|
Db.Insert(qulityProfile);
|
2011-06-19 18:56:32 +00:00
|
|
|
|
|
2011-06-04 01:56:53 +00:00
|
|
|
|
foreach (var _seriesId in seriesIds)
|
2011-05-30 06:47:11 +00:00
|
|
|
|
{
|
2011-06-04 01:56:53 +00:00
|
|
|
|
int seriesId = _seriesId;
|
|
|
|
|
var series = Builder<Series>.CreateNew()
|
|
|
|
|
.With(s => s.SeriesId = seriesId)
|
|
|
|
|
.With(s => s.Monitored = true)
|
|
|
|
|
.Build();
|
|
|
|
|
|
2013-01-19 23:55:58 +00:00
|
|
|
|
Db.Insert(series);
|
2011-06-04 01:56:53 +00:00
|
|
|
|
|
|
|
|
|
foreach (var _seasonNumber in seasonsNumbers)
|
|
|
|
|
{
|
|
|
|
|
for (int i = 1; i <= Episodes_Per_Season; i++)
|
|
|
|
|
{
|
2011-06-05 07:25:50 +00:00
|
|
|
|
var epFileId = 0;
|
|
|
|
|
|
|
|
|
|
if (i < 10)
|
|
|
|
|
{
|
|
|
|
|
var epFile = Builder<EpisodeFile>.CreateNew()
|
|
|
|
|
.With(e => e.SeriesId = seriesId)
|
2011-06-19 18:56:32 +00:00
|
|
|
|
.And(e => e.SeasonNumber = _seasonNumber)
|
2011-06-05 07:25:50 +00:00
|
|
|
|
.And(e => e.Path = Guid.NewGuid().ToString())
|
|
|
|
|
.Build();
|
|
|
|
|
|
|
|
|
|
files.Add(epFile);
|
|
|
|
|
|
|
|
|
|
currentFileId++;
|
|
|
|
|
epFileId = currentFileId;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2011-06-04 01:56:53 +00:00
|
|
|
|
var episode = Builder<Episode>.CreateNew()
|
|
|
|
|
.With(e => e.SeriesId = seriesId)
|
|
|
|
|
.And(e => e.SeasonNumber = _seasonNumber)
|
|
|
|
|
.And(e => e.EpisodeNumber = i)
|
|
|
|
|
.And(e => e.Ignored = false)
|
|
|
|
|
.And(e => e.TvDbEpisodeId = episodes.Count + 1)
|
2011-06-05 07:25:50 +00:00
|
|
|
|
.And(e => e.EpisodeFileId = epFileId)
|
2011-06-04 01:56:53 +00:00
|
|
|
|
.And(e => e.AirDate = DateTime.Today.AddDays(-20))
|
|
|
|
|
.Build();
|
|
|
|
|
|
|
|
|
|
episodes.Add(episode);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2011-06-05 06:02:31 +00:00
|
|
|
|
}
|
|
|
|
|
|
2013-01-19 23:55:58 +00:00
|
|
|
|
Db.InsertMany(episodes);
|
|
|
|
|
Db.InsertMany(files);
|
2011-06-05 07:25:50 +00:00
|
|
|
|
}
|
2011-05-30 06:47:11 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
[Test]
|
2011-06-05 06:02:31 +00:00
|
|
|
|
public void get_episode_by_series_seasons_episode_x5000()
|
2011-05-30 06:47:11 +00:00
|
|
|
|
{
|
2011-12-15 04:15:53 +00:00
|
|
|
|
|
|
|
|
|
Mocker.SetConstant(db);
|
|
|
|
|
Mocker.Resolve<SeriesProvider>();
|
2011-06-04 01:56:53 +00:00
|
|
|
|
|
2011-12-15 04:15:53 +00:00
|
|
|
|
var epProvider = Mocker.Resolve<EpisodeProvider>();
|
2011-05-30 06:47:11 +00:00
|
|
|
|
|
|
|
|
|
Thread.Sleep(1000);
|
2011-06-04 01:56:53 +00:00
|
|
|
|
|
|
|
|
|
var random = new Random();
|
|
|
|
|
Console.WriteLine("Starting Test");
|
|
|
|
|
|
2011-05-30 06:47:11 +00:00
|
|
|
|
var sw = Stopwatch.StartNew();
|
2011-06-05 06:02:31 +00:00
|
|
|
|
for (int i = 0; i < 5000; i++)
|
2011-06-04 01:56:53 +00:00
|
|
|
|
{
|
2011-06-19 18:56:32 +00:00
|
|
|
|
var ep = epProvider.GetEpisode(6, random.Next(2, 5), random.Next(2, Episodes_Per_Season - 10));
|
|
|
|
|
ep.Series.Should().NotBeNull();
|
2011-06-04 01:56:53 +00:00
|
|
|
|
}
|
|
|
|
|
|
2011-05-30 06:47:11 +00:00
|
|
|
|
sw.Stop();
|
|
|
|
|
|
2011-06-04 01:56:53 +00:00
|
|
|
|
Console.WriteLine("Took " + sw.Elapsed);
|
2011-05-30 06:47:11 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Test]
|
2011-06-05 06:02:31 +00:00
|
|
|
|
public void get_episode_by_series_seasons_x1000()
|
2011-05-30 06:47:11 +00:00
|
|
|
|
{
|
2011-12-15 04:15:53 +00:00
|
|
|
|
|
|
|
|
|
Mocker.SetConstant(db);
|
|
|
|
|
Mocker.Resolve<SeriesProvider>();
|
2011-06-19 18:56:32 +00:00
|
|
|
|
|
2011-12-15 04:15:53 +00:00
|
|
|
|
var epProvider = Mocker.Resolve<EpisodeProvider>();
|
2011-06-04 01:56:53 +00:00
|
|
|
|
|
2011-05-30 06:47:11 +00:00
|
|
|
|
|
|
|
|
|
Thread.Sleep(1000);
|
|
|
|
|
|
2011-06-04 01:56:53 +00:00
|
|
|
|
|
|
|
|
|
var random = new Random();
|
|
|
|
|
Console.WriteLine("Starting Test");
|
|
|
|
|
|
|
|
|
|
var sw = Stopwatch.StartNew();
|
2011-06-05 06:02:31 +00:00
|
|
|
|
for (int i = 0; i < 1000; i++)
|
2011-05-30 06:47:11 +00:00
|
|
|
|
{
|
2011-06-04 01:56:53 +00:00
|
|
|
|
epProvider.GetEpisodesBySeason(6, random.Next(2, 5)).Should().NotBeNull();
|
2011-05-30 06:47:11 +00:00
|
|
|
|
}
|
|
|
|
|
|
2011-06-04 01:56:53 +00:00
|
|
|
|
|
2011-05-30 06:47:11 +00:00
|
|
|
|
sw.Stop();
|
|
|
|
|
|
2011-06-04 01:56:53 +00:00
|
|
|
|
Console.WriteLine("Took " + sw.Elapsed);
|
2011-05-30 06:47:11 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Test]
|
2011-06-05 06:02:31 +00:00
|
|
|
|
public void get_episode_file_count_x100()
|
2011-05-30 06:47:11 +00:00
|
|
|
|
{
|
2011-12-15 04:15:53 +00:00
|
|
|
|
|
|
|
|
|
Mocker.SetConstant(db);
|
|
|
|
|
Mocker.Resolve<SeriesProvider>();
|
|
|
|
|
Mocker.Resolve<EpisodeProvider>();
|
|
|
|
|
var mediaProvider = Mocker.Resolve<MediaFileProvider>();
|
2011-05-30 06:47:11 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Thread.Sleep(1000);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var random = new Random();
|
2011-06-04 01:56:53 +00:00
|
|
|
|
Console.WriteLine("Starting Test");
|
2011-05-30 06:47:11 +00:00
|
|
|
|
|
|
|
|
|
var sw = Stopwatch.StartNew();
|
2011-06-05 06:02:31 +00:00
|
|
|
|
for (int i = 0; i < 100; i++)
|
2011-05-30 06:47:11 +00:00
|
|
|
|
{
|
2011-06-04 01:56:53 +00:00
|
|
|
|
mediaProvider.GetEpisodeFilesCount(random.Next(1, 5)).Should().NotBeNull();
|
2011-05-30 06:47:11 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2011-06-05 06:02:31 +00:00
|
|
|
|
sw.Stop();
|
|
|
|
|
|
|
|
|
|
Console.WriteLine("Took " + sw.Elapsed);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Test]
|
2011-06-19 18:56:32 +00:00
|
|
|
|
public void get_episode_file_count_x1000()
|
2011-06-05 06:02:31 +00:00
|
|
|
|
{
|
2011-12-15 04:15:53 +00:00
|
|
|
|
|
|
|
|
|
Mocker.SetConstant(db);
|
|
|
|
|
Mocker.Resolve<SeriesProvider>();
|
|
|
|
|
Mocker.Resolve<EpisodeProvider>();
|
|
|
|
|
var mediaProvider = Mocker.Resolve<MediaFileProvider>();
|
2011-06-05 06:02:31 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Thread.Sleep(1000);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var random = new Random();
|
|
|
|
|
Console.WriteLine("Starting Test");
|
|
|
|
|
|
|
|
|
|
var sw = Stopwatch.StartNew();
|
2011-06-19 18:56:32 +00:00
|
|
|
|
for (int i = 0; i < 1000; i++)
|
2011-06-05 06:02:31 +00:00
|
|
|
|
{
|
2011-06-19 18:56:32 +00:00
|
|
|
|
mediaProvider.GetEpisodeFilesCount(random.Next(1, 5)).Should().NotBeNull();
|
2011-06-05 06:02:31 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2011-05-30 06:47:11 +00:00
|
|
|
|
sw.Stop();
|
|
|
|
|
|
2011-06-04 01:56:53 +00:00
|
|
|
|
Console.WriteLine("Took " + sw.Elapsed);
|
2011-05-30 06:47:11 +00:00
|
|
|
|
}
|
2011-06-05 07:25:50 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
[Test]
|
2011-06-19 20:43:47 +00:00
|
|
|
|
public void get_season_count_x500()
|
2011-06-05 07:25:50 +00:00
|
|
|
|
{
|
2011-12-15 04:15:53 +00:00
|
|
|
|
|
|
|
|
|
Mocker.SetConstant(db);
|
|
|
|
|
var provider = Mocker.Resolve<EpisodeProvider>();
|
2011-06-05 07:25:50 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Thread.Sleep(1000);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var random = new Random();
|
|
|
|
|
Console.WriteLine("Starting Test");
|
|
|
|
|
|
|
|
|
|
var sw = Stopwatch.StartNew();
|
2011-06-19 20:43:47 +00:00
|
|
|
|
for (int i = 0; i < 500; i++)
|
2011-06-05 07:25:50 +00:00
|
|
|
|
{
|
2011-06-19 18:56:32 +00:00
|
|
|
|
provider.GetSeasons(random.Next(1, 10)).Should().HaveSameCount(seasonsNumbers);
|
2011-06-05 07:25:50 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
sw.Stop();
|
|
|
|
|
|
|
|
|
|
Console.WriteLine("Took " + sw.Elapsed);
|
|
|
|
|
}
|
|
|
|
|
|
2011-06-19 18:56:32 +00:00
|
|
|
|
|
|
|
|
|
|
2011-05-30 06:47:11 +00:00
|
|
|
|
}
|
|
|
|
|
}
|