Index: Ringtoets/Integration/src/Ringtoets.Integration.IO/AggregatedSerializableCombinedFailureMechanismSectionAssemblies.cs =================================================================== diff -u --- Ringtoets/Integration/src/Ringtoets.Integration.IO/AggregatedSerializableCombinedFailureMechanismSectionAssemblies.cs (revision 0) +++ Ringtoets/Integration/src/Ringtoets.Integration.IO/AggregatedSerializableCombinedFailureMechanismSectionAssemblies.cs (revision 316e5aab030403874f0517958110eb3eea831527) @@ -0,0 +1,82 @@ +// 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 Ringtoets.AssemblyTool.IO.Model; + +namespace Ringtoets.Integration.IO +{ + /// + /// Class that holds all the information that is related when generating a collection of + /// . + /// + public class AggregatedSerializableCombinedFailureMechanismSectionAssemblies + { + /// + /// An instance of . + /// + /// The + /// that the belong to. + /// A collection of + /// that is associated with . + /// A collection of . + /// Thrown when any parameter is null. + public AggregatedSerializableCombinedFailureMechanismSectionAssemblies(SerializableFailureMechanismSectionCollection failureMechanismSectionCollection, + IEnumerable failureMechanismSections, + IEnumerable combinedFailureMechanismSectionAssemblies) + { + if (failureMechanismSectionCollection == null) + { + throw new ArgumentNullException(nameof(failureMechanismSectionCollection)); + } + + if (failureMechanismSections == null) + { + throw new ArgumentNullException(nameof(failureMechanismSections)); + } + + if (combinedFailureMechanismSectionAssemblies == null) + { + throw new ArgumentNullException(nameof(combinedFailureMechanismSectionAssemblies)); + } + + FailureMechanismSectionCollection = failureMechanismSectionCollection; + FailureMechanismSections = failureMechanismSections; + CombinedFailureMechanismSectionAssemblies = combinedFailureMechanismSectionAssemblies; + } + + /// + /// Gets the collection where the serializable failure mechanism sections belong to. + /// + public SerializableFailureMechanismSectionCollection FailureMechanismSectionCollection { get;} + + /// + /// Gets the collection of serializable failure mechanism sections. + /// + public IEnumerable FailureMechanismSections { get; } + + /// + /// Gets the collection of serializable combined failure mechanism section assemblies. + /// + public IEnumerable CombinedFailureMechanismSectionAssemblies { get; } + } +} \ No newline at end of file Index: Ringtoets/Integration/src/Ringtoets.Integration.IO/AggregatedSerializableFailureMechanism.cs =================================================================== diff -u -rb0f0122af5f9b499bb001da2fdac289960bf4bb1 -r316e5aab030403874f0517958110eb3eea831527 --- Ringtoets/Integration/src/Ringtoets.Integration.IO/AggregatedSerializableFailureMechanism.cs (.../AggregatedSerializableFailureMechanism.cs) (revision b0f0122af5f9b499bb001da2fdac289960bf4bb1) +++ Ringtoets/Integration/src/Ringtoets.Integration.IO/AggregatedSerializableFailureMechanism.cs (.../AggregatedSerializableFailureMechanism.cs) (revision 316e5aab030403874f0517958110eb3eea831527) @@ -33,8 +33,8 @@ /// /// An instance of . /// - /// The . - /// The + /// The . + /// The /// that belongs to the failure mechanism. /// A collection of /// that belongs to the failure mechanism. Index: Ringtoets/Integration/src/Ringtoets.Integration.IO/Ringtoets.Integration.IO.csproj =================================================================== diff -u -r728cb3dd140c73e41fc4305d5bcc9c9b8f690208 -r316e5aab030403874f0517958110eb3eea831527 --- Ringtoets/Integration/src/Ringtoets.Integration.IO/Ringtoets.Integration.IO.csproj (.../Ringtoets.Integration.IO.csproj) (revision 728cb3dd140c73e41fc4305d5bcc9c9b8f690208) +++ Ringtoets/Integration/src/Ringtoets.Integration.IO/Ringtoets.Integration.IO.csproj (.../Ringtoets.Integration.IO.csproj) (revision 316e5aab030403874f0517958110eb3eea831527) @@ -15,6 +15,7 @@ + Index: Ringtoets/Integration/test/Ringtoets.Integration.IO.Test/AggregatedSerializableCombinedFailureMechanismSectionAssembliesTest.cs =================================================================== diff -u --- Ringtoets/Integration/test/Ringtoets.Integration.IO.Test/AggregatedSerializableCombinedFailureMechanismSectionAssembliesTest.cs (revision 0) +++ Ringtoets/Integration/test/Ringtoets.Integration.IO.Test/AggregatedSerializableCombinedFailureMechanismSectionAssembliesTest.cs (revision 316e5aab030403874f0517958110eb3eea831527) @@ -0,0 +1,93 @@ +// 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 NUnit.Framework; +using Ringtoets.AssemblyTool.IO.Model; + +namespace Ringtoets.Integration.IO.Test +{ + [TestFixture] + public class AggregatedSerializableCombinedFailureMechanismSectionAssembliesTest + { + [Test] + public void Constructor_FailureMechanismSectionCollectionNull_ThrowsArgumentNullException() + { + // Call + TestDelegate call = () => new AggregatedSerializableCombinedFailureMechanismSectionAssemblies(null, + Enumerable.Empty(), + Enumerable.Empty()); + + // Assert + var exception = Assert.Throws(call); + Assert.AreEqual("failureMechanismSectionCollection", exception.ParamName); + } + + [Test] + public void Constructor_FailureMechanismSectionsNull_ThrowsArgumentNullException() + { + // Call + TestDelegate call = () => new AggregatedSerializableCombinedFailureMechanismSectionAssemblies(new SerializableFailureMechanismSectionCollection(), + null, + Enumerable.Empty()); + + // Assert + var exception = Assert.Throws(call); + Assert.AreEqual("failureMechanismSections", exception.ParamName); + } + + [Test] + public void Constructor_CombinedFailureMechanismSectionAssembliesNull_ThrowsArgumentNullException() + { + // Call + TestDelegate call = () => new AggregatedSerializableCombinedFailureMechanismSectionAssemblies(new SerializableFailureMechanismSectionCollection(), + Enumerable.Empty(), + null); + + // Assert + var exception = Assert.Throws(call); + Assert.AreEqual("combinedFailureMechanismSectionAssemblies", exception.ParamName); + } + + [Test] + public void Constructor_WithValidArguments_ExpectedValues() + { + // Setup + var failureMechanismSectionCollection = new SerializableFailureMechanismSectionCollection(); + IEnumerable failureMechanismSections = + Enumerable.Empty(); + IEnumerable failureMechanismSectionAssemblies = + Enumerable.Empty(); + + // Call + var aggregate = new AggregatedSerializableCombinedFailureMechanismSectionAssemblies(failureMechanismSectionCollection, + failureMechanismSections, + failureMechanismSectionAssemblies); + + // Assert + Assert.AreSame(failureMechanismSectionCollection, aggregate.FailureMechanismSectionCollection); + Assert.AreSame(failureMechanismSections, aggregate.FailureMechanismSections); + Assert.AreSame(failureMechanismSectionAssemblies, aggregate.CombinedFailureMechanismSectionAssemblies); + } + } +} \ No newline at end of file Index: Ringtoets/Integration/test/Ringtoets.Integration.IO.Test/Ringtoets.Integration.IO.Test.csproj =================================================================== diff -u -r728cb3dd140c73e41fc4305d5bcc9c9b8f690208 -r316e5aab030403874f0517958110eb3eea831527 --- Ringtoets/Integration/test/Ringtoets.Integration.IO.Test/Ringtoets.Integration.IO.Test.csproj (.../Ringtoets.Integration.IO.Test.csproj) (revision 728cb3dd140c73e41fc4305d5bcc9c9b8f690208) +++ Ringtoets/Integration/test/Ringtoets.Integration.IO.Test/Ringtoets.Integration.IO.Test.csproj (.../Ringtoets.Integration.IO.Test.csproj) (revision 316e5aab030403874f0517958110eb3eea831527) @@ -17,6 +17,7 @@ +