Lidarr/src/NzbDrone.Core/Datastore/Migration/Framework/MigrationController.cs

69 lines
2.0 KiB
C#
Raw Normal View History

using System.Data.SQLite;
using System.Diagnostics;
using System.Reflection;
2013-03-25 06:13:53 +00:00
using FluentMigrator.Runner;
using FluentMigrator.Runner.Initialization;
namespace NzbDrone.Core.Datastore.Migration.Framework
{
public interface IMigrationController
{
void Migrate(string connectionString, MigrationContext migrationContext);
2013-03-25 06:13:53 +00:00
}
public class MigrationController : IMigrationController
{
private readonly IAnnouncer _announcer;
public MigrationController(IAnnouncer announcer)
2013-03-25 06:13:53 +00:00
{
_announcer = announcer;
}
public void Migrate(string connectionString, MigrationContext migrationContext)
2013-03-25 06:13:53 +00:00
{
var sw = Stopwatch.StartNew();
2013-11-30 21:08:53 +00:00
_announcer.Heading("Migrating " + connectionString);
var assembly = Assembly.GetExecutingAssembly();
var runnerContext = new RunnerContext(_announcer)
{
Namespace = "NzbDrone.Core.Datastore.Migration",
ApplicationContext = migrationContext
};
2013-11-30 21:08:53 +00:00
var options = new MigrationOptions { PreviewOnly = false, Timeout = 60 };
var factory = new NzbDroneSqliteProcessorFactory();
2013-11-30 21:08:53 +00:00
var processor = factory.Create(connectionString, _announcer, options);
try
{
var runner = new MigrationRunner(assembly, runnerContext, processor);
if (migrationContext.DesiredVersion.HasValue)
{
runner.MigrateUp(migrationContext.DesiredVersion.Value, true);
}
else
{
runner.MigrateUp(true);
}
}
catch (SQLiteException)
{
processor.Dispose();
SQLiteConnection.ClearAllPools();
throw;
}
processor.Dispose();
sw.Stop();
_announcer.ElapsedTime(sw.Elapsed);
2013-03-25 06:13:53 +00:00
}
}
}