// 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 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 General Public License for more details.
//
// You should have received a copy of the GNU 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.Drawing;
using System.Globalization;
using System.Linq;
using System.Windows.Forms;
using Core.Common.Base;
using Core.Common.Controls.DataGrid;
using Core.Common.Gui.Commands;
using Core.Common.Util;
using NUnit.Extensions.Forms;
using NUnit.Framework;
using Rhino.Mocks;
using Ringtoets.Common.Data.AssessmentSection;
using Ringtoets.Common.Data.Contribution;
using Ringtoets.Common.Data.FailureMechanism;
using Ringtoets.Common.Data.TestUtil;
using Ringtoets.Integration.Data;
using Ringtoets.Integration.Forms.Views;
namespace Ringtoets.Integration.Forms.Test.Views
{
[TestFixture]
public class FailureMechanismContributionViewTest : NUnitFormTest
{
private const string returnPeriodLabelName = "returnPeriodLabel";
private const string dataGridViewControlName = "dataGridView";
private const string assessmentSectionConfigurationLabelName = "assessmentSectionCompositionLabel";
private const int isRelevantColumnIndex = 0;
private const int nameColumnIndex = 1;
private const int codeColumnIndex = 2;
private const int contributionColumnIndex = 3;
private const int probabilitySpaceColumnIndex = 4;
private Form testForm;
[Test]
public void Constructor_AssessmentSectionNull_ThrowsArgumentNullException()
{
// Setup
var mocks = new MockRepository();
var viewCommands = mocks.Stub();
mocks.ReplayAll();
// Call
TestDelegate call = () => new FailureMechanismContributionView(null, viewCommands);
// Assert
var exception = Assert.Throws(call);
Assert.AreEqual("assessmentSection", exception.ParamName);
mocks.VerifyAll();
}
[Test]
public void Constructor_ViewCommandsNull_ThrowsArgumentNullException()
{
// Setup
var mocks = new MockRepository();
var assessmentSection = mocks.Stub();
mocks.ReplayAll();
// Call
TestDelegate call = () => new FailureMechanismContributionView(assessmentSection, null);
// Assert
string paramName = Assert.Throws(call).ParamName;
Assert.AreEqual("viewCommands", paramName);
mocks.VerifyAll();
}
[Test]
public void Constructor_ExpectedValues()
{
// Setup
var mocks = new MockRepository();
var assessmentSection = mocks.Stub();
var viewCommands = mocks.Stub();
mocks.ReplayAll();
// Call
using (var contributionView = new FailureMechanismContributionView(assessmentSection, viewCommands))
{
ShowFormWithView(contributionView);
var dataGridView = (DataGridViewControl) new ControlTester("probabilityDistributionGrid").TheObject;
var groupBoxView = (GroupBox) new ControlTester("groupBoxAssessmentSectionDetails").TheObject;
// Assert
Assert.AreEqual(new Size(0, 0), dataGridView.MinimumSize);
Assert.AreEqual(DockStyle.Fill, dataGridView.Dock);
Assert.IsFalse(dataGridView.AutoScroll);
Assert.AreEqual(new Size(0, 0), groupBoxView.MinimumSize);
Assert.AreEqual(DockStyle.Top, groupBoxView.Dock);
Assert.IsFalse(contributionView.AutoScroll);
}
mocks.VerifyAll();
}
[Test]
public void ReturnPeriodTextBox_Initialize_TextSetToData()
{
// Setup
var mocks = new MockRepository();
var viewCommands = mocks.Stub();
mocks.ReplayAll();
var assessmentSection = new AssessmentSection(AssessmentSectionComposition.Dike);
FailureMechanismContribution failureMechanismContribution = assessmentSection.FailureMechanismContribution;
// Call
using (var contributionView = new FailureMechanismContributionView(assessmentSection, viewCommands)
{
Data = failureMechanismContribution,
AssessmentSection = assessmentSection
})
{
ShowFormWithView(contributionView);
// Assert
var returnPeriodLabel = new ControlTester(returnPeriodLabelName);
int returnPeriod = Convert.ToInt32(1.0 / failureMechanismContribution.Norm);
string expectedReturnPeriodLabel = $"Norm van het dijktraject: 1 / {returnPeriod.ToString(CultureInfo.CurrentCulture)}";
Assert.AreEqual(expectedReturnPeriodLabel, returnPeriodLabel.Properties.Text);
}
mocks.VerifyAll();
}
[Test]
public void Data_Always_CorrectHeaders()
{
// Setup
var mocks = new MockRepository();
var assessmentSection = mocks.Stub();
var viewCommands = mocks.Stub();
mocks.ReplayAll();
using (var distributionView = new FailureMechanismContributionView(assessmentSection, viewCommands))
{
// Call
ShowFormWithView(distributionView);
// Assert
var dataGridView = (DataGridView) new ControlTester(dataGridViewControlName).TheObject;
string isRelevantColumnHeaderText = dataGridView.Columns[isRelevantColumnIndex].HeaderText;
Assert.AreEqual("Algemeen filter", isRelevantColumnHeaderText);
string nameColumnHeaderText = dataGridView.Columns[nameColumnIndex].HeaderText;
Assert.AreEqual("Toetsspoor", nameColumnHeaderText);
string codeColumnHeaderText = dataGridView.Columns[codeColumnIndex].HeaderText;
Assert.AreEqual("Label", codeColumnHeaderText);
string contributionColumnHeaderText = dataGridView.Columns[contributionColumnIndex].HeaderText;
Assert.AreEqual("Toegestane bijdrage aan faalkans [%]", contributionColumnHeaderText);
string probabilitySpaceColumnHeaderText = dataGridView.Columns[probabilitySpaceColumnIndex].HeaderText;
Assert.AreEqual("Faalkansruimte [1/jaar]", probabilitySpaceColumnHeaderText);
}
mocks.VerifyAll();
}
[Test]
public void Data_SetToSomeContribution_ShowsColumnsWithData()
{
// Setup
var random = new Random(21);
int otherContribution = random.Next(0, 100);
const double norm = 1.0 / 30000;
var assessmentSection = new AssessmentSection(AssessmentSectionComposition.Dike);
const string testName = "testName";
const string testCode = "testCode";
double testContribution = 100 - otherContribution;
var mocks = new MockRepository();
var viewCommands = mocks.Stub();
var someMechanism = mocks.StrictMock(testName, testCode, 1);
someMechanism.Contribution = testContribution;
mocks.ReplayAll();
var initialContribution = new FailureMechanismContribution(new[]
{
someMechanism
}, otherContribution, norm, norm);
using (var distributionView = new FailureMechanismContributionView(assessmentSection, viewCommands)
{
AssessmentSection = assessmentSection
})
{
ShowFormWithView(distributionView);
// Call
distributionView.Data = initialContribution;
// Assert
var dataGridView = (DataGridView) new ControlTester(dataGridViewControlName).TheObject;
DataGridViewRow row = dataGridView.Rows[0];
var nameCell = (DataGridViewTextBoxCell) row.Cells[nameColumnIndex];
Assert.AreEqual(testName, nameCell.Value);
var codeCell = (DataGridViewTextBoxCell) row.Cells[codeColumnIndex];
Assert.AreEqual(testCode, codeCell.Value);
var contributionCell = (DataGridViewTextBoxCell) row.Cells[contributionColumnIndex];
Assert.AreEqual(testContribution, contributionCell.Value);
var probabilitySpaceCell = (DataGridViewTextBoxCell) row.Cells[probabilitySpaceColumnIndex];
Assert.AreEqual(initialContribution.Distribution.Single(d => d.FailureMechanism == someMechanism).ProbabilitySpace, probabilitySpaceCell.Value);
}
mocks.VerifyAll();
}
[Test]
public void Data_SetNewData_DetachesFromOldData()
{
// Setup
const int initialReturnPeriod = 100;
const int newReturnPeriod = 200;
var random = new Random(21);
var assessmentSection1 = new AssessmentSection(AssessmentSectionComposition.Dike);
var assessmentSection2 = new AssessmentSection(AssessmentSectionComposition.Dike);
var mocks = new MockRepository();
var viewCommands = mocks.Stub();
var someMechanism = mocks.Stub();
mocks.ReplayAll();
var initialContribution = new FailureMechanismContribution(new[]
{
someMechanism
}, random.Next(0, 100),
1.0 / initialReturnPeriod,
1.0 / initialReturnPeriod);
var newContribution = new FailureMechanismContribution(new[]
{
someMechanism
}, random.Next(0, 100),
1.0 / newReturnPeriod,
1.0 / newReturnPeriod);
using (var distributionView = new FailureMechanismContributionView(assessmentSection1, viewCommands)
{
Data = initialContribution,
AssessmentSection = assessmentSection1
})
{
ShowFormWithView(distributionView);
var returnPeriodLabel = new ControlTester(returnPeriodLabelName);
// Precondition
string initialReturnPeriodLabelText = $"Norm van het dijktraject: 1 / {initialReturnPeriod.ToString(CultureInfo.CurrentCulture)}";
Assert.AreEqual(initialReturnPeriodLabelText, returnPeriodLabel.Properties.Text);
// Call
distributionView.Data = newContribution;
distributionView.AssessmentSection = assessmentSection2;
// Assert
string newReturnPeriodLabelText = $"Norm van het dijktraject: 1 / {newReturnPeriod.ToString(CultureInfo.CurrentCulture)}";
Assert.AreEqual(newReturnPeriodLabelText, returnPeriodLabel.Properties.Text);
}
mocks.VerifyAll();
}
[Test]
public void UpdateObserver_ChangeReturnPeriodAndNotify_UpdateReturnPeriodTextBox()
{
// Setup
const int initialReturnPeriod = 100;
const int newReturnPeriod = 200;
var random = new Random(21);
var assessmentSection = new AssessmentSection(AssessmentSectionComposition.Dike);
var mocks = new MockRepository();
var viewCommands = mocks.Stub();
var someMechanism = mocks.Stub();
mocks.ReplayAll();
var contribution = new FailureMechanismContribution(new[]
{
someMechanism
}, random.Next(0, 100),
1.0 / initialReturnPeriod,
1.0 / 300);
using (var distributionView = new FailureMechanismContributionView(assessmentSection, viewCommands)
{
Data = contribution,
AssessmentSection = assessmentSection
})
{
ShowFormWithView(distributionView);
var returnPeriodLabel = new ControlTester(returnPeriodLabelName);
// Precondition
string initialReturnPeriodLabelText = $"Norm van het dijktraject: 1 / {initialReturnPeriod.ToString(CultureInfo.CurrentCulture)}";
Assert.AreEqual(initialReturnPeriodLabelText, returnPeriodLabel.Properties.Text);
// Call
contribution.LowerLimitNorm = 1.0 / newReturnPeriod;
contribution.NotifyObservers();
// Assert
string newReturnPeriodLabelText = $"Norm van het dijktraject: 1 / {newReturnPeriod.ToString(CultureInfo.CurrentCulture)}";
Assert.AreEqual(newReturnPeriodLabelText, returnPeriodLabel.Properties.Text);
}
mocks.VerifyAll();
}
[Test]
public void UpdateObserver_ChangeNormativeNormAndNotify_UpdateReturnPeriodTextBox()
{
// Setup
const int lowerLimitNorm = 100;
const int signalingNorm = 1000;
var random = new Random(21);
var assessmentSection = new AssessmentSection(AssessmentSectionComposition.Dike);
var mocks = new MockRepository();
var viewCommands = mocks.Stub();
var someMechanism = mocks.Stub();
mocks.ReplayAll();
var contribution = new FailureMechanismContribution(new[]
{
someMechanism
}, random.Next(0, 100), 1.0 / lowerLimitNorm, 1.0 / signalingNorm);
using (var distributionView = new FailureMechanismContributionView(assessmentSection, viewCommands)
{
Data = contribution,
AssessmentSection = assessmentSection
})
{
ShowFormWithView(distributionView);
var returnPeriodLabel = new ControlTester(returnPeriodLabelName);
// Precondition
string initialReturnPeriodLabelText = $"Norm van het dijktraject: 1 / {lowerLimitNorm.ToString(CultureInfo.CurrentCulture)}";
Assert.AreEqual(initialReturnPeriodLabelText, returnPeriodLabel.Properties.Text);
// Call
contribution.NormativeNorm = NormType.Signaling;
contribution.NotifyObservers();
// Assert
string newReturnPeriodLabelText = $"Norm van het dijktraject: 1 / {signalingNorm.ToString(CultureInfo.CurrentCulture)}";
Assert.AreEqual(newReturnPeriodLabelText, returnPeriodLabel.Properties.Text);
}
mocks.VerifyAll();
}
[Test]
public void GivenFailureMechanismContributionView_WhenObserverNotified_UpdatesDataSource()
{
// Given
var mocks = new MockRepository();
var assessmentSection = mocks.Stub();
var viewCommands = mocks.Stub();
var failureMechanism = mocks.Stub();
mocks.ReplayAll();
using (var view = new FailureMechanismContributionView(assessmentSection, viewCommands))
{
FailureMechanismContribution contributionData = FailureMechanismContributionTestFactory.CreateFailureMechanismContribution(new[]
{
failureMechanism
});
view.Data = contributionData;
ShowFormWithView(view);
// Precondition
var dataGridView = (DataGridView) new ControlTester(dataGridViewControlName).TheObject;
Assert.AreEqual(2, dataGridView.RowCount);
// When
contributionData.UpdateContributions(new IFailureMechanism[0], 30);
contributionData.NotifyObservers();
// Then
Assert.AreEqual(1, dataGridView.RowCount);
}
mocks.VerifyAll();
}
[Test]
[TestCase(true)]
[TestCase(false)]
public void GivenFailureMechanismContributionView_WhenSettingData_ProperlyInitializeRelevancyColumn(bool isFailureMechanismRelevant)
{
// Given
var assessmentSection = new AssessmentSection(AssessmentSectionComposition.Dike);
var mocks = new MockRepository();
var viewCommands = mocks.Stub();
var failureMechanism = mocks.Stub();
failureMechanism.Stub(fm => fm.Name).Return("A");
failureMechanism.Stub(fm => fm.Code).Return("C");
failureMechanism.Contribution = 100;
failureMechanism.IsRelevant = isFailureMechanismRelevant;
mocks.ReplayAll();
using (var view = new FailureMechanismContributionView(assessmentSection, viewCommands))
{
// When
FailureMechanismContribution contributionData = FailureMechanismContributionTestFactory.CreateFailureMechanismContribution(new[]
{
failureMechanism
});
view.Data = contributionData;
view.AssessmentSection = assessmentSection;
ShowFormWithView(view);
// Then
var dataGridView = (DataGridView) new ControlTester(dataGridViewControlName).TheObject;
DataGridViewRow row = dataGridView.Rows[0];
var isRelevantGridCell = (DataGridViewCheckBoxCell) row.Cells[isRelevantColumnIndex];
Assert.AreEqual(isFailureMechanismRelevant, isRelevantGridCell.Value);
}
mocks.VerifyAll();
}
[Test]
public void GivenFailureMechanismContributionView_WhenSettingDataWithZeroContributionFailureMechanism_ProbabilitySpaceShowsAsNotApplicable()
{
// Given
var assessmentSection = new AssessmentSection(AssessmentSectionComposition.Dike);
const double norm = 1.0 / 30000;
var mocks = new MockRepository();
var viewCommands = mocks.Stub();
var failureMechanism = mocks.Stub();
failureMechanism.Stub(fm => fm.Name).Return("A");
failureMechanism.Stub(fm => fm.Code).Return("C");
failureMechanism.Contribution = 0;
mocks.ReplayAll();
using (var view = new FailureMechanismContributionView(assessmentSection, viewCommands))
{
// When
var contributionData = new FailureMechanismContribution(new[]
{
failureMechanism
}, 100, norm, norm);
view.Data = contributionData;
view.AssessmentSection = assessmentSection;
ShowFormWithView(view);
// Then
var dataGridView = (DataGridView) new ControlTester(dataGridViewControlName).TheObject;
DataGridViewRow zeroContributionFailureMechanismRow = dataGridView.Rows[0];
DataGridViewCell probabilitySpaceCell = zeroContributionFailureMechanismRow.Cells[probabilitySpaceColumnIndex];
Assert.AreEqual("n.v.t", probabilitySpaceCell.FormattedValue);
}
mocks.VerifyAll();
}
[Test]
public void GivenFailureMechanismContributionView_WhenSettingDataWithNormalContributionFailureMechanism_ProbabilitySpaceShowsAsLocalisedText()
{
// Given
const double contribution = 25.0;
const double norm = 1.0 / 30000;
var assessmentSection = new AssessmentSection(AssessmentSectionComposition.Dike);
var mocks = new MockRepository();
var viewCommands = mocks.Stub();
var failureMechanism = mocks.Stub();
failureMechanism.Stub(fm => fm.Name).Return("A");
failureMechanism.Stub(fm => fm.Code).Return("C");
failureMechanism.Contribution = contribution;
mocks.ReplayAll();
using (var view = new FailureMechanismContributionView(assessmentSection, viewCommands))
{
// When
var contributionData = new FailureMechanismContribution(new[]
{
failureMechanism
}, 100.0 - contribution,
norm,
norm);
view.Data = contributionData;
view.AssessmentSection = assessmentSection;
ShowFormWithView(view);
// Then
var dataGridView = (DataGridView) new ControlTester(dataGridViewControlName).TheObject;
DataGridViewRow zeroContributionFailureMechanismRow = dataGridView.Rows[0];
DataGridViewCell probabilitySpaceCell = zeroContributionFailureMechanismRow.Cells[probabilitySpaceColumnIndex];
Assert.AreEqual("1/#,#", probabilitySpaceCell.InheritedStyle.Format);
string expectedTextValue = new FailureMechanismContributionItem(failureMechanism, norm)
.ProbabilitySpace.ToString(probabilitySpaceCell.InheritedStyle.Format, probabilitySpaceCell.InheritedStyle.FormatProvider);
Assert.AreEqual(expectedTextValue, probabilitySpaceCell.FormattedValue);
}
mocks.VerifyAll();
}
[Test]
[TestCase(AssessmentSectionComposition.Dike, "Dijk")]
[TestCase(AssessmentSectionComposition.Dune, "Duin")]
[TestCase(AssessmentSectionComposition.DikeAndDune, "Dijk / Duin")]
public void CompositionComboBox_WithDataSet_SelectedDisplayTextAndValueCorrect(AssessmentSectionComposition composition, string expectedDisplayText)
{
// Setup
var assessmentSection = new AssessmentSection(composition);
var mocks = new MockRepository();
var viewCommands = mocks.Stub();
mocks.ReplayAll();
using (var view = new FailureMechanismContributionView(assessmentSection, viewCommands))
{
ShowFormWithView(view);
view.Data = assessmentSection.FailureMechanismContribution;
view.AssessmentSection = assessmentSection;
// Call
var compositionLabel = (Label) new ControlTester(assessmentSectionConfigurationLabelName).TheObject;
// Assert
string expectedLabelValue = $"Trajecttype: {expectedDisplayText}";
Assert.AreEqual(expectedLabelValue, compositionLabel.Text);
}
mocks.VerifyAll();
}
[Test]
[TestCase(AssessmentSectionComposition.Dike, AssessmentSectionComposition.Dune)]
[TestCase(AssessmentSectionComposition.Dike, AssessmentSectionComposition.DikeAndDune)]
[TestCase(AssessmentSectionComposition.Dune, AssessmentSectionComposition.Dike)]
[TestCase(AssessmentSectionComposition.Dune, AssessmentSectionComposition.DikeAndDune)]
[TestCase(AssessmentSectionComposition.DikeAndDune, AssessmentSectionComposition.Dike)]
[TestCase(AssessmentSectionComposition.DikeAndDune, AssessmentSectionComposition.Dune)]
public void UpdateObserver_ChangeAssessmentSectionCompositionAndNotify_ChangeCompositionComboBoxItem(
AssessmentSectionComposition initialComposition,
AssessmentSectionComposition newComposition)
{
// Given
var assessmentSection = new AssessmentSection(initialComposition);
var mocks = new MockRepository();
var viewCommands = mocks.Stub();
mocks.ReplayAll();
using (var view = new FailureMechanismContributionView(assessmentSection, viewCommands)
{
Data = assessmentSection.FailureMechanismContribution,
AssessmentSection = assessmentSection
})
{
ShowFormWithView(view);
// Precondition
Assert.AreNotEqual(assessmentSection.Composition, newComposition);
// Call
assessmentSection.ChangeComposition(newComposition);
assessmentSection.FailureMechanismContribution.NotifyObservers();
// Assert
var compositionLabel = (Label) new ControlTester(assessmentSectionConfigurationLabelName).TheObject;
string compositionDisplayName = new EnumDisplayWrapper(newComposition).DisplayName;
string newCompositionValue = $"Trajecttype: {compositionDisplayName}";
Assert.AreEqual(newCompositionValue, compositionLabel.Text);
}
mocks.VerifyAll();
}
[Test]
public void GivenView_WhenSettingRelevantFailureMechanism_RowIsStyledAsEnabled()
{
// Given
var mocks = new MockRepository();
var assessmentSection = mocks.Stub();
var viewCommands = mocks.Stub();
var failureMechanism = mocks.Stub();
failureMechanism.IsRelevant = true;
mocks.ReplayAll();
using (var view = new FailureMechanismContributionView(assessmentSection, viewCommands))
{
ShowFormWithView(view);
FailureMechanismContribution contribution = FailureMechanismContributionTestFactory.CreateFailureMechanismContribution(new[]
{
failureMechanism
});
// When
view.Data = contribution;
// Then
var dataGridView = (DataGridView) new ControlTester(dataGridViewControlName).TheObject;
DataGridViewRow row = dataGridView.Rows[0];
for (var i = 0; i < row.Cells.Count; i++)
{
if (i == isRelevantColumnIndex)
{
continue;
}
DataGridViewCell cell = row.Cells[i];
AssertIsCellStyledAsEnabled(cell);
}
}
mocks.VerifyAll();
}
[Test]
public void GivenView_WhenSettingFailureMechanismThatIsIrrelevant_RowIsStyledAsGreyedOut()
{
// Given
var mocks = new MockRepository();
var assessmentSection = mocks.Stub();
var viewCommands = mocks.Stub();
var failureMechanism = mocks.Stub();
failureMechanism.IsRelevant = false;
mocks.ReplayAll();
using (var view = new FailureMechanismContributionView(assessmentSection, viewCommands))
{
ShowFormWithView(view);
FailureMechanismContribution contribution = FailureMechanismContributionTestFactory.CreateFailureMechanismContribution(new[]
{
failureMechanism
});
// When
view.Data = contribution;
// Then
var dataGridView = (DataGridView) new ControlTester(dataGridViewControlName).TheObject;
DataGridViewRow row = dataGridView.Rows[0];
for (var i = 0; i < row.Cells.Count; i++)
{
if (i == isRelevantColumnIndex)
{
continue;
}
DataGridViewCell cell = row.Cells[i];
AssertIsCellStyleGreyedOut(cell);
}
}
mocks.VerifyAll();
}
[Test]
[TestCase(true)]
[TestCase(false)]
public void GivenView_IsRelevantPropertyChangeNotified_RowStylesUpdates(bool initialIsRelevant)
{
// Given
var failureMechanismObservers = new List();
var mocks = new MockRepository();
var viewCommands = mocks.Stub();
var failureMechanism = mocks.Stub();
failureMechanism.Stub(fm => fm.Name).Return("A");
failureMechanism.Stub(fm => fm.Code).Return("C");
failureMechanism.IsRelevant = initialIsRelevant;
failureMechanism.Stub(fm => fm.Attach(null))
.IgnoreArguments()
.WhenCalled(invocation => failureMechanismObservers.Add((IObserver) invocation.Arguments[0]));
failureMechanism.Stub(fm => fm.NotifyObservers())
.WhenCalled(invocation => failureMechanismObservers[0].UpdateObserver());
failureMechanism.Stub(fm => fm.Detach(null))
.IgnoreArguments()
.WhenCalled(invocation => failureMechanismObservers.Remove((IObserver) invocation.Arguments[0]));
var assessmentSection = mocks.Stub();
assessmentSection.Stub(section => section.GetFailureMechanisms()).Return(new[]
{
failureMechanism
});
assessmentSection.Stub(section => section.Composition).Return(AssessmentSectionComposition.Dike);
mocks.ReplayAll();
using (var view = new FailureMechanismContributionView(assessmentSection, viewCommands))
{
ShowFormWithView(view);
FailureMechanismContribution contribution = FailureMechanismContributionTestFactory.CreateFailureMechanismContribution(new[]
{
failureMechanism
});
view.Data = contribution;
view.AssessmentSection = assessmentSection;
var dataGridView = (DataGridView) new ControlTester(dataGridViewControlName).TheObject;
DataGridViewRow row = dataGridView.Rows[0];
for (var i = 0; i < row.Cells.Count; i++)
{
if (i != isRelevantColumnIndex)
{
DataGridViewCell cell = row.Cells[i];
if (failureMechanism.IsRelevant)
{
AssertIsCellStyledAsEnabled(cell);
}
else
{
AssertIsCellStyleGreyedOut(cell);
}
}
}
// When
failureMechanism.IsRelevant = !initialIsRelevant;
failureMechanism.NotifyObservers();
// Then
for (var i = 0; i < row.Cells.Count; i++)
{
if (i != isRelevantColumnIndex)
{
DataGridViewCell cell = row.Cells[i];
if (failureMechanism.IsRelevant)
{
AssertIsCellStyledAsEnabled(cell);
}
else
{
AssertIsCellStyleGreyedOut(cell);
}
}
}
}
mocks.VerifyAll();
}
[Test]
public void GivenView_WhenMakingFailureMechanismIrrelevant_UpdateFailureMechanismAndNotifyObserversAndCloseRelatedViews()
{
// Given
var mocks = new MockRepository();
var assessmentSection = mocks.Stub();
var failureMechanism = mocks.Stub();
failureMechanism.Stub(fm => fm.Name).Return("A");
failureMechanism.Stub(fm => fm.Code).Return("b");
failureMechanism.IsRelevant = true;
failureMechanism.Expect(fm => fm.NotifyObservers());
var viewCommands = mocks.Stub();
viewCommands.Expect(c => c.RemoveAllViewsForItem(failureMechanism));
mocks.ReplayAll();
FailureMechanismContribution contribution = FailureMechanismContributionTestFactory.CreateFailureMechanismContribution(new[]
{
failureMechanism
});
using (var view = new FailureMechanismContributionView(assessmentSection, viewCommands))
{
ShowFormWithView(view);
view.Data = contribution;
var dataGridView = (DataGridView) new ControlTester(dataGridViewControlName).TheObject;
DataGridViewRow row = dataGridView.Rows[0];
// When
row.Cells[isRelevantColumnIndex].Value = false;
// Then
Assert.IsFalse(failureMechanism.IsRelevant);
}
mocks.VerifyAll();
}
[Test]
public void GivenView_WhenSettingFailureMechanismThatIsAlwaysRelevant_IsRelevantFlagTrueAndReadonly()
{
// Given
var mocks = new MockRepository();
var assessmentSection = mocks.Stub();
var viewCommands = mocks.Stub();
mocks.ReplayAll();
using (var view = new FailureMechanismContributionView(assessmentSection, viewCommands))
{
ShowFormWithView(view);
FailureMechanismContribution contribution = FailureMechanismContributionTestFactory.CreateFailureMechanismContribution();
// Precondition:
FailureMechanismContributionItem[] contributionItems = contribution.Distribution.ToArray();
Assert.AreEqual(1, contributionItems.Length);
Assert.IsTrue(contributionItems[0].IsAlwaysRelevant);
Assert.IsTrue(contributionItems[0].IsRelevant);
// When
view.Data = contribution;
// Then
var dataGridView = (DataGridView) new ControlTester(dataGridViewControlName).TheObject;
DataGridViewRow row = dataGridView.Rows[0];
DataGridViewCell isRelevantCell = row.Cells[isRelevantColumnIndex];
Assert.IsTrue((bool) isRelevantCell.Value);
Assert.IsTrue(isRelevantCell.ReadOnly);
}
mocks.VerifyAll();
}
public override void Setup()
{
base.Setup();
testForm = new Form();
}
public override void TearDown()
{
testForm.Dispose();
base.TearDown();
}
private void ShowFormWithView(FailureMechanismContributionView distributionView)
{
testForm.Controls.Add(distributionView);
testForm.Show();
}
private static void AssertIsCellStyledAsEnabled(DataGridViewCell cell)
{
Color enabledBackColor = Color.FromKnownColor(KnownColor.White);
Color enabledForeColor = Color.FromKnownColor(KnownColor.ControlText);
Assert.IsTrue(cell.ReadOnly);
Assert.AreEqual(enabledBackColor, cell.Style.BackColor,
"Color does not match for column index: " + cell.ColumnIndex);
Assert.AreEqual(enabledForeColor, cell.Style.ForeColor,
"Color does not match for column index: " + cell.ColumnIndex);
}
private static void AssertIsCellStyleGreyedOut(DataGridViewCell cell)
{
Color irrelevantMechanismBackColor = Color.FromKnownColor(KnownColor.DarkGray);
Color irrelevantMechanismForeColor = Color.FromKnownColor(KnownColor.GrayText);
Assert.IsTrue(cell.ReadOnly);
Assert.AreEqual(irrelevantMechanismBackColor, cell.Style.BackColor,
"Color does not match for column index: " + cell.ColumnIndex);
Assert.AreEqual(irrelevantMechanismForeColor, cell.Style.ForeColor,
"Color does not match for column index: " + cell.ColumnIndex);
}
}
}