using System; using System.Collections.Generic; using System.IO; using System.Linq; using FluentMigrator.Runner; using Marr.Data; using Moq; using NUnit.Framework; using NzbDrone.Common.Messaging; using NzbDrone.Core.Datastore; using NzbDrone.Core.Datastore.Migration.Framework; namespace NzbDrone.Core.Test.Framework { [Category("DbTest")] public abstract class DbTest : DbTest where TSubject : class where TModel : ModelBase, new() { private TSubject _subject; protected BasicRepository Storage { get; private set; } protected IList AllStoredModels { get { return Storage.All().ToList(); } } protected TModel StoredModel { get { return Storage.All().Single(); } } [SetUp] public void CoreTestSetup() { _subject = null; Storage = Mocker.Resolve>(); } protected TSubject Subject { get { if (_subject == null) { _subject = Mocker.Resolve(); } return _subject; } } } public abstract class DbTest : CoreTest { private ITestDatabase _db; protected virtual MigrationType MigrationType { get { return MigrationType.Main; } } protected ITestDatabase Db { get { if (_db == null) throw new InvalidOperationException("Test object database doesn't exists. Make sure you call WithRealDb() if you intend to use an actual database."); return _db; } } private void WithTestDb() { WithTempAsAppPath(); Mocker.SetConstant(Mocker.Resolve()); Mocker.SetConstant(Mocker.Resolve()); Mocker.SetConstant(Mocker.Resolve()); Mocker.SetConstant(Mocker.Resolve()); Mocker.SetConstant(Mocker.Resolve()); MapRepository.Instance.EnableTraceLogging = true; var factory = Mocker.Resolve(); var _database = factory.Create(MigrationType); _db = new TestDatabase(_database); Mocker.SetConstant(_database); } [SetUp] public void SetupReadDb() { WithTestDb(); } [TearDown] public void TearDown() { if (TestFolderInfo != null && Directory.Exists(TestFolderInfo.AppDataFolder)) { var files = Directory.GetFiles(TestFolderInfo.AppDataFolder); foreach (var file in files) { try { File.Delete(file); } catch (Exception) { } } } } } public interface ITestDatabase { void InsertMany(IEnumerable items) where T : ModelBase, new(); T Insert(T item) where T : ModelBase, new(); List All() where T : ModelBase, new(); T Single() where T : ModelBase, new(); void Update(T childModel) where T : ModelBase, new(); void Delete(T childModel) where T : ModelBase, new(); } public class TestDatabase : ITestDatabase { private readonly IDatabase _dbConnection; private IMessageAggregator _messageAggregator; public TestDatabase(IDatabase dbConnection) { _messageAggregator = new Mock().Object; _dbConnection = dbConnection; } public void InsertMany(IEnumerable items) where T : ModelBase, new() { new BasicRepository(_dbConnection, _messageAggregator).InsertMany(items.ToList()); } public T Insert(T item) where T : ModelBase, new() { return new BasicRepository(_dbConnection, _messageAggregator).Insert(item); } public List All() where T : ModelBase, new() { return new BasicRepository(_dbConnection, _messageAggregator).All().ToList(); } public T Single() where T : ModelBase, new() { return All().SingleOrDefault(); } public void Update(T childModel) where T : ModelBase, new() { new BasicRepository(_dbConnection, _messageAggregator).Update(childModel); } public void Delete(T childModel) where T : ModelBase, new() { new BasicRepository(_dbConnection, _messageAggregator).Delete(childModel); } } }