Fisheye: Tag 077025419175c14370ea4376cf95e0470098d26d refers to a dead (removed) revision in file `Ringtoets/Integration/src/Ringtoets.Integration.Data/Assembly/CombinedAssemblyFailureMechanismInputFactory.cs'. Fisheye: No comparison available. Pass `N' to diff? Index: Ringtoets/Integration/src/Ringtoets.Integration.Data/Assembly/CombinedAssemblyFailureMechanismSectionFactory.cs =================================================================== diff -u --- Ringtoets/Integration/src/Ringtoets.Integration.Data/Assembly/CombinedAssemblyFailureMechanismSectionFactory.cs (revision 0) +++ Ringtoets/Integration/src/Ringtoets.Integration.Data/Assembly/CombinedAssemblyFailureMechanismSectionFactory.cs (revision 077025419175c14370ea4376cf95e0470098d26d) @@ -0,0 +1,160 @@ +// 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 Ringtoets.AssemblyTool.Data; +using Ringtoets.Common.Data.FailureMechanism; +using Ringtoets.GrassCoverErosionInwards.Data; +using Ringtoets.Integration.Data.StandAlone; +using Ringtoets.Integration.Data.StandAlone.AssemblyFactories; +using Ringtoets.Integration.Data.StandAlone.SectionResults; +using Ringtoets.MacroStabilityInwards.Data; +using Ringtoets.Piping.Data; + +namespace Ringtoets.Integration.Data.Assembly +{ + /// + /// Factory that creates instances. + /// + internal static class CombinedAssemblyFailureMechanismSectionFactory + { + /// + /// Creates a collection of collections. + /// + /// The assessment section to use. + /// The failure mechanisms to build input for. + /// A collection of collections. + /// Thrown when any parameter is null. + public static IEnumerable> CreateInput(AssessmentSection assessmentSection, + IEnumerable failureMechanisms) + { + if (assessmentSection == null) + { + throw new ArgumentNullException(nameof(assessmentSection)); + } + + if (failureMechanisms == null) + { + throw new ArgumentNullException(nameof(failureMechanisms)); + } + + var inputs = new List>(); + + PipingFailureMechanism pipingFailureMechanism = assessmentSection.Piping; + if (failureMechanisms.Contains(pipingFailureMechanism)) + { + inputs.Add(CreateCombinedSections(pipingFailureMechanism.SectionResults, + assessmentSection, PipingAssemblyFunc) + .ToArray()); + } + + GrassCoverErosionInwardsFailureMechanism grassInwardsFailureMechanism = assessmentSection.GrassCoverErosionInwards; + if (failureMechanisms.Contains(grassInwardsFailureMechanism)) + { + inputs.Add(CreateCombinedSections(grassInwardsFailureMechanism.SectionResults, + assessmentSection, GrassCoverErosionInwardsAssemblyFunc) + .ToArray()); + } + + MacroStabilityInwardsFailureMechanism macroStabilityInwardsFailureMechanism = assessmentSection.MacroStabilityInwards; + if (failureMechanisms.Contains(macroStabilityInwardsFailureMechanism)) + { + inputs.Add(CreateCombinedSections(macroStabilityInwardsFailureMechanism.SectionResults, + assessmentSection, MacroStabilityInwardsAssemblyFunc) + .ToArray()); + } + + MacroStabilityOutwardsFailureMechanism macroStabilityOutwardsFailureMechanism = assessmentSection.MacroStabilityOutwards; + if (failureMechanisms.Contains(macroStabilityOutwardsFailureMechanism)) + { + inputs.Add(CreateCombinedSections(macroStabilityOutwardsFailureMechanism.SectionResults, + assessmentSection, MacroStabilityOutwardsAssemblyFunc) + .ToArray()); + } + + return inputs; + } + + private static IEnumerable CreateCombinedSections( + IEnumerable sectionResults, + AssessmentSection assessmentSection, + Func getAssemblyFunc) + where TFailureMechanismSectionResult : FailureMechanismSectionResult + { + double totalSectionsLength = 0; + + var combinedSections = new List(); + foreach (TFailureMechanismSectionResult sectionResult in sectionResults) + { + double endPoint = sectionResult.Section.Length + totalSectionsLength; + combinedSections.Add(new CombinedAssemblyFailureMechanismSection(totalSectionsLength, + endPoint, + getAssemblyFunc(sectionResult, assessmentSection))); + + totalSectionsLength = endPoint; + } + + return combinedSections.ToArray(); + } + + #region Assembly Funcs + + private static Func PipingAssemblyFunc + { + get + { + return (sectionResult, assessmentSection) => PipingFailureMechanismAssemblyFactory.GetSectionAssemblyCategoryGroup( + sectionResult, assessmentSection.Piping, assessmentSection); + } + } + + private static Func GrassCoverErosionInwardsAssemblyFunc + { + get + { + return (sectionResult, assessmentSection) => GrassCoverErosionInwardsFailureMechanismAssemblyFactory.GetSectionAssemblyCategoryGroup( + sectionResult, assessmentSection.GrassCoverErosionInwards, assessmentSection); + } + } + + private static Func MacroStabilityInwardsAssemblyFunc + { + get + { + return (sectionResult, assessmentSection) => MacroStabilityInwardsFailureMechanismAssemblyFactory.GetSectionAssemblyCategoryGroup( + sectionResult, assessmentSection.MacroStabilityInwards, assessmentSection); + } + } + + private static Func MacroStabilityOutwardsAssemblyFunc + { + get + { + return (sectionResult, assessmentSection) => MacroStabilityOutwardsFailureMechanismAssemblyFactory.GetSectionAssemblyCategoryGroup( + sectionResult, assessmentSection.MacroStabilityOutwards, assessmentSection); + } + } + + #endregion + } +} \ No newline at end of file Index: Ringtoets/Integration/src/Ringtoets.Integration.Data/Ringtoets.Integration.Data.csproj =================================================================== diff -u -r260eeac10d6b7fc5fe49c11a8659283a00d5e603 -r077025419175c14370ea4376cf95e0470098d26d --- Ringtoets/Integration/src/Ringtoets.Integration.Data/Ringtoets.Integration.Data.csproj (.../Ringtoets.Integration.Data.csproj) (revision 260eeac10d6b7fc5fe49c11a8659283a00d5e603) +++ Ringtoets/Integration/src/Ringtoets.Integration.Data/Ringtoets.Integration.Data.csproj (.../Ringtoets.Integration.Data.csproj) (revision 077025419175c14370ea4376cf95e0470098d26d) @@ -11,7 +11,7 @@ - + Fisheye: Tag 077025419175c14370ea4376cf95e0470098d26d refers to a dead (removed) revision in file `Ringtoets/Integration/test/Ringtoets.Integration.Data.Test/Assembly/CombinedAssemblyFailureMechanismInputFactoryTest.cs'. Fisheye: No comparison available. Pass `N' to diff? Index: Ringtoets/Integration/test/Ringtoets.Integration.Data.Test/Assembly/CombinedAssemblyFailureMechanismSectionFactoryTest.cs =================================================================== diff -u --- Ringtoets/Integration/test/Ringtoets.Integration.Data.Test/Assembly/CombinedAssemblyFailureMechanismSectionFactoryTest.cs (revision 0) +++ Ringtoets/Integration/test/Ringtoets.Integration.Data.Test/Assembly/CombinedAssemblyFailureMechanismSectionFactoryTest.cs (revision 077025419175c14370ea4376cf95e0470098d26d) @@ -0,0 +1,107 @@ +// 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.TestUtil; +using NUnit.Framework; +using Ringtoets.AssemblyTool.Data; +using Ringtoets.AssemblyTool.KernelWrapper.TestUtil.Calculators; +using Ringtoets.Common.Data.AssessmentSection; +using Ringtoets.Common.Data.FailureMechanism; +using Ringtoets.Integration.Data.Assembly; +using Ringtoets.Integration.TestUtil; + +namespace Ringtoets.Integration.Data.Test.Assembly +{ + [TestFixture] + public class CombinedAssemblyFailureMechanismSectionFactoryTest + { + [Test] + public void CreateInput_AssessmentSectionNull_ThrowsArgumentNullException() + { + // Call + TestDelegate call = () => CombinedAssemblyFailureMechanismSectionFactory.CreateInput(null, Enumerable.Empty()); + + // Assert + var exception = Assert.Throws(call); + Assert.AreEqual("assessmentSection", exception.ParamName); + } + + [Test] + public void CreateInput_failureMechanismsNull_ThrowsArgumentNullException() + { + // Setup + var assessmentSection = new AssessmentSection(new Random(21).NextEnumValue()); + + // Call + TestDelegate call = () => CombinedAssemblyFailureMechanismSectionFactory.CreateInput(assessmentSection, null); + + // Assert + var exception = Assert.Throws(call); + Assert.AreEqual("failureMechanisms", exception.ParamName); + } + + [Test] + public void CreateInput_WithAllFailureMechanismsRelevant_ReturnsInputCollection() + { + // Setup + AssessmentSection assessmentSection = TestDataGenerator.GetAssessmensectionWithAllFailureMechanismSectionsAndResults( + new Random(21).NextEnumValue()); + + IFailureMechanism[] failureMechanisms = assessmentSection.GetFailureMechanisms().ToArray(); + + using (new AssemblyToolCalculatorFactoryConfig()) + { + // Call + IEnumerable[] inputs = CombinedAssemblyFailureMechanismSectionFactory.CreateInput( + assessmentSection, failureMechanisms).ToArray(); + + // Assert + Assert.AreEqual(4, inputs.Length); + AssertSections(assessmentSection.Piping.SectionResults.ToArray(), inputs[0].ToArray()); + AssertSections(assessmentSection.GrassCoverErosionInwards.SectionResults.ToArray(), inputs[1].ToArray()); + AssertSections(assessmentSection.MacroStabilityInwards.SectionResults.ToArray(), inputs[2].ToArray()); + AssertSections(assessmentSection.MacroStabilityOutwards.SectionResults.ToArray(), inputs[3].ToArray()); + } + } + + private static void AssertSections(T[] originalSectionResults, CombinedAssemblyFailureMechanismSection[] inputSections) + where T : FailureMechanismSectionResult + { + Assert.AreEqual(originalSectionResults.Length, inputSections.Length); + + double expectedSectionStart = 0; + + for (var i = 0; i < originalSectionResults.Length; i++) + { + double expectedSectionEnd = expectedSectionStart + originalSectionResults[i].Section.Length; + + Assert.AreEqual(expectedSectionStart, inputSections[i].SectionStart); + Assert.AreEqual(expectedSectionEnd, inputSections[i].SectionEnd); + Assert.AreEqual(FailureMechanismSectionAssemblyCategoryGroup.VIv, inputSections[i].CategoryGroup); + + expectedSectionStart = expectedSectionEnd; + } + } + } +} \ No newline at end of file Index: Ringtoets/Integration/test/Ringtoets.Integration.Data.Test/Ringtoets.Integration.Data.Test.csproj =================================================================== diff -u -r1046921a24c7d047235317c67656befadef30cf9 -r077025419175c14370ea4376cf95e0470098d26d --- Ringtoets/Integration/test/Ringtoets.Integration.Data.Test/Ringtoets.Integration.Data.Test.csproj (.../Ringtoets.Integration.Data.Test.csproj) (revision 1046921a24c7d047235317c67656befadef30cf9) +++ Ringtoets/Integration/test/Ringtoets.Integration.Data.Test/Ringtoets.Integration.Data.Test.csproj (.../Ringtoets.Integration.Data.Test.csproj) (revision 077025419175c14370ea4376cf95e0470098d26d) @@ -19,7 +19,7 @@ - +