Sonarr/NzbDrone.Core.Test/dbBenchmark.cs

182 lines
5.1 KiB
C#
Raw Normal View History

2011-05-30 06:47:11 +00:00
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Threading;
using FizzWare.NBuilder;
using FluentAssertions;
2011-06-02 21:06:46 +00:00
using NUnit.Framework;
using NzbDrone.Core.Providers;
2011-05-30 06:47:11 +00:00
using NzbDrone.Core.Repository;
using NzbDrone.Core.Test.Framework;
using SubSonic.Repository;
2011-05-30 06:47:11 +00:00
namespace NzbDrone.Core.Test
{
[TestFixture]
// ReSharper disable InconsistentNaming
public class DbBenchmark : TestBase
2011-05-30 06:47:11 +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 };
private readonly List<Episode> episodes = new List<Episode>();
private readonly List<EpisodeFile> files = new List<EpisodeFile>();
private readonly IRepository repo = MockLib.GetEmptyRepository();
[TestFixtureSetUp]
public new void Setup()
2011-05-30 06:47:11 +00:00
{
base.Setup();
2011-05-30 06:47:11 +00:00
foreach (var _seriesId in seriesIds)
2011-05-30 06:47:11 +00:00
{
int seriesId = _seriesId;
var series = Builder<Series>.CreateNew()
.With(s => s.SeriesId = seriesId)
.With(s => s.Monitored = true)
.Build();
repo.Add(series);
foreach (var _seasonNumber in seasonsNumbers)
{
for (int i = 1; i <= Episodes_Per_Season; i++)
{
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)
.And(e => e.AirDate = DateTime.Today.AddDays(-20))
.Build();
episodes.Add(episode);
if (i < 10)
{
var epFile = Builder<EpisodeFile>.CreateNew()
.With(e => e.SeriesId = seriesId)
.And(e => e.SeasonNumber = _seasonNumber)
.And(e => e.Path = Guid.NewGuid().ToString())
.Build();
files.Add(epFile);
}
}
}
2011-06-05 06:02:31 +00:00
}
repo.AddMany(episodes);
repo.AddMany(files);
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
{
var epProvider = new EpisodeProvider(repo, null);
2011-05-30 06:47:11 +00:00
Thread.Sleep(1000);
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++)
{
epProvider.GetEpisode(6, random.Next(2, 5), random.Next(2, Episodes_Per_Season - 10)).Should().NotBeNull();
}
2011-05-30 06:47:11 +00:00
sw.Stop();
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
{
var epProvider = new EpisodeProvider(repo, null);
2011-05-30 06:47:11 +00:00
Thread.Sleep(1000);
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
{
epProvider.GetEpisodesBySeason(6, random.Next(2, 5)).Should().NotBeNull();
2011-05-30 06:47:11 +00:00
}
2011-05-30 06:47:11 +00:00
sw.Stop();
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
{
var mocker = new AutoMoq.AutoMoqer();
mocker.SetConstant(repo);
mocker.SetConstant(mocker.Resolve<EpisodeProvider>());
var mediaProvider = mocker.Resolve<MediaFileProvider>();
2011-05-30 06:47:11 +00:00
Thread.Sleep(1000);
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 < 100; i++)
2011-05-30 06:47:11 +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]
public void get_season_count_x5000()
{
var mocker = new AutoMoq.AutoMoqer();
mocker.SetConstant(repo);
var provider = mocker.Resolve<EpisodeProvider>();
Thread.Sleep(1000);
var random = new Random();
Console.WriteLine("Starting Test");
var sw = Stopwatch.StartNew();
for (int i = 0; i < 5000; i++)
{
provider.GetSeasons(random.Next(1, 10)).Should().HaveSameCount(seasonsNumbers);
}
2011-05-30 06:47:11 +00:00
sw.Stop();
Console.WriteLine("Took " + sw.Elapsed);
2011-05-30 06:47:11 +00:00
}
}
}