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 @@
-
+