// 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.Linq; using Core.Common.Base; using Core.Common.Gui.Commands; using Core.Common.TestUtil; using Core.Common.Util.Extensions; using NUnit.Framework; using Rhino.Mocks; using Ringtoets.ClosingStructures.Data; using Ringtoets.Common.Data.AssessmentSection; using Ringtoets.Common.Data.Hydraulics; using Ringtoets.Common.Data.Structures; using Ringtoets.Common.Data.TestUtil; using Ringtoets.Common.Data.TestUtil.IllustrationPoints; using Ringtoets.GrassCoverErosionInwards.Data; using Ringtoets.GrassCoverErosionOutwards.Data; using Ringtoets.GrassCoverErosionOutwards.Data.TestUtil; using Ringtoets.HeightStructures.Data; using Ringtoets.Integration.Data; using Ringtoets.Integration.Data.Merge; using Ringtoets.Integration.Plugin.Merge; using Ringtoets.MacroStabilityInwards.Data; using Ringtoets.Piping.Data; using Ringtoets.StabilityPointStructures.Data; using Ringtoets.StabilityStoneCover.Data; using Ringtoets.WaveImpactAsphaltCover.Data; namespace Ringtoets.Integration.Plugin.Test.Merge { [TestFixture] public class AssessmentSectionMergeHandlerTest { [Test] public void Constructor_ViewCommandsNull_ThrowsArgumentNullException() { // Call TestDelegate call = () => new AssessmentSectionMergeHandler(null); // Assert var exception = Assert.Throws(call); Assert.AreEqual("viewCommands", exception.ParamName); } [Test] public void Constructor_ExpectedValues() { // Setup var mocks = new MockRepository(); var viewCommands = mocks.StrictMock(); mocks.ReplayAll(); // Call var handler = new AssessmentSectionMergeHandler(viewCommands); // Assert Assert.IsInstanceOf(handler); mocks.VerifyAll(); } [Test] public void PerformMerge_TargetAssessmentSectionNull_ThrowsArgumentNullException() { // Setup var mocks = new MockRepository(); var viewCommands = mocks.StrictMock(); mocks.ReplayAll(); var handler = new AssessmentSectionMergeHandler(viewCommands); // Call TestDelegate call = () => handler.PerformMerge(null, new AssessmentSectionMergeData( new AssessmentSection(AssessmentSectionComposition.Dike), new AssessmentSectionMergeData.ConstructionProperties())); // Assert var exception = Assert.Throws(call); Assert.AreEqual("targetAssessmentSection", exception.ParamName); mocks.VerifyAll(); } [Test] public void PerformMerge_MergeDataNull_ThrowsArgumentNullException() { // Setup var mocks = new MockRepository(); var viewCommands = mocks.StrictMock(); mocks.ReplayAll(); var handler = new AssessmentSectionMergeHandler(viewCommands); // Call TestDelegate call = () => handler.PerformMerge(new AssessmentSection(AssessmentSectionComposition.Dike), null); // Assert var exception = Assert.Throws(call); Assert.AreEqual("mergeData", exception.ParamName); } [Test] public void PerformMerge_WithAllData_AllViewsForTargetAssessmentSectionClosed() { // Setup var targetAssessmentSection = new AssessmentSection(AssessmentSectionComposition.Dike); var mocks = new MockRepository(); var viewCommands = mocks.StrictMock(); viewCommands.Expect(vc => vc.RemoveAllViewsForItem(targetAssessmentSection)); mocks.ReplayAll(); var handler = new AssessmentSectionMergeHandler(viewCommands); // Call handler.PerformMerge(targetAssessmentSection, new AssessmentSectionMergeData( new AssessmentSection(AssessmentSectionComposition.Dike), new AssessmentSectionMergeData.ConstructionProperties())); // Assert mocks.VerifyAll(); } [Test] public void PerformMerge_WithAllFailureMechanismsToMerge_SetNewFailureMechanisms() { // Setup var mocks = new MockRepository(); var viewCommands = mocks.Stub(); mocks.ReplayAll(); var handler = new AssessmentSectionMergeHandler(viewCommands); var targetAssessmentSection = new AssessmentSection(AssessmentSectionComposition.Dike); var sourceAssessmentSection = new AssessmentSection(AssessmentSectionComposition.Dike); // Call handler.PerformMerge(targetAssessmentSection, new AssessmentSectionMergeData( sourceAssessmentSection, new AssessmentSectionMergeData.ConstructionProperties { MergePiping = true, MergeGrassCoverErosionInwards = true, MergeMacroStabilityInwards = true, MergeMacroStabilityOutwards = true, MergeMicrostability = true, MergeStabilityStoneCover = true, MergeWaveImpactAsphaltCover = true, MergeWaterPressureAsphaltCover = true, MergeGrassCoverErosionOutwards = true, MergeGrassCoverSlipOffOutwards = true, MergeGrassCoverSlipOffInwards = true, MergeHeightStructures = true, MergeClosingStructures = true, MergePipingStructure = true, MergeStabilityPointStructures = true, MergeStrengthStabilityLengthwiseConstruction = true, MergeDuneErosion = true, MergeTechnicalInnovation = true })); // Assert Assert.AreSame(sourceAssessmentSection.Piping, targetAssessmentSection.Piping); Assert.AreSame(sourceAssessmentSection.GrassCoverErosionInwards, targetAssessmentSection.GrassCoverErosionInwards); Assert.AreSame(sourceAssessmentSection.MacroStabilityInwards, targetAssessmentSection.MacroStabilityInwards); Assert.AreSame(sourceAssessmentSection.MacroStabilityOutwards, targetAssessmentSection.MacroStabilityOutwards); Assert.AreSame(sourceAssessmentSection.Microstability, targetAssessmentSection.Microstability); Assert.AreSame(sourceAssessmentSection.StabilityStoneCover, targetAssessmentSection.StabilityStoneCover); Assert.AreSame(sourceAssessmentSection.WaveImpactAsphaltCover, targetAssessmentSection.WaveImpactAsphaltCover); Assert.AreSame(sourceAssessmentSection.WaterPressureAsphaltCover, targetAssessmentSection.WaterPressureAsphaltCover); Assert.AreSame(sourceAssessmentSection.GrassCoverErosionOutwards, targetAssessmentSection.GrassCoverErosionOutwards); Assert.AreSame(sourceAssessmentSection.GrassCoverSlipOffOutwards, targetAssessmentSection.GrassCoverSlipOffOutwards); Assert.AreSame(sourceAssessmentSection.GrassCoverSlipOffInwards, targetAssessmentSection.GrassCoverSlipOffInwards); Assert.AreSame(sourceAssessmentSection.HeightStructures, targetAssessmentSection.HeightStructures); Assert.AreSame(sourceAssessmentSection.ClosingStructures, targetAssessmentSection.ClosingStructures); Assert.AreSame(sourceAssessmentSection.PipingStructure, targetAssessmentSection.PipingStructure); Assert.AreSame(sourceAssessmentSection.StabilityPointStructures, targetAssessmentSection.StabilityPointStructures); Assert.AreSame(sourceAssessmentSection.StrengthStabilityLengthwiseConstruction, targetAssessmentSection.StrengthStabilityLengthwiseConstruction); Assert.AreSame(sourceAssessmentSection.DuneErosion, targetAssessmentSection.DuneErosion); Assert.AreSame(sourceAssessmentSection.TechnicalInnovation, targetAssessmentSection.TechnicalInnovation); } [Test] public void PerformMerge_WithNoFailureMechanismsToMerge_FailureMechanismsSame() { // Setup var mocks = new MockRepository(); var viewCommands = mocks.Stub(); mocks.ReplayAll(); var handler = new AssessmentSectionMergeHandler(viewCommands); var targetAssessmentSection = new AssessmentSection(AssessmentSectionComposition.Dike); var sourceAssessmentSection = new AssessmentSection(AssessmentSectionComposition.Dike); // Call handler.PerformMerge(targetAssessmentSection, new AssessmentSectionMergeData( sourceAssessmentSection, new AssessmentSectionMergeData.ConstructionProperties())); // Assert Assert.AreNotSame(sourceAssessmentSection.Piping, targetAssessmentSection.Piping); Assert.AreNotSame(sourceAssessmentSection.GrassCoverErosionInwards, targetAssessmentSection.GrassCoverErosionInwards); Assert.AreNotSame(sourceAssessmentSection.MacroStabilityInwards, targetAssessmentSection.MacroStabilityInwards); Assert.AreNotSame(sourceAssessmentSection.MacroStabilityOutwards, targetAssessmentSection.MacroStabilityOutwards); Assert.AreNotSame(sourceAssessmentSection.Microstability, targetAssessmentSection.Microstability); Assert.AreNotSame(sourceAssessmentSection.StabilityStoneCover, targetAssessmentSection.StabilityStoneCover); Assert.AreNotSame(sourceAssessmentSection.WaveImpactAsphaltCover, targetAssessmentSection.WaveImpactAsphaltCover); Assert.AreNotSame(sourceAssessmentSection.WaterPressureAsphaltCover, targetAssessmentSection.WaterPressureAsphaltCover); Assert.AreNotSame(sourceAssessmentSection.GrassCoverErosionOutwards, targetAssessmentSection.GrassCoverErosionOutwards); Assert.AreNotSame(sourceAssessmentSection.GrassCoverSlipOffOutwards, targetAssessmentSection.GrassCoverSlipOffOutwards); Assert.AreNotSame(sourceAssessmentSection.GrassCoverSlipOffInwards, targetAssessmentSection.GrassCoverSlipOffInwards); Assert.AreNotSame(sourceAssessmentSection.HeightStructures, targetAssessmentSection.HeightStructures); Assert.AreNotSame(sourceAssessmentSection.ClosingStructures, targetAssessmentSection.ClosingStructures); Assert.AreNotSame(sourceAssessmentSection.PipingStructure, targetAssessmentSection.PipingStructure); Assert.AreNotSame(sourceAssessmentSection.StabilityPointStructures, targetAssessmentSection.StabilityPointStructures); Assert.AreNotSame(sourceAssessmentSection.StrengthStabilityLengthwiseConstruction, targetAssessmentSection.StrengthStabilityLengthwiseConstruction); Assert.AreNotSame(sourceAssessmentSection.DuneErosion, targetAssessmentSection.DuneErosion); Assert.AreNotSame(sourceAssessmentSection.TechnicalInnovation, targetAssessmentSection.TechnicalInnovation); } [Test] public void PerformMerge_WithAllFailureMechanismsToMerge_LogMessages() { // Setup var mocks = new MockRepository(); var viewCommands = mocks.Stub(); mocks.ReplayAll(); var handler = new AssessmentSectionMergeHandler(viewCommands); var targetAssessmentSection = new AssessmentSection(AssessmentSectionComposition.Dike); var sourceAssessmentSection = new AssessmentSection(AssessmentSectionComposition.Dike); // Call Action call = () => handler.PerformMerge(targetAssessmentSection, new AssessmentSectionMergeData( sourceAssessmentSection, new AssessmentSectionMergeData.ConstructionProperties { MergePiping = true, MergeGrassCoverErosionInwards = true, MergeMacroStabilityInwards = true, MergeMacroStabilityOutwards = true, MergeMicrostability = true, MergeStabilityStoneCover = true, MergeWaveImpactAsphaltCover = true, MergeWaterPressureAsphaltCover = true, MergeGrassCoverErosionOutwards = true, MergeGrassCoverSlipOffOutwards = true, MergeGrassCoverSlipOffInwards = true, MergeHeightStructures = true, MergeClosingStructures = true, MergePipingStructure = true, MergeStabilityPointStructures = true, MergeStrengthStabilityLengthwiseConstruction = true, MergeDuneErosion = true, MergeTechnicalInnovation = true })); // Assert TestHelper.AssertLogMessages(call, messages => { string[] msgs = messages.ToArray(); Assert.AreEqual(18, msgs.Length); Assert.AreEqual("Gegevens van toetsspoor 'Dijken en dammen - Piping' zijn vervangen.", msgs[0]); Assert.AreEqual("Gegevens van toetsspoor 'Dijken en dammen - Grasbekleding erosie kruin en binnentalud' zijn vervangen.", msgs[1]); Assert.AreEqual("Gegevens van toetsspoor 'Dijken en dammen - Macrostabiliteit binnenwaarts' zijn vervangen.", msgs[2]); Assert.AreEqual("Gegevens van toetsspoor 'Dijken en dammen - Macrostabiliteit buitenwaarts' zijn vervangen.", msgs[3]); Assert.AreEqual("Gegevens van toetsspoor 'Dijken en dammen - Microstabiliteit' zijn vervangen.", msgs[4]); Assert.AreEqual("Gegevens van toetsspoor 'Dijken en dammen - Stabiliteit steenzetting' zijn vervangen.", msgs[5]); Assert.AreEqual("Gegevens van toetsspoor 'Dijken en dammen - Golfklappen op asfaltbekleding' zijn vervangen.", msgs[6]); Assert.AreEqual("Gegevens van toetsspoor 'Dijken en dammen - Wateroverdruk bij asfaltbekleding' zijn vervangen.", msgs[7]); Assert.AreEqual("Gegevens van toetsspoor 'Dijken en dammen - Grasbekleding erosie buitentalud' zijn vervangen.", msgs[8]); Assert.AreEqual("Gegevens van toetsspoor 'Dijken en dammen - Grasbekleding afschuiven buitentalud' zijn vervangen.", msgs[9]); Assert.AreEqual("Gegevens van toetsspoor 'Dijken en dammen - Grasbekleding afschuiven binnentalud' zijn vervangen.", msgs[10]); Assert.AreEqual("Gegevens van toetsspoor 'Kunstwerken - Hoogte kunstwerk' zijn vervangen.", msgs[11]); Assert.AreEqual("Gegevens van toetsspoor 'Kunstwerken - Betrouwbaarheid sluiting kunstwerk' zijn vervangen.", msgs[12]); Assert.AreEqual("Gegevens van toetsspoor 'Kunstwerken - Piping bij kunstwerk' zijn vervangen.", msgs[13]); Assert.AreEqual("Gegevens van toetsspoor 'Kunstwerken - Sterkte en stabiliteit puntconstructies' zijn vervangen.", msgs[14]); Assert.AreEqual("Gegevens van toetsspoor 'Kunstwerken - Sterkte en stabiliteit langsconstructies' zijn vervangen.", msgs[15]); Assert.AreEqual("Gegevens van toetsspoor 'Duinwaterkering - Duinafslag' zijn vervangen.", msgs[16]); Assert.AreEqual("Gegevens van toetsspoor 'Technische innovaties - Technische innovaties' zijn vervangen.", msgs[17]); }); } [Test] public void GivenFailureMechanismWithWithCalculations_WhenCalculationHasReferenceToHydraulicBoundaryLocation_ThenReferenceUpdated() { // Given var mocks = new MockRepository(); var viewCommands = mocks.Stub(); mocks.ReplayAll(); var handler = new AssessmentSectionMergeHandler(viewCommands); var targetLocations = new[] { new HydraulicBoundaryLocation(1, "location 1", 1, 1), new HydraulicBoundaryLocation(2, "location 2", 2, 2) }; var sourceLocations = new[] { new HydraulicBoundaryLocation(1, "location 1", 1, 1), new HydraulicBoundaryLocation(2, "location 2", 2, 2) }; AssessmentSection targetAssessmentSection = CreateAssessmentSection(targetLocations); AssessmentSection sourceAssessmentSection = CreateAssessmentSection(sourceLocations); sourceAssessmentSection.Piping.CalculationsGroup.Children.Add(new PipingCalculationScenario(new GeneralPipingInput()) { InputParameters = { HydraulicBoundaryLocation = sourceLocations[0] } }); sourceAssessmentSection.GrassCoverErosionInwards.CalculationsGroup.Children.Add(new GrassCoverErosionInwardsCalculation { InputParameters = { HydraulicBoundaryLocation = sourceLocations[1] } }); sourceAssessmentSection.MacroStabilityInwards.CalculationsGroup.Children.Add(new MacroStabilityInwardsCalculationScenario { InputParameters = { HydraulicBoundaryLocation = sourceLocations[0] } }); sourceAssessmentSection.HeightStructures.CalculationsGroup.Children.Add(new StructuresCalculation { InputParameters = { HydraulicBoundaryLocation = sourceLocations[1] } }); sourceAssessmentSection.ClosingStructures.CalculationsGroup.Children.Add(new StructuresCalculation { InputParameters = { HydraulicBoundaryLocation = sourceLocations[0] } }); sourceAssessmentSection.StabilityPointStructures.CalculationsGroup.Children.Add(new StructuresCalculation { InputParameters = { HydraulicBoundaryLocation = sourceLocations[1] } }); sourceAssessmentSection.StabilityStoneCover.WaveConditionsCalculationGroup.Children.Add(new StabilityStoneCoverWaveConditionsCalculation { InputParameters = { HydraulicBoundaryLocation = sourceLocations[0] } }); sourceAssessmentSection.WaveImpactAsphaltCover.WaveConditionsCalculationGroup.Children.Add(new WaveImpactAsphaltCoverWaveConditionsCalculation { InputParameters = { HydraulicBoundaryLocation = sourceLocations[1] } }); GrassCoverErosionOutwardsHydraulicBoundaryLocationsTestHelper.SetHydraulicBoundaryLocations(sourceAssessmentSection.GrassCoverErosionOutwards, sourceLocations, true); sourceAssessmentSection.GrassCoverErosionOutwards.WaveConditionsCalculationGroup.Children.Add(new GrassCoverErosionOutwardsWaveConditionsCalculation { InputParameters = { HydraulicBoundaryLocation = sourceLocations[0] } }); HydraulicBoundaryLocationCalculation[] sourceWaterLevelForMechanismSpecificFactorizedSignalingNorm = sourceAssessmentSection.GrassCoverErosionOutwards.WaterLevelCalculationsForMechanismSpecificFactorizedSignalingNorm.ToArray(); HydraulicBoundaryLocationCalculation[] sourceWaterLevelForMechanismSpecificSignalingNorm = sourceAssessmentSection.GrassCoverErosionOutwards.WaterLevelCalculationsForMechanismSpecificSignalingNorm.ToArray(); HydraulicBoundaryLocationCalculation[] sourceWaterLevelForMechanismSpecificLowerLimitNorm = sourceAssessmentSection.GrassCoverErosionOutwards.WaterLevelCalculationsForMechanismSpecificLowerLimitNorm.ToArray(); HydraulicBoundaryLocationCalculation[] sourceWaveHeightForMechanismSpecificFactorizedSignalingNorm = sourceAssessmentSection.GrassCoverErosionOutwards.WaveHeightCalculationsForMechanismSpecificFactorizedSignalingNorm.ToArray(); HydraulicBoundaryLocationCalculation[] sourceWaveHeightForMechanismSpecificSignalingNorm = sourceAssessmentSection.GrassCoverErosionOutwards.WaveHeightCalculationsForMechanismSpecificSignalingNorm.ToArray(); HydraulicBoundaryLocationCalculation[] sourceWaveHeightForMechanismSpecificLowerLimitNorm = sourceAssessmentSection.GrassCoverErosionOutwards.WaveHeightCalculationsForMechanismSpecificLowerLimitNorm.ToArray(); // When handler.PerformMerge(targetAssessmentSection, new AssessmentSectionMergeData( sourceAssessmentSection, new AssessmentSectionMergeData.ConstructionProperties { MergePiping = true, MergeGrassCoverErosionInwards = true, MergeMacroStabilityInwards = true, MergeStabilityStoneCover = true, MergeWaveImpactAsphaltCover = true, MergeGrassCoverErosionOutwards = true, MergeHeightStructures = true, MergeClosingStructures = true, MergeStabilityPointStructures = true })); // Then var pipingCalculation = (PipingCalculationScenario) targetAssessmentSection.Piping.Calculations.Single(); Assert.AreSame(targetLocations[0], pipingCalculation.InputParameters.HydraulicBoundaryLocation); var grassInwardsCalculation = (GrassCoverErosionInwardsCalculation) targetAssessmentSection.GrassCoverErosionInwards.Calculations.Single(); Assert.AreSame(targetLocations[1], grassInwardsCalculation.InputParameters.HydraulicBoundaryLocation); var macroStabilityInwardsCalculation = (MacroStabilityInwardsCalculation) targetAssessmentSection.MacroStabilityInwards.Calculations.Single(); Assert.AreSame(targetLocations[0], macroStabilityInwardsCalculation.InputParameters.HydraulicBoundaryLocation); var heightStructuresCalculation = (StructuresCalculation) targetAssessmentSection.HeightStructures.Calculations.Single(); Assert.AreSame(targetLocations[1], heightStructuresCalculation.InputParameters.HydraulicBoundaryLocation); var closingStructuresCalculation = (StructuresCalculation) targetAssessmentSection.ClosingStructures.Calculations.Single(); Assert.AreSame(targetLocations[0], closingStructuresCalculation.InputParameters.HydraulicBoundaryLocation); var stabilityPointStructuresCalculation = (StructuresCalculation) targetAssessmentSection.StabilityPointStructures.Calculations.Single(); Assert.AreSame(targetLocations[1], stabilityPointStructuresCalculation.InputParameters.HydraulicBoundaryLocation); var stabilityStoneCoverCalculation = (StabilityStoneCoverWaveConditionsCalculation) targetAssessmentSection.StabilityStoneCover.Calculations.Single(); Assert.AreSame(targetLocations[0], stabilityStoneCoverCalculation.InputParameters.HydraulicBoundaryLocation); var waveImpactAsphaltCoverCalculation = (WaveImpactAsphaltCoverWaveConditionsCalculation) targetAssessmentSection.WaveImpactAsphaltCover.Calculations.Single(); Assert.AreSame(targetLocations[1], waveImpactAsphaltCoverCalculation.InputParameters.HydraulicBoundaryLocation); var grassOutwardsCalculation = (GrassCoverErosionOutwardsWaveConditionsCalculation) targetAssessmentSection.GrassCoverErosionOutwards.Calculations.Single(); Assert.AreSame(targetLocations[0], grassOutwardsCalculation.InputParameters.HydraulicBoundaryLocation); AssertHydraulicBoundaryCalculations(sourceWaterLevelForMechanismSpecificFactorizedSignalingNorm, targetAssessmentSection.GrassCoverErosionOutwards.WaterLevelCalculationsForMechanismSpecificFactorizedSignalingNorm, targetLocations); AssertHydraulicBoundaryCalculations(sourceWaterLevelForMechanismSpecificSignalingNorm, targetAssessmentSection.GrassCoverErosionOutwards.WaterLevelCalculationsForMechanismSpecificSignalingNorm, targetLocations); AssertHydraulicBoundaryCalculations(sourceWaterLevelForMechanismSpecificLowerLimitNorm, targetAssessmentSection.GrassCoverErosionOutwards.WaterLevelCalculationsForMechanismSpecificLowerLimitNorm, targetLocations); AssertHydraulicBoundaryCalculations(sourceWaveHeightForMechanismSpecificFactorizedSignalingNorm, targetAssessmentSection.GrassCoverErosionOutwards.WaveHeightCalculationsForMechanismSpecificFactorizedSignalingNorm, targetLocations); AssertHydraulicBoundaryCalculations(sourceWaveHeightForMechanismSpecificSignalingNorm, targetAssessmentSection.GrassCoverErosionOutwards.WaveHeightCalculationsForMechanismSpecificSignalingNorm, targetLocations); AssertHydraulicBoundaryCalculations(sourceWaveHeightForMechanismSpecificLowerLimitNorm, targetAssessmentSection.GrassCoverErosionOutwards.WaveHeightCalculationsForMechanismSpecificLowerLimitNorm, targetLocations); } private static void AssertHydraulicBoundaryCalculations(IEnumerable sourceCalculations, IEnumerable targetCalculations, IEnumerable targetLocations) { Assert.AreEqual(sourceCalculations.Count(), targetLocations.Count()); Assert.AreEqual(targetCalculations.Count(), sourceCalculations.Count()); for (var i = 0; i < sourceCalculations.Count(); i++) { HydraulicBoundaryLocationCalculation sourceCalculation = sourceCalculations.ElementAt(i); HydraulicBoundaryLocationCalculation targetCalculation = targetCalculations.ElementAt(i); Assert.AreEqual(sourceCalculation.InputParameters.ShouldIllustrationPointsBeCalculated, targetCalculation.InputParameters.ShouldIllustrationPointsBeCalculated); Assert.AreSame(sourceCalculation.Output, targetCalculation.Output); Assert.AreSame(targetLocations.ElementAt(i), targetCalculation.HydraulicBoundaryLocation); } } private static AssessmentSection CreateAssessmentSection(HydraulicBoundaryLocation[] locations) { var assessmentSection = new AssessmentSection(AssessmentSectionComposition.Dike); assessmentSection.HydraulicBoundaryDatabase.Locations.AddRange(locations); assessmentSection.SetHydraulicBoundaryLocationCalculations(locations); return assessmentSection; } #region HydraulicBoundaryLocationCalculations [Test] [TestCaseSource(nameof(GetHydraulicBoundaryLocationCalculationFuncs))] public void GivenAssessmentSectionWithHydraulicBoundaryLocationCalculations_WhenTargetAssessmentSectionHasOutput_ThenCalculationsNotChanged( Func> getCalculationsFunc) { // Given var mocks = new MockRepository(); var viewCommands = mocks.Stub(); mocks.ReplayAll(); HydraulicBoundaryLocation[] locations = { new TestHydraulicBoundaryLocation(), new TestHydraulicBoundaryLocation() }; AssessmentSection targetAssessmentSection = CreateAssessmentSection(locations); AssessmentSection sourceAssessmentSection = CreateAssessmentSection(locations); IEnumerable targetCalculations = getCalculationsFunc(targetAssessmentSection); IEnumerable sourceCalculations = getCalculationsFunc(sourceAssessmentSection); SetOutput(targetCalculations); sourceCalculations.ForEachElementDo(c => c.InputParameters.ShouldIllustrationPointsBeCalculated = true); var handler = new AssessmentSectionMergeHandler(viewCommands); // Precondition Assert.IsTrue(targetCalculations.All(c => c.HasOutput)); Assert.IsTrue(sourceCalculations.All(c => !c.HasOutput)); Assert.IsTrue(targetCalculations.All(c => !c.InputParameters.ShouldIllustrationPointsBeCalculated)); // When handler.PerformMerge(targetAssessmentSection, new AssessmentSectionMergeData( sourceAssessmentSection, new AssessmentSectionMergeData.ConstructionProperties())); // Then Assert.IsTrue(targetCalculations.All(c => c.HasOutput)); Assert.IsTrue(sourceCalculations.All(c => !c.HasOutput)); Assert.IsTrue(targetCalculations.All(c => !c.InputParameters.ShouldIllustrationPointsBeCalculated)); mocks.VerifyAll(); } [Test] [TestCaseSource(nameof(GetHydraulicBoundaryLocationCalculationFuncs))] public void GivenAssessmentSectionWithHydraulicBoundaryLocationCalculations_WhenBothAssessmentSectionsHaveOutput_ThenCalculationsNotChanged( Func> getCalculationsFunc) { // Given var mocks = new MockRepository(); var viewCommands = mocks.Stub(); mocks.ReplayAll(); HydraulicBoundaryLocation[] locations = { new TestHydraulicBoundaryLocation(), new TestHydraulicBoundaryLocation() }; AssessmentSection targetAssessmentSection = CreateAssessmentSection(locations); AssessmentSection sourceAssessmentSection = CreateAssessmentSection(locations); IEnumerable targetCalculations = getCalculationsFunc(targetAssessmentSection); IEnumerable sourceCalculations = getCalculationsFunc(sourceAssessmentSection); SetOutput(targetCalculations); SetOutput(sourceCalculations); sourceCalculations.ForEachElementDo(c => c.InputParameters.ShouldIllustrationPointsBeCalculated = true); var handler = new AssessmentSectionMergeHandler(viewCommands); // Precondition Assert.IsTrue(targetCalculations.All(c => c.HasOutput)); Assert.IsTrue(sourceCalculations.All(c => c.HasOutput)); Assert.IsTrue(targetCalculations.All(c => !c.Output.HasGeneralResult)); Assert.IsTrue(sourceCalculations.All(c => !c.Output.HasGeneralResult)); Assert.IsTrue(targetCalculations.All(c => !c.InputParameters.ShouldIllustrationPointsBeCalculated)); // When handler.PerformMerge(targetAssessmentSection, new AssessmentSectionMergeData( sourceAssessmentSection, new AssessmentSectionMergeData.ConstructionProperties())); // Then Assert.IsTrue(targetCalculations.All(c => c.HasOutput)); Assert.IsTrue(sourceCalculations.All(c => c.HasOutput)); Assert.IsTrue(targetCalculations.All(c => !c.Output.HasGeneralResult)); Assert.IsTrue(sourceCalculations.All(c => !c.Output.HasGeneralResult)); Assert.IsTrue(targetCalculations.All(c => !c.InputParameters.ShouldIllustrationPointsBeCalculated)); mocks.VerifyAll(); } [Test] [TestCaseSource(nameof(GetHydraulicBoundaryLocationCalculationFuncs))] public void GivenAssessmentSectionWithHydraulicBoundaryLocationCalculations_WhenSourceAssessmentSectionHasOutput_ThenCalculationDataMerged( Func> getCalculationsFunc) { // Given var mocks = new MockRepository(); var viewCommands = mocks.Stub(); mocks.ReplayAll(); HydraulicBoundaryLocation[] locations = { new TestHydraulicBoundaryLocation(), new TestHydraulicBoundaryLocation() }; AssessmentSection targetAssessmentSection = CreateAssessmentSection(locations); AssessmentSection sourceAssessmentSection = CreateAssessmentSection(locations); IEnumerable targetCalculations = getCalculationsFunc(targetAssessmentSection); IEnumerable sourceCalculations = getCalculationsFunc(sourceAssessmentSection); SetOutput(sourceCalculations); sourceCalculations.ForEachElementDo(c => c.InputParameters.ShouldIllustrationPointsBeCalculated = true); var handler = new AssessmentSectionMergeHandler(viewCommands); // Precondition Assert.IsTrue(targetCalculations.All(c => !c.HasOutput)); Assert.IsTrue(sourceCalculations.All(c => c.HasOutput)); Assert.IsTrue(targetCalculations.All(c => !c.InputParameters.ShouldIllustrationPointsBeCalculated)); Assert.IsTrue(sourceCalculations.All(c => c.InputParameters.ShouldIllustrationPointsBeCalculated)); // When handler.PerformMerge(targetAssessmentSection, new AssessmentSectionMergeData( sourceAssessmentSection, new AssessmentSectionMergeData.ConstructionProperties())); // Then Assert.IsTrue(targetCalculations.All(c => c.HasOutput)); Assert.IsTrue(targetCalculations.All(c => c.InputParameters.ShouldIllustrationPointsBeCalculated)); mocks.VerifyAll(); } [Test] [TestCaseSource(nameof(GetHydraulicBoundaryLocationCalculationFuncs))] public void GivenAssessmentSectionWithHydraulicBoundaryLocationCalculations_WhenTargetAssessmentSectionHasOutputWithIllustrationPoints_ThenCalculationsNotChanged( Func> getCalculationsFunc) { // Given var mocks = new MockRepository(); var viewCommands = mocks.Stub(); mocks.ReplayAll(); HydraulicBoundaryLocation[] locations = { new TestHydraulicBoundaryLocation(), new TestHydraulicBoundaryLocation() }; AssessmentSection targetAssessmentSection = CreateAssessmentSection(locations); AssessmentSection sourceAssessmentSection = CreateAssessmentSection(locations); IEnumerable targetCalculations = getCalculationsFunc(targetAssessmentSection); IEnumerable sourceCalculations = getCalculationsFunc(sourceAssessmentSection); SetOutput(targetCalculations, true); SetOutput(sourceCalculations); var handler = new AssessmentSectionMergeHandler(viewCommands); // Precondition Assert.IsTrue(targetCalculations.All(c => c.HasOutput)); Assert.IsTrue(targetCalculations.All(c => c.Output.HasGeneralResult)); Assert.IsTrue(sourceCalculations.All(c => c.HasOutput)); Assert.IsTrue(sourceCalculations.All(c => !c.Output.HasGeneralResult)); // When handler.PerformMerge(targetAssessmentSection, new AssessmentSectionMergeData( sourceAssessmentSection, new AssessmentSectionMergeData.ConstructionProperties())); // Then Assert.IsTrue(targetCalculations.All(c => c.HasOutput)); Assert.IsTrue(targetCalculations.All(c => c.Output.HasGeneralResult)); Assert.IsTrue(sourceCalculations.All(c => c.HasOutput)); Assert.IsTrue(sourceCalculations.All(c => !c.Output.HasGeneralResult)); mocks.VerifyAll(); } [Test] [TestCaseSource(nameof(GetHydraulicBoundaryLocationCalculationFuncs))] public void GivenAssessmentSectionWithHydraulicBoundaryLocationCalculations_WhenSourceAssessmentSectionHasOutputWithIllustrationPoints_ThenCalculationsMerged( Func> getCalculationsFunc) { // Given var mocks = new MockRepository(); var viewCommands = mocks.Stub(); mocks.ReplayAll(); HydraulicBoundaryLocation[] locations = { new TestHydraulicBoundaryLocation(), new TestHydraulicBoundaryLocation() }; AssessmentSection targetAssessmentSection = CreateAssessmentSection(locations); AssessmentSection sourceAssessmentSection = CreateAssessmentSection(locations); IEnumerable targetCalculations = getCalculationsFunc(targetAssessmentSection); IEnumerable sourceCalculations = getCalculationsFunc(sourceAssessmentSection); SetOutput(targetCalculations); SetOutput(sourceCalculations, true); var handler = new AssessmentSectionMergeHandler(viewCommands); // Precondition Assert.IsTrue(targetCalculations.All(c => c.HasOutput)); Assert.IsTrue(targetCalculations.All(c => !c.Output.HasGeneralResult)); Assert.IsTrue(sourceCalculations.All(c => c.HasOutput)); Assert.IsTrue(sourceCalculations.All(c => c.Output.HasGeneralResult)); // When handler.PerformMerge(targetAssessmentSection, new AssessmentSectionMergeData( sourceAssessmentSection, new AssessmentSectionMergeData.ConstructionProperties())); // Then Assert.IsTrue(targetCalculations.All(c => c.HasOutput)); Assert.IsTrue(targetCalculations.All(c => c.Output.HasGeneralResult)); mocks.VerifyAll(); } [Test] [TestCaseSource(nameof(GetHydraulicBoundaryLocationCalculationFuncs))] public void GivenAssessmentSectionWithHydraulicBoundaryLocationCalculations_WhenBothAssessmentSectionsHaveOutputAndIllustrationPoints_ThenCalculationsNotChanged( Func> getCalculationsFunc) { // Given var mocks = new MockRepository(); var viewCommands = mocks.Stub(); mocks.ReplayAll(); HydraulicBoundaryLocation[] locations = { new TestHydraulicBoundaryLocation(), new TestHydraulicBoundaryLocation() }; AssessmentSection targetAssessmentSection = CreateAssessmentSection(locations); AssessmentSection sourceAssessmentSection = CreateAssessmentSection(locations); IEnumerable targetCalculations = getCalculationsFunc(targetAssessmentSection); IEnumerable sourceCalculations = getCalculationsFunc(sourceAssessmentSection); SetOutput(targetCalculations, true); SetOutput(sourceCalculations, true); sourceCalculations.ForEachElementDo(c => c.InputParameters.ShouldIllustrationPointsBeCalculated = true); var handler = new AssessmentSectionMergeHandler(viewCommands); // Precondition Assert.IsTrue(targetCalculations.All(c => c.HasOutput)); Assert.IsTrue(sourceCalculations.All(c => c.HasOutput)); Assert.IsTrue(targetCalculations.All(c => c.Output.HasGeneralResult)); Assert.IsTrue(sourceCalculations.All(c => c.Output.HasGeneralResult)); Assert.IsTrue(targetCalculations.All(c => !c.InputParameters.ShouldIllustrationPointsBeCalculated)); // When handler.PerformMerge(targetAssessmentSection, new AssessmentSectionMergeData( sourceAssessmentSection, new AssessmentSectionMergeData.ConstructionProperties())); // Then Assert.IsTrue(targetCalculations.All(c => c.HasOutput)); Assert.IsTrue(sourceCalculations.All(c => c.HasOutput)); Assert.IsTrue(targetCalculations.All(c => c.Output.HasGeneralResult)); Assert.IsTrue(sourceCalculations.All(c => c.Output.HasGeneralResult)); Assert.IsTrue(targetCalculations.All(c => !c.InputParameters.ShouldIllustrationPointsBeCalculated)); mocks.VerifyAll(); } [Test] [TestCaseSource(nameof(GetHydraulicBoundaryLocationCalculationFuncs))] public void PerformMerge_HydraulicBoundaryLocationCalculationsMerged_ObserversNotifiedAndMessageLogged( Func> getCalculationsFunc) { // Setup var mocks = new MockRepository(); var viewCommands = mocks.Stub(); var observer = mocks.StrictMock(); observer.Expect(o => o.UpdateObserver()).Repeat.Twice(); mocks.ReplayAll(); HydraulicBoundaryLocation[] locations = { new TestHydraulicBoundaryLocation(), new TestHydraulicBoundaryLocation() }; AssessmentSection targetAssessmentSection = CreateAssessmentSection(locations); AssessmentSection sourceAssessmentSection = CreateAssessmentSection(locations); IEnumerable targetCalculations = getCalculationsFunc(targetAssessmentSection); IEnumerable sourceCalculations = getCalculationsFunc(sourceAssessmentSection); targetCalculations.ForEachElementDo(calculation => calculation.Attach(observer)); SetOutput(targetCalculations); SetOutput(sourceCalculations, true); var handler = new AssessmentSectionMergeHandler(viewCommands); // Call Action call = () => handler.PerformMerge(targetAssessmentSection, new AssessmentSectionMergeData( sourceAssessmentSection, new AssessmentSectionMergeData.ConstructionProperties())); // Assert TestHelper.AssertLogMessageWithLevelIsGenerated(call, new Tuple("Hydraulische belastingen zijn samengevoegd.", LogLevelConstant.Info)); mocks.VerifyAll(); } [Test] [TestCaseSource(nameof(GetHydraulicBoundaryLocationCalculationFuncs))] public void PerformMerge_HydraulicBoundaryLocationCalculationsNotMerged_ObserversNotNotifiedAndNoMessageLogged( Func> getCalculationsFunc) { // Setup var mocks = new MockRepository(); var viewCommands = mocks.Stub(); var observer = mocks.StrictMock(); mocks.ReplayAll(); HydraulicBoundaryLocation[] locations = { new TestHydraulicBoundaryLocation(), new TestHydraulicBoundaryLocation() }; AssessmentSection targetAssessmentSection = CreateAssessmentSection(locations); AssessmentSection sourceAssessmentSection = CreateAssessmentSection(locations); IEnumerable targetCalculations = getCalculationsFunc(targetAssessmentSection); IEnumerable sourceCalculations = getCalculationsFunc(sourceAssessmentSection); targetCalculations.ForEachElementDo(calculation => calculation.Attach(observer)); SetOutput(targetCalculations); SetOutput(sourceCalculations); var handler = new AssessmentSectionMergeHandler(viewCommands); // Call Action call = () => handler.PerformMerge(targetAssessmentSection, new AssessmentSectionMergeData( sourceAssessmentSection, new AssessmentSectionMergeData.ConstructionProperties())); // Assert TestHelper.AssertLogMessagesCount(call, 0); mocks.VerifyAll(); } private static void SetOutput(IEnumerable calculations, bool illustrationPoints = false) { foreach (HydraulicBoundaryLocationCalculation calculation in calculations) { calculation.Output = illustrationPoints ? new TestHydraulicBoundaryLocationCalculationOutput(new TestGeneralResultSubMechanismIllustrationPoint()) : new TestHydraulicBoundaryLocationCalculationOutput(); } } private static IEnumerable GetHydraulicBoundaryLocationCalculationFuncs() { yield return new TestCaseData(new Func>( section => section.WaterLevelCalculationsForFactorizedSignalingNorm)); yield return new TestCaseData(new Func>( section => section.WaterLevelCalculationsForSignalingNorm)); yield return new TestCaseData(new Func>( section => section.WaterLevelCalculationsForLowerLimitNorm)); yield return new TestCaseData(new Func>( section => section.WaterLevelCalculationsForFactorizedLowerLimitNorm)); yield return new TestCaseData(new Func>( section => section.WaveHeightCalculationsForFactorizedSignalingNorm)); yield return new TestCaseData(new Func>( section => section.WaveHeightCalculationsForSignalingNorm)); yield return new TestCaseData(new Func>( section => section.WaveHeightCalculationsForLowerLimitNorm)); yield return new TestCaseData(new Func>( section => section.WaveHeightCalculationsForFactorizedLowerLimitNorm)); } #endregion } }