// Copyright (C) Stichting Deltares 2017. All rights reserved.
//
// This file is part of Ringtoets.
//
// Ringtoets is free software: you can redistribute it and/or modify
// it under the terms of the GNU Lesser General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public License
// along with this program. If not, see .
//
// All names, logos, and references to "Deltares" are registered trademarks of
// Stichting Deltares and remain full property of Stichting Deltares at all times.
// All rights reserved.
using System;
using System.Collections.Generic;
using System.IO;
using Core.Common.Base.Data;
using Core.Common.Base.Service;
using Core.Common.Base.Storage;
using Core.Common.TestUtil;
using NUnit.Framework;
using Rhino.Mocks;
namespace Core.Common.Gui.Test
{
[TestFixture]
public class OpenProjectActivityTest
{
[Test]
public void Constructor_ExpectedValues()
{
// Setup
var mocks = new MockRepository();
var projectOwner = mocks.Stub();
var projectFactory = mocks.Stub();
var projectStorage = mocks.Stub();
mocks.ReplayAll();
var openProjectProperties = new OpenProjectActivity.OpenProjectConstructionProperties
{
FilePath = "",
ProjectOwner = projectOwner,
ProjectFactory = projectFactory,
ProjectStorage = projectStorage
};
// Call
var activity = new OpenProjectActivity(openProjectProperties);
// Assert
Assert.IsInstanceOf(activity);
Assert.AreEqual("Openen van project", activity.Description);
Assert.IsNull(activity.ProgressText);
Assert.AreEqual(ActivityState.None, activity.State);
mocks.VerifyAll();
}
[Test]
public void Constructor_OpenProjectConstructionPropertiesNull_ThrowArgumentNullException()
{
// Call
TestDelegate call = () => new OpenProjectActivity(null);
// Assert
string paramName = Assert.Throws(call).ParamName;
Assert.AreEqual("requiredOpenProjectProperties", paramName);
}
[Test]
public void Constructor_FilePathNull_ThrowArgumentException()
{
// Setup
var mocks = new MockRepository();
var projectOwner = mocks.Stub();
var projectFactory = mocks.Stub();
var projectStorage = mocks.Stub();
mocks.ReplayAll();
var openProjectProperties = new OpenProjectActivity.OpenProjectConstructionProperties
{
FilePath = null,
ProjectOwner = projectOwner,
ProjectFactory = projectFactory,
ProjectStorage = projectStorage
};
// Call
TestDelegate call = () => new OpenProjectActivity(openProjectProperties);
// Assert
const string expectedMessage = "Filepath should be set.";
string paramName = TestHelper.AssertThrowsArgumentExceptionAndTestMessage(call, expectedMessage).ParamName;
Assert.AreEqual("requiredOpenProjectProperties", paramName);
mocks.VerifyAll();
}
[Test]
public void Constructor_ProjectOwnerNull_ThrowArgumentException()
{
// Setup
var mocks = new MockRepository();
var projectFactory = mocks.Stub();
var projectStorage = mocks.Stub();
mocks.ReplayAll();
var openProjectProperties = new OpenProjectActivity.OpenProjectConstructionProperties
{
FilePath = "",
ProjectOwner = null,
ProjectFactory = projectFactory,
ProjectStorage = projectStorage
};
// Call
TestDelegate call = () => new OpenProjectActivity(openProjectProperties);
// Assert
const string expectedMessage = "Project owner should be set.";
string paramName = TestHelper.AssertThrowsArgumentExceptionAndTestMessage(call, expectedMessage).ParamName;
Assert.AreEqual("requiredOpenProjectProperties", paramName);
mocks.VerifyAll();
}
[Test]
public void Constructor_ProjectFactoryNull_ThrowArgumentException()
{
// Setup
var mocks = new MockRepository();
var projectOwner = mocks.Stub();
var projectStorage = mocks.Stub();
mocks.ReplayAll();
var openProjectProperties = new OpenProjectActivity.OpenProjectConstructionProperties
{
FilePath = "",
ProjectOwner = projectOwner,
ProjectFactory = null,
ProjectStorage = projectStorage
};
// Call
TestDelegate call = () => new OpenProjectActivity(openProjectProperties);
// Assert
const string expectedMessage = "Project factory should be set.";
string paramName = TestHelper.AssertThrowsArgumentExceptionAndTestMessage(call, expectedMessage).ParamName;
Assert.AreEqual("requiredOpenProjectProperties", paramName);
mocks.VerifyAll();
}
[Test]
public void Constructor_StoreProjectNull_ThrowArgumentException()
{
// Setup
var mocks = new MockRepository();
var projectOwner = mocks.Stub();
var projectFactory = mocks.Stub();
mocks.ReplayAll();
var openProjectProperties = new OpenProjectActivity.OpenProjectConstructionProperties
{
FilePath = "",
ProjectOwner = projectOwner,
ProjectFactory = projectFactory,
ProjectStorage = null
};
// Call
TestDelegate call = () => new OpenProjectActivity(openProjectProperties);
// Assert
const string expectedMessage = "Project storage should be set.";
string paramName = TestHelper.AssertThrowsArgumentExceptionAndTestMessage(call, expectedMessage).ParamName;
Assert.AreEqual("requiredOpenProjectProperties", paramName);
mocks.VerifyAll();
}
[Test]
public void Constructor_MigrationFilePathNull_ThrowArgumentException()
{
// Setup
var mocks = new MockRepository();
var projectOwner = mocks.Stub();
var projectFactory = mocks.Stub();
var projectStorage = mocks.Stub();
var projectMigrator = mocks.Stub();
mocks.ReplayAll();
var openProjectProperties = new OpenProjectActivity.OpenProjectConstructionProperties
{
FilePath = "",
ProjectOwner = projectOwner,
ProjectFactory = projectFactory,
ProjectStorage = projectStorage
};
var migrateProjectProperties = new OpenProjectActivity.ProjectMigrationConstructionProperties
{
MigrationFilePath = null,
Migrator = projectMigrator
};
// Call
TestDelegate call = () => new OpenProjectActivity(openProjectProperties, migrateProjectProperties);
// Assert
const string expectedMessage = "Migration target file path should be set.";
string paramName = TestHelper.AssertThrowsArgumentExceptionAndTestMessage(call, expectedMessage).ParamName;
Assert.AreEqual("optionalProjectMigrationProperties", paramName);
mocks.VerifyAll();
}
[Test]
public void Constructor_MigrateProjectNull_ThrowArgumentException()
{
// Setup
var mocks = new MockRepository();
var projectOwner = mocks.Stub();
var projectFactory = mocks.Stub();
var projectStorage = mocks.Stub();
mocks.ReplayAll();
var openProjectProperties = new OpenProjectActivity.OpenProjectConstructionProperties
{
FilePath = "",
ProjectOwner = projectOwner,
ProjectFactory = projectFactory,
ProjectStorage = projectStorage
};
var migrateProjectProperties = new OpenProjectActivity.ProjectMigrationConstructionProperties
{
MigrationFilePath = "",
Migrator = null
};
// Call
TestDelegate call = () => new OpenProjectActivity(openProjectProperties, migrateProjectProperties);
// Assert
const string expectedMessage = "Project migrator should be set.";
string paramName = TestHelper.AssertThrowsArgumentExceptionAndTestMessage(call, expectedMessage).ParamName;
Assert.AreEqual("optionalProjectMigrationProperties", paramName);
mocks.VerifyAll();
}
[Test]
public void Run_StoreProjectLoadProjectDoesNotThrow_ActivityExecutedWithoutLogMessages()
{
// Setup
const string someFilePath = "";
var mocks = new MockRepository();
var project = mocks.Stub();
var projectStorage = mocks.Stub();
projectStorage.Expect(ps => ps.LoadProject(someFilePath))
.Return(project);
var projectFactory = mocks.Stub();
var projectOwner = mocks.Stub();
mocks.ReplayAll();
var openProjectProperties = new OpenProjectActivity.OpenProjectConstructionProperties
{
FilePath = someFilePath,
ProjectOwner = projectOwner,
ProjectFactory = projectFactory,
ProjectStorage = projectStorage
};
var activity = new OpenProjectActivity(openProjectProperties);
// Call
Action call = () => activity.Run();
// Assert
TestHelper.AssertLogMessagesCount(call, 0);
Assert.AreEqual(ActivityState.Executed, activity.State);
mocks.VerifyAll();
}
[Test]
public void Run_StoreProjectLoadProjectReturnsNull_ActivityFailedWithoutLogMessages()
{
// Setup
const string someFilePath = "";
var mocks = new MockRepository();
var projectStorage = mocks.Stub();
projectStorage.Expect(ps => ps.LoadProject(someFilePath))
.Return(null);
var projectFactory = mocks.Stub();
var projectOwner = mocks.Stub();
mocks.ReplayAll();
var openProjectProperties = new OpenProjectActivity.OpenProjectConstructionProperties
{
FilePath = someFilePath,
ProjectOwner = projectOwner,
ProjectFactory = projectFactory,
ProjectStorage = projectStorage
};
var activity = new OpenProjectActivity(openProjectProperties);
// Call
Action call = () => activity.Run();
// Assert
TestHelper.AssertLogMessagesCount(call, 0);
Assert.AreEqual(ActivityState.Failed, activity.State);
mocks.VerifyAll();
}
[Test]
public void Run_StoreProjectLoadProjectThrowsStorageException_ActivityFailedWithLogMessage()
{
// Setup
const string someFilePath = "";
const string message = "";
var innerException = new Exception("A");
var mocks = new MockRepository();
var projectStorage = mocks.Stub();
projectStorage.Expect(ps => ps.LoadProject(someFilePath))
.Throw(new StorageException(message, innerException));
var projectFactory = mocks.Stub();
var projectOwner = mocks.Stub();
mocks.ReplayAll();
var openProjectProperties = new OpenProjectActivity.OpenProjectConstructionProperties
{
FilePath = someFilePath,
ProjectOwner = projectOwner,
ProjectFactory = projectFactory,
ProjectStorage = projectStorage
};
var activity = new OpenProjectActivity(openProjectProperties);
// Call
Action call = () => activity.Run();
// Assert
TestHelper.AssertLogMessageIsGenerated(call, message, 1);
Assert.AreEqual(ActivityState.Failed, activity.State);
mocks.VerifyAll();
}
[Test]
public void Run_StoreProjectLoadProjectThrowsArgumentException_ActivityFailedWithoutLogMessages()
{
// Setup
const string someFilePath = "";
var mocks = new MockRepository();
var projectStorage = mocks.Stub();
projectStorage.Expect(ps => ps.LoadProject(someFilePath))
.Throw(new ArgumentException());
var projectFactory = mocks.Stub();
var projectOwner = mocks.Stub();
mocks.ReplayAll();
var openProjectProperties = new OpenProjectActivity.OpenProjectConstructionProperties
{
FilePath = someFilePath,
ProjectOwner = projectOwner,
ProjectFactory = projectFactory,
ProjectStorage = projectStorage
};
var activity = new OpenProjectActivity(openProjectProperties);
// Call
Action call = () => activity.Run();
// Assert
TestHelper.AssertLogMessagesCount(call, 0);
Assert.AreEqual(ActivityState.Failed, activity.State);
mocks.VerifyAll();
}
[Test]
public void Run_SuccessfulMigrateAndLoadProject_ActivityExecutedWithoutLogMessages()
{
// Setup
const string someFilePath = "";
const string someMigrationFilePath = "";
var mocks = new MockRepository();
var project = mocks.Stub();
var projectStorage = mocks.Stub();
projectStorage.Expect(ps => ps.LoadProject(someMigrationFilePath))
.Return(project);
var projectFactory = mocks.Stub();
var projectOwner = mocks.Stub();
var projectMigrator = mocks.Stub();
projectMigrator.Expect(m => m.Migrate(someFilePath, someMigrationFilePath))
.Return(true);
mocks.ReplayAll();
var openProjectProperties = new OpenProjectActivity.OpenProjectConstructionProperties
{
FilePath = someFilePath,
ProjectOwner = projectOwner,
ProjectFactory = projectFactory,
ProjectStorage = projectStorage
};
var migrateProjectProperties = new OpenProjectActivity.ProjectMigrationConstructionProperties
{
MigrationFilePath = someMigrationFilePath,
Migrator = projectMigrator
};
var activity = new OpenProjectActivity(openProjectProperties, migrateProjectProperties);
// Call
Action call = () => activity.Run();
// Assert
TestHelper.AssertLogMessagesCount(call, 0);
Assert.AreEqual(ActivityState.Executed, activity.State);
mocks.VerifyAll();
}
[Test]
public void Run_FailedToMigrate_ActivityFailedWithoutLogMessages()
{
// Setup
const string someFilePath = "";
const string someMigrationFilePath = "";
var mocks = new MockRepository();
var project = mocks.Stub();
var projectStorage = mocks.Stub();
projectStorage.Expect(ps => ps.LoadProject(someMigrationFilePath))
.Return(project)
.Repeat.Never();
var projectFactory = mocks.Stub();
var projectOwner = mocks.Stub();
var projectMigrator = mocks.Stub();
projectMigrator.Expect(m => m.Migrate(someFilePath, someMigrationFilePath))
.Return(false);
mocks.ReplayAll();
var openProjectProperties = new OpenProjectActivity.OpenProjectConstructionProperties
{
FilePath = someFilePath,
ProjectOwner = projectOwner,
ProjectFactory = projectFactory,
ProjectStorage = projectStorage
};
var migrateProjectProperties = new OpenProjectActivity.ProjectMigrationConstructionProperties
{
MigrationFilePath = someMigrationFilePath,
Migrator = projectMigrator
};
var activity = new OpenProjectActivity(openProjectProperties, migrateProjectProperties);
// Call
Action call = () => activity.Run();
// Assert
TestHelper.AssertLogMessagesCount(call, 0);
Assert.AreEqual(ActivityState.Failed, activity.State);
mocks.VerifyAll();
}
[Test]
public void Run_MigrateThrowsArgumentException_ActivityFailedWithLogMessage()
{
// Setup
const string someFilePath = "";
const string someMigrationFilePath = "";
const string exceptionMessage = "";
var mocks = new MockRepository();
var project = mocks.Stub();
var projectStorage = mocks.StrictMock();
projectStorage.Expect(ps => ps.LoadProject(someMigrationFilePath))
.Return(project)
.Repeat.Never();
var projectFactory = mocks.Stub();
var projectOwner = mocks.Stub();
var projectMigrator = mocks.StrictMock();
projectMigrator.Expect(m => m.Migrate(someFilePath, someMigrationFilePath))
.Throw(new ArgumentException(exceptionMessage));
mocks.ReplayAll();
var openProjectProperties = new OpenProjectActivity.OpenProjectConstructionProperties
{
FilePath = someFilePath,
ProjectOwner = projectOwner,
ProjectFactory = projectFactory,
ProjectStorage = projectStorage
};
var migrateProjectProperties = new OpenProjectActivity.ProjectMigrationConstructionProperties
{
MigrationFilePath = someMigrationFilePath,
Migrator = projectMigrator
};
var activity = new OpenProjectActivity(openProjectProperties, migrateProjectProperties);
// Call
Action call = () => activity.Run();
// Assert
TestHelper.AssertLogMessageIsGenerated(call, exceptionMessage, 1);
Assert.AreEqual(ActivityState.Failed, activity.State);
mocks.VerifyAll();
}
[Test]
public void Run_WithMigration_ExpectedProgressNotifications()
{
// Setup
var mocks = new MockRepository();
var projectFactory = mocks.Stub();
var projectOwner = mocks.Stub();
var storeProject = mocks.Stub();
var migrateProject = mocks.Stub();
migrateProject.Stub(pm => pm.Migrate(null, null))
.IgnoreArguments()
.Return(true);
mocks.ReplayAll();
var openProjectProperties = new OpenProjectActivity.OpenProjectConstructionProperties
{
FilePath = "",
ProjectFactory = projectFactory,
ProjectOwner = projectOwner,
ProjectStorage = storeProject
};
var migrateProjectProperties = new OpenProjectActivity.ProjectMigrationConstructionProperties
{
MigrationFilePath = "",
Migrator = migrateProject
};
var activity = new OpenProjectActivity(openProjectProperties,
migrateProjectProperties);
var progressMessages = new List();
activity.ProgressChanged += (sender, args) =>
{
Assert.AreSame(activity, sender);
Assert.AreEqual(EventArgs.Empty, args);
progressMessages.Add(activity.ProgressText);
};
// Call
activity.Run();
// Assert
var expectedProgressMessages = new[]
{
"Stap 1 van 3 | Migreren van project",
"Stap 2 van 3 | Inlezen van project"
};
CollectionAssert.AreEqual(expectedProgressMessages, progressMessages);
mocks.VerifyAll();
}
[Test]
public void Run_WithoutMigration_ExpectedProgressNotifications()
{
// Setup
var mocks = new MockRepository();
var projectFactory = mocks.Stub();
var projectOwner = mocks.Stub();
var storeProject = mocks.Stub();
mocks.ReplayAll();
var openProjectProperties = new OpenProjectActivity.OpenProjectConstructionProperties
{
FilePath = "",
ProjectFactory = projectFactory,
ProjectOwner = projectOwner,
ProjectStorage = storeProject
};
var activity = new OpenProjectActivity(openProjectProperties);
var progressMessages = new List();
activity.ProgressChanged += (sender, args) =>
{
Assert.AreSame(activity, sender);
Assert.AreEqual(EventArgs.Empty, args);
progressMessages.Add(activity.ProgressText);
};
// Call
activity.Run();
// Assert
var expectedProgressMessages = new[]
{
"Stap 1 van 2 | Inlezen van project"
};
CollectionAssert.AreEqual(expectedProgressMessages, progressMessages);
mocks.VerifyAll();
}
[Test]
public void Finish_ActivityExecutedSuccessfully_ProjectOwnerAndNewProjectUpdatedWithLogMessage()
{
// Setup
const string someFilePath = @"c:\\folder\someFilePath.rtd";
var mocks = new MockRepository();
var project = mocks.Stub();
project.Expect(p => p.NotifyObservers());
var projectStorage = mocks.Stub();
projectStorage.Stub(ps => ps.LoadProject(someFilePath))
.Return(project);
var projectFactory = mocks.Stub();
var projectOwner = mocks.Stub();
projectOwner.Expect(po => po.SetProject(project, someFilePath));
mocks.ReplayAll();
var openProjectProperties = new OpenProjectActivity.OpenProjectConstructionProperties
{
FilePath = someFilePath,
ProjectOwner = projectOwner,
ProjectFactory = projectFactory,
ProjectStorage = projectStorage
};
var activity = new OpenProjectActivity(openProjectProperties);
activity.Run();
// Precondition
Assert.AreEqual(ActivityState.Executed, activity.State);
// Call
Action call = () => activity.Finish();
// Assert
const string expectedMessage = "Openen van project is gelukt.";
TestHelper.AssertLogMessageIsGenerated(call, expectedMessage, 1);
Assert.AreEqual(ActivityState.Finished, activity.State);
Assert.AreEqual(Path.GetFileNameWithoutExtension(someFilePath), project.Name);
mocks.VerifyAll();
}
[Test]
public void Finish_ActivityFailedDueToNoProject_ProjectOwnerHasNewEmptyProjectWithLogMessage()
{
// Setup
const string someFilePath = @"c:\\folder\someFilePath.rtd";
var mocks = new MockRepository();
var projectStorage = mocks.Stub();
projectStorage.Stub(ps => ps.LoadProject(someFilePath))
.Return(null);
var project = mocks.Stub();
var projectFactory = mocks.Stub();
projectFactory.Expect(f => f.CreateNewProject())
.Return(project);
var projectOwner = mocks.Stub();
projectOwner.Expect(po => po.SetProject(project, null));
mocks.ReplayAll();
var openProjectProperties = new OpenProjectActivity.OpenProjectConstructionProperties
{
FilePath = someFilePath,
ProjectOwner = projectOwner,
ProjectFactory = projectFactory,
ProjectStorage = projectStorage
};
var activity = new OpenProjectActivity(openProjectProperties);
activity.Run();
// Precondition
Assert.AreEqual(ActivityState.Failed, activity.State);
// Call
Action call = () => activity.Finish();
// Assert
Tuple expectedMessage = Tuple.Create("Openen van project is mislukt.",
LogLevelConstant.Error);
TestHelper.AssertLogMessageWithLevelIsGenerated(call, expectedMessage, 1);
Assert.AreEqual(ActivityState.Failed, activity.State);
mocks.VerifyAll();
}
[Test]
[TestCase(true)]
[TestCase(false)]
public void Finish_ActivityFailedDueToException_ProjectOwnerHasNewEmptyProjectWithLogMessage(bool trueForStorageExceptionFalseForArgumentException)
{
// Setup
const string someFilePath = @"c:\\folder\someFilePath.rtd";
Exception exception = trueForStorageExceptionFalseForArgumentException ?
(Exception) new StorageException() :
new ArgumentException();
var mocks = new MockRepository();
var projectStorage = mocks.Stub();
projectStorage.Stub(ps => ps.LoadProject(someFilePath))
.Throw(exception);
var project = mocks.Stub();
var projectFactory = mocks.Stub();
projectFactory.Expect(f => f.CreateNewProject())
.Return(project);
var projectOwner = mocks.Stub();
projectOwner.Expect(po => po.SetProject(project, null));
mocks.ReplayAll();
var openProjectProperties = new OpenProjectActivity.OpenProjectConstructionProperties
{
FilePath = someFilePath,
ProjectOwner = projectOwner,
ProjectFactory = projectFactory,
ProjectStorage = projectStorage
};
var activity = new OpenProjectActivity(openProjectProperties);
activity.Run();
// Precondition
Assert.AreEqual(ActivityState.Failed, activity.State);
// Call
Action call = () => activity.Finish();
// Assert
Tuple expectedMessage = Tuple.Create("Openen van project is mislukt.",
LogLevelConstant.Error);
TestHelper.AssertLogMessageWithLevelIsGenerated(call, expectedMessage, 1);
Assert.AreEqual(ActivityState.Failed, activity.State);
mocks.VerifyAll();
}
[Test]
public void Finish_ActivityCancelled_ProjectOwnerNotUpdatedWithLogMessage()
{
// Setup
const string someFilePath = @"c:\\folder\someFilePath.rtd";
var mocks = new MockRepository();
var project = mocks.Stub();
project.Expect(p => p.NotifyObservers())
.Repeat.Never();
var projectStorage = mocks.Stub();
projectStorage.Stub(ps => ps.LoadProject(someFilePath))
.Return(project);
var projectFactory = mocks.Stub();
var projectOwner = mocks.Stub();
projectOwner.Expect(po => po.SetProject(project, someFilePath))
.Repeat.Never();
mocks.ReplayAll();
var openProjectProperties = new OpenProjectActivity.OpenProjectConstructionProperties
{
FilePath = someFilePath,
ProjectOwner = projectOwner,
ProjectFactory = projectFactory,
ProjectStorage = projectStorage
};
var activity = new OpenProjectActivity(openProjectProperties);
activity.Run();
activity.Cancel();
// Precondition
Assert.AreEqual(ActivityState.Canceled, activity.State);
// Call
Action call = () => activity.Finish();
// Assert
Tuple expectedMessage = Tuple.Create("Openen van project is geannuleerd.",
LogLevelConstant.Warn);
TestHelper.AssertLogMessageWithLevelIsGenerated(call, expectedMessage, 1);
Assert.AreEqual(ActivityState.Canceled, activity.State);
mocks.VerifyAll();
}
[Test]
public void Finish_ProjectMigratedAndOpened_ExpectedProgressText()
{
// Setup
var mocks = new MockRepository();
var project = mocks.Stub();
var projectFactory = mocks.Stub();
var projectOwner = mocks.Stub();
var storeProject = mocks.Stub();
storeProject.Stub(sp => sp.LoadProject(null))
.IgnoreArguments()
.Return(project);
var migrateProject = mocks.Stub();
migrateProject.Stub(pm => pm.Migrate(null, null))
.IgnoreArguments()
.Return(true);
mocks.ReplayAll();
var openProjectProperties = new OpenProjectActivity.OpenProjectConstructionProperties
{
FilePath = "",
ProjectFactory = projectFactory,
ProjectOwner = projectOwner,
ProjectStorage = storeProject
};
var migrateProjectProperties = new OpenProjectActivity.ProjectMigrationConstructionProperties
{
MigrationFilePath = "",
Migrator = migrateProject
};
var activity = new OpenProjectActivity(openProjectProperties,
migrateProjectProperties);
activity.Run();
// Precondition
Assert.AreEqual(ActivityState.Executed, activity.State);
var progressMessages = new List();
activity.ProgressChanged += (sender, args) =>
{
Assert.AreSame(activity, sender);
Assert.AreEqual(EventArgs.Empty, args);
progressMessages.Add(activity.ProgressText);
};
// Call
activity.Finish();
// Assert
var expectedProgressMessages = new[]
{
"Stap 3 van 3 | Initialiseren van geopend project"
};
CollectionAssert.AreEqual(expectedProgressMessages, progressMessages);
mocks.VerifyAll();
}
[Test]
public void Finish_OnlyProjectOpened_ExpectedProgressText()
{
// Setup
var mocks = new MockRepository();
var project = mocks.Stub();
var projectFactory = mocks.Stub();
var projectOwner = mocks.Stub();
var storeProject = mocks.Stub();
storeProject.Stub(sp => sp.LoadProject(null))
.IgnoreArguments()
.Return(project);
mocks.ReplayAll();
var openProjectProperties = new OpenProjectActivity.OpenProjectConstructionProperties
{
FilePath = "",
ProjectFactory = projectFactory,
ProjectOwner = projectOwner,
ProjectStorage = storeProject
};
var activity = new OpenProjectActivity(openProjectProperties);
activity.Run();
// Precondition
Assert.AreEqual(ActivityState.Executed, activity.State);
var progressMessages = new List();
activity.ProgressChanged += (sender, args) =>
{
Assert.AreSame(activity, sender);
Assert.AreEqual(EventArgs.Empty, args);
progressMessages.Add(activity.ProgressText);
};
// Call
activity.Finish();
// Assert
var expectedProgressMessages = new[]
{
"Stap 2 van 2 | Initialiseren van geopend project"
};
CollectionAssert.AreEqual(expectedProgressMessages, progressMessages);
mocks.VerifyAll();
}
[Test]
public void Finish_ProjectMigrationFailed_ExpectedProgressText()
{
// Setup
var mocks = new MockRepository();
var projectFactory = mocks.Stub();
var projectOwner = mocks.Stub();
var storeProject = mocks.Stub();
var migrateProject = mocks.Stub();
migrateProject.Stub(pm => pm.Migrate(null, null))
.IgnoreArguments()
.Throw(new ArgumentException());
mocks.ReplayAll();
var openProjectProperties = new OpenProjectActivity.OpenProjectConstructionProperties
{
FilePath = "",
ProjectFactory = projectFactory,
ProjectOwner = projectOwner,
ProjectStorage = storeProject
};
var migrateProjectProperties = new OpenProjectActivity.ProjectMigrationConstructionProperties
{
MigrationFilePath = "",
Migrator = migrateProject
};
var activity = new OpenProjectActivity(openProjectProperties,
migrateProjectProperties);
activity.Run();
// Precondition
Assert.AreEqual(ActivityState.Failed, activity.State);
var progressMessages = new List();
activity.ProgressChanged += (sender, args) =>
{
Assert.AreSame(activity, sender);
Assert.AreEqual(EventArgs.Empty, args);
progressMessages.Add(activity.ProgressText);
};
// Call
activity.Finish();
// Assert
var expectedProgressMessages = new[]
{
"Stap 3 van 3 | Initialiseren van leeg project"
};
CollectionAssert.AreEqual(expectedProgressMessages, progressMessages);
mocks.VerifyAll();
}
[Test]
public void Finish_OnlyProjectOpenFailed_ExpectedProgressText()
{
// Setup
var mocks = new MockRepository();
var projectFactory = mocks.Stub();
var projectOwner = mocks.Stub();
var storeProject = mocks.Stub();
storeProject.Stub(s => s.LoadProject(null))
.IgnoreArguments()
.Throw(new StorageException());
mocks.ReplayAll();
var openProjectProperties = new OpenProjectActivity.OpenProjectConstructionProperties
{
FilePath = "",
ProjectFactory = projectFactory,
ProjectOwner = projectOwner,
ProjectStorage = storeProject
};
var activity = new OpenProjectActivity(openProjectProperties);
activity.Run();
// Precondition
Assert.AreEqual(ActivityState.Failed, activity.State);
var progressMessages = new List();
activity.ProgressChanged += (sender, args) =>
{
Assert.AreSame(activity, sender);
Assert.AreEqual(EventArgs.Empty, args);
progressMessages.Add(activity.ProgressText);
};
// Call
activity.Finish();
// Assert
var expectedProgressMessages = new[]
{
"Stap 2 van 2 | Initialiseren van leeg project"
};
CollectionAssert.AreEqual(expectedProgressMessages, progressMessages);
mocks.VerifyAll();
}
[Test]
[TestCase(true)]
[TestCase(false)]
public void GivenActivityMigratingAndOpeningProject_WhenCancellingDuringMigration_DoNotLoadProject(bool migrationSuccessful)
{
// Setup
var mocks = new MockRepository();
var projectFactory = mocks.StrictMock();
var storeProject = mocks.StrictMock();
var projectOwner = mocks.StrictMock();
var migrateProject = mocks.Stub();
migrateProject.Stub(mp => mp.Migrate(null, null))
.IgnoreArguments()
.Return(migrationSuccessful);
mocks.ReplayAll();
var openProjectProperties = new OpenProjectActivity.OpenProjectConstructionProperties
{
FilePath = "",
ProjectFactory = projectFactory,
ProjectStorage = storeProject,
ProjectOwner = projectOwner
};
var migrateProjectProperties = new OpenProjectActivity.ProjectMigrationConstructionProperties
{
MigrationFilePath = "",
Migrator = migrateProject
};
var activity = new OpenProjectActivity(openProjectProperties,
migrateProjectProperties);
// When
activity.ProgressChanged += (sender, args) => activity.Cancel();
activity.Run();
activity.Finish();
// Assert
Assert.AreEqual(ActivityState.Canceled, activity.State);
mocks.VerifyAll();
}
[Test]
public void GivenActivityMigratinProject_WhenCancellingAndMigrationThrowsException_DoNotLoadProject()
{
// Setup
var mocks = new MockRepository();
var projectFactory = mocks.StrictMock();
var storeProject = mocks.StrictMock();
var projectOwner = mocks.StrictMock();
var migrateProject = mocks.Stub();
migrateProject.Stub(mp => mp.Migrate(null, null))
.IgnoreArguments()
.Throw(new ArgumentException());
mocks.ReplayAll();
var openProjectProperties = new OpenProjectActivity.OpenProjectConstructionProperties
{
FilePath = "",
ProjectFactory = projectFactory,
ProjectStorage = storeProject,
ProjectOwner = projectOwner
};
var migrateProjectProperties = new OpenProjectActivity.ProjectMigrationConstructionProperties
{
MigrationFilePath = "",
Migrator = migrateProject
};
var activity = new OpenProjectActivity(openProjectProperties,
migrateProjectProperties);
// When
activity.ProgressChanged += (sender, args) => activity.Cancel();
activity.Run();
activity.Finish();
// Assert
Assert.AreEqual(ActivityState.Canceled, activity.State);
mocks.VerifyAll();
}
[Test]
[TestCase(true)]
[TestCase(false)]
public void GivenActivityOpeningProject_WhenCancellingDuringLoadProject_DoNotSetProject(bool loadProjectSuccessful)
{
// Setup
var mocks = new MockRepository();
IProject project = loadProjectSuccessful ?
mocks.Stub() :
null;
var projectFactory = mocks.StrictMock();
var projectOwner = mocks.StrictMock();
var storeProject = mocks.Stub();
storeProject.Stub(s => s.LoadProject(null))
.IgnoreArguments()
.Return(project);
mocks.ReplayAll();
var openProjectProperties = new OpenProjectActivity.OpenProjectConstructionProperties
{
FilePath = "",
ProjectFactory = projectFactory,
ProjectStorage = storeProject,
ProjectOwner = projectOwner
};
var activity = new OpenProjectActivity(openProjectProperties);
// When
activity.ProgressChanged += (sender, args) => activity.Cancel();
activity.Run();
activity.Finish();
// Assert
Assert.AreEqual(ActivityState.Canceled, activity.State);
mocks.VerifyAll();
}
[Test]
public void GivenActivityOpeningProject_WhenCancellingWhileLoadProjectThrowsStorageException_DoNotSetProject()
{
// Setup
var mocks = new MockRepository();
var projectFactory = mocks.StrictMock();
var projectOwner = mocks.StrictMock();
var storeProject = mocks.Stub();
storeProject.Stub(s => s.LoadProject(null))
.IgnoreArguments()
.Throw(new StorageException());
mocks.ReplayAll();
var openProjectProperties = new OpenProjectActivity.OpenProjectConstructionProperties
{
FilePath = "",
ProjectFactory = projectFactory,
ProjectStorage = storeProject,
ProjectOwner = projectOwner
};
var activity = new OpenProjectActivity(openProjectProperties);
// When
activity.ProgressChanged += (sender, args) => activity.Cancel();
activity.Run();
activity.Finish();
// Assert
Assert.AreEqual(ActivityState.Canceled, activity.State);
mocks.VerifyAll();
}
}
}