// Copyright (C) Stichting Deltares 2016. 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.Linq; using Application.Ringtoets.Storage.DbContext; using Application.Ringtoets.Storage.Read; using Application.Ringtoets.Storage.Serializers; using Core.Common.Base.Geometry; using NUnit.Framework; using Ringtoets.ClosingStructures.Data; using Ringtoets.Common.Data.Calculation; using Ringtoets.Common.Data.DikeProfiles; using Ringtoets.Common.Data.TestUtil; using Ringtoets.GrassCoverErosionInwards.Data; using Ringtoets.GrassCoverErosionOutwards.Data; using Ringtoets.HeightStructures.Data; using Ringtoets.Piping.Data; using Ringtoets.StabilityPointStructures.Data; using Ringtoets.StabilityStoneCover.Data; using Ringtoets.WaveImpactAsphaltCover.Data; namespace Application.Ringtoets.Storage.Test.Read { [TestFixture] public class FailureMechanismEntityReadExtensionsTest { [Test] [TestCase(true)] [TestCase(false)] public void ReadAsStandAloneFailureMechanism_WithoutSectionsSet_ReturnsNewStandAloneFailureMechanism(bool isRelevant) { // Setup var entity = new FailureMechanismEntity { IsRelevant = Convert.ToByte(isRelevant), Comments = "Some comment" }; var collector = new ReadConversionCollector(); var failureMechanism = new TestFailureMechanism(); // Call entity.ReadCommonFailureMechanismProperties(failureMechanism, collector); // Assert Assert.IsEmpty(failureMechanism.Sections); Assert.AreEqual(isRelevant, failureMechanism.IsRelevant); Assert.AreEqual(entity.Comments, failureMechanism.Comments); Assert.IsEmpty(failureMechanism.Sections); } [Test] public void ReadAsStandAloneFailureMechanism_WithSectionsSet_ReturnsNewStandAloneFailureMechanismWithFailureMechanismSections() { // Setup var entity = new FailureMechanismEntity { FailureMechanismSectionEntities = { CreateSimpleFailureMechanismSectionEntity() } }; var collector = new ReadConversionCollector(); var failureMechanism = new TestFailureMechanism(); // Call entity.ReadCommonFailureMechanismProperties(failureMechanism, collector); // Assert Assert.AreEqual(1, failureMechanism.Sections.Count()); } private static FailureMechanismSectionEntity CreateSimpleFailureMechanismSectionEntity() { var dummyPoints = new[] { new Point2D(0, 0) }; string dymmyPointXml = new Point2DXmlSerializer().ToXml(dummyPoints); var failureMechanismSectionEntity = new FailureMechanismSectionEntity { Name = "section", FailureMechanismSectionPointXml = dymmyPointXml }; return failureMechanismSectionEntity; } #region Piping [Test] public void ReadAsPipingFailureMechanism_WithoutFailureMechanism_ThrowsArgumentNullException() { // Setup var entity = new FailureMechanismEntity(); // Call TestDelegate test = () => entity.ReadAsPipingFailureMechanism(null, new ReadConversionCollector()); // Assert var parameter = Assert.Throws(test).ParamName; Assert.AreEqual("failureMechanism", parameter); } [Test] public void ReadAsPipingFailureMechanism_WithoutCollector_ThrowsArgumentNullException() { // Setup var entity = new FailureMechanismEntity(); // Call TestDelegate test = () => entity.ReadAsPipingFailureMechanism(new PipingFailureMechanism(), null); // Assert var parameter = Assert.Throws(test).ParamName; Assert.AreEqual("collector", parameter); } [Test] [TestCase(true)] [TestCase(false)] public void ReadAsPipingFailureMechanism_WithCollector_ReturnsNewPipingFailureMechanismWithPropertiesSet(bool isRelevant) { // Setup var entity = new FailureMechanismEntity { IsRelevant = Convert.ToByte(isRelevant), Comments = "Some comment", CalculationGroupEntity = new CalculationGroupEntity(), PipingFailureMechanismMetaEntities = new[] { new PipingFailureMechanismMetaEntity { A = 0.95, UpliftCriticalSafetyFactor = 1.2 } } }; var collector = new ReadConversionCollector(); var failureMechanism = new PipingFailureMechanism(); // Call entity.ReadAsPipingFailureMechanism(failureMechanism, collector); // Assert Assert.IsNotNull(failureMechanism); Assert.AreEqual(isRelevant, failureMechanism.IsRelevant); Assert.AreEqual(entity.Comments, failureMechanism.Comments); Assert.IsEmpty(failureMechanism.StochasticSoilModels); Assert.IsEmpty(failureMechanism.Sections); var pipingFailureMechanismMetaEntities = entity.PipingFailureMechanismMetaEntities.ToArray(); var probabilityAssessmentInput = pipingFailureMechanismMetaEntities[0]; Assert.AreEqual(probabilityAssessmentInput.A, failureMechanism.PipingProbabilityAssessmentInput.A); Assert.AreEqual(probabilityAssessmentInput.UpliftCriticalSafetyFactor, failureMechanism.PipingProbabilityAssessmentInput.UpliftCriticalSafetyFactor.Value); } [Test] public void ReadAsPipingFailureMechanism_WithStochasticSoilModelsSet_ReturnsNewPipingFailureMechanismWithStochasticSoilModelsSet() { // Setup string emptySegmentPointsXml = new Point2DXmlSerializer().ToXml(new Point2D[0]); var entity = new FailureMechanismEntity { CalculationGroupEntity = new CalculationGroupEntity(), StochasticSoilModelEntities = { new StochasticSoilModelEntity { StochasticSoilModelSegmentPointXml = emptySegmentPointsXml, Name = "A", Order = 1 }, new StochasticSoilModelEntity { StochasticSoilModelSegmentPointXml = emptySegmentPointsXml, Name = "B", Order = 0 } } }; var collector = new ReadConversionCollector(); var failureMechanism = new PipingFailureMechanism(); // Call entity.ReadAsPipingFailureMechanism(failureMechanism, collector); // Assert Assert.AreEqual(2, failureMechanism.StochasticSoilModels.Count); CollectionAssert.AreEqual(new[] { "B", "A" }, failureMechanism.StochasticSoilModels.Select(s => s.Name)); } [Test] public void ReadAsPipingFailureMechanism_WithSurfaceLines_ReturnsNewPipingFailureMechanismWithSurfaceLinesSet() { // Setup string emptyPointsXml = new Point3DXmlSerializer().ToXml(new Point3D[0]); var entity = new FailureMechanismEntity { CalculationGroupEntity = new CalculationGroupEntity(), SurfaceLineEntities = { new SurfaceLineEntity { PointsXml = emptyPointsXml, Name = "1", Order = 1 }, new SurfaceLineEntity { PointsXml = emptyPointsXml, Name = "2", Order = 0 } } }; var collector = new ReadConversionCollector(); var failureMechanism = new PipingFailureMechanism(); // Call entity.ReadAsPipingFailureMechanism(failureMechanism, collector); // Assert Assert.AreEqual(2, failureMechanism.SurfaceLines.Count); CollectionAssert.AreEqual(new[] { "2", "1" }, failureMechanism.SurfaceLines.Select(sl => sl.Name)); } [Test] public void ReadAsPipingFailureMechanism_WithSectionsSet_ReturnsNewPipingFailureMechanismWithFailureMechanismSectionsSet() { // Setup FailureMechanismSectionEntity failureMechanismSectionEntity = CreateSimpleFailureMechanismSectionEntity(); var pipingSectionResultEntity = new PipingSectionResultEntity { FailureMechanismSectionEntity = failureMechanismSectionEntity }; failureMechanismSectionEntity.PipingSectionResultEntities.Add(pipingSectionResultEntity); var entity = new FailureMechanismEntity { CalculationGroupEntity = new CalculationGroupEntity(), FailureMechanismSectionEntities = { failureMechanismSectionEntity } }; var collector = new ReadConversionCollector(); var failureMechanism = new PipingFailureMechanism(); // Call entity.ReadAsPipingFailureMechanism(failureMechanism, collector); // Assert Assert.AreEqual(1, failureMechanism.Sections.Count()); } [Test] public void ReadAsPipingFailureMechanism_WithCalculationGroup_ReturnsNewPipingFailureMechanismWithCalculationGroupSet() { // Setup var entity = new FailureMechanismEntity { CalculationGroupEntity = new CalculationGroupEntity { IsEditable = 0, Name = "Berekeningen", Order = 0, CalculationGroupEntity1 = { new CalculationGroupEntity { IsEditable = 1, Name = "Child1", Order = 0 }, new CalculationGroupEntity { IsEditable = 1, Name = "Child2", Order = 1 }, } } }; var collector = new ReadConversionCollector(); var failureMechanism = new PipingFailureMechanism(); // Call entity.ReadAsPipingFailureMechanism(failureMechanism, collector); // Assert Assert.AreEqual(2, failureMechanism.CalculationsGroup.Children.Count); ICalculationBase child1 = failureMechanism.CalculationsGroup.Children[0]; Assert.AreEqual("Child1", child1.Name); ICalculationBase child2 = failureMechanism.CalculationsGroup.Children[1]; Assert.AreEqual("Child2", child2.Name); } #endregion #region Grass Cover Erosion Inwards [Test] [TestCase(true)] [TestCase(false)] public void ReadAsGrassCoverErosionInwardsFailureMechanism_WithCollector_ReturnsNewGrassCoverErosionInwardsFailureMechanismWithPropertiesSet(bool isRelevant) { // Setup var entity = new FailureMechanismEntity { IsRelevant = Convert.ToByte(isRelevant), Comments = "Some comment", GrassCoverErosionInwardsFailureMechanismMetaEntities = { new GrassCoverErosionInwardsFailureMechanismMetaEntity { N = 3 } }, CalculationGroupEntity = new CalculationGroupEntity() }; var collector = new ReadConversionCollector(); var failureMechanism = new GrassCoverErosionInwardsFailureMechanism(); // Call entity.ReadAsGrassCoverErosionInwardsFailureMechanism(failureMechanism, collector); // Assert Assert.IsNotNull(failureMechanism); Assert.AreEqual(isRelevant, failureMechanism.IsRelevant); Assert.AreEqual(entity.Comments, failureMechanism.Comments); Assert.IsEmpty(failureMechanism.Sections); Assert.AreEqual(3, failureMechanism.GeneralInput.N); } [Test] public void ReadAsGrassCoverErosionInwardsFailureMechanism_WithDikeProfilesSet_ReturnsGrassCoverErosionInwardsFailureMechanismWithDikeProfilesAdded() { // Setup string emptyDikeGeometryXml = new RoughnessPointXmlSerializer().ToXml(new RoughnessPoint[0]); string emptyForeshoreBinaryXml = new Point2DXmlSerializer().ToXml(new Point2D[0]); var entity = new FailureMechanismEntity { GrassCoverErosionInwardsFailureMechanismMetaEntities = { new GrassCoverErosionInwardsFailureMechanismMetaEntity { N = 3 } }, DikeProfileEntities = { new DikeProfileEntity { DikeGeometryXml = emptyDikeGeometryXml, ForeshoreXml = emptyForeshoreBinaryXml }, new DikeProfileEntity { DikeGeometryXml = emptyDikeGeometryXml, ForeshoreXml = emptyForeshoreBinaryXml } }, CalculationGroupEntity = new CalculationGroupEntity() }; GrassCoverErosionInwardsFailureMechanism failureMechanism = new GrassCoverErosionInwardsFailureMechanism(); ReadConversionCollector collector = new ReadConversionCollector(); // Call entity.ReadAsGrassCoverErosionInwardsFailureMechanism(failureMechanism, collector); // Assert Assert.AreEqual(2, failureMechanism.DikeProfiles.Count); } [Test] public void ReadAsGrassCoverErosionInwardsFailureMechanism_WithSectionsSet_ReturnsNewGrassCoverErosionInwardsFailureMechanismWithFailureMechanismSectionsAdded() { // Setup FailureMechanismSectionEntity failureMechanismSectionEntity = CreateSimpleFailureMechanismSectionEntity(); var grassCoverErosionInwardsSectionResultEntity = new GrassCoverErosionInwardsSectionResultEntity { FailureMechanismSectionEntity = failureMechanismSectionEntity }; failureMechanismSectionEntity.GrassCoverErosionInwardsSectionResultEntities.Add(grassCoverErosionInwardsSectionResultEntity); var entity = new FailureMechanismEntity { FailureMechanismSectionEntities = { failureMechanismSectionEntity }, GrassCoverErosionInwardsFailureMechanismMetaEntities = { new GrassCoverErosionInwardsFailureMechanismMetaEntity { N = 1 } }, CalculationGroupEntity = new CalculationGroupEntity() }; var collector = new ReadConversionCollector(); var failureMechanism = new GrassCoverErosionInwardsFailureMechanism(); // Call entity.ReadAsGrassCoverErosionInwardsFailureMechanism(failureMechanism, collector); // Assert Assert.AreEqual(1, failureMechanism.Sections.Count()); } [Test] public void ReadAsGrassCoverErosionInwardsFailureMechanism_WithCalculationGroup_ReturnsNewGrassCoverErosionInwardsFailureMechanismWithCalculationGroupSet() { // Setup var entity = new FailureMechanismEntity { CalculationGroupEntity = new CalculationGroupEntity { IsEditable = 0, Name = "Berekeningen", Order = 0, CalculationGroupEntity1 = { new CalculationGroupEntity { IsEditable = 1, Name = "Child1", Order = 0 }, new CalculationGroupEntity { IsEditable = 1, Name = "Child2", Order = 1 }, } }, GrassCoverErosionInwardsFailureMechanismMetaEntities = { new GrassCoverErosionInwardsFailureMechanismMetaEntity { N = 1 } } }; var collector = new ReadConversionCollector(); var failureMechanism = new GrassCoverErosionInwardsFailureMechanism(); // Call entity.ReadAsGrassCoverErosionInwardsFailureMechanism(failureMechanism, collector); // Assert Assert.AreEqual(2, failureMechanism.CalculationsGroup.Children.Count); ICalculationBase child1 = failureMechanism.CalculationsGroup.Children[0]; Assert.AreEqual("Child1", child1.Name); ICalculationBase child2 = failureMechanism.CalculationsGroup.Children[1]; Assert.AreEqual("Child2", child2.Name); } #endregion #region Grass Cover Erosion Outwards [Test] [TestCase(true)] [TestCase(false)] public void ReadAsGrassCoverErosionOutwardsFailureMechanism_WithCollector_ReturnsNewGrassCoverErosionOutwardsFailureMechanismWithPropertiesSet(bool isRelevant) { // Setup var entity = new FailureMechanismEntity { IsRelevant = Convert.ToByte(isRelevant), Comments = "Some comment", GrassCoverErosionOutwardsFailureMechanismMetaEntities = { new GrassCoverErosionOutwardsFailureMechanismMetaEntity { N = 3 } }, CalculationGroupEntity = new CalculationGroupEntity() }; var collector = new ReadConversionCollector(); var failureMechanism = new GrassCoverErosionOutwardsFailureMechanism(); // Call entity.ReadAsGrassCoverErosionOutwardsFailureMechanism(failureMechanism, collector); // Assert Assert.IsNotNull(failureMechanism); Assert.AreEqual(isRelevant, failureMechanism.IsRelevant); Assert.AreEqual(entity.Comments, failureMechanism.Comments); Assert.IsEmpty(failureMechanism.Sections); Assert.AreEqual(3, failureMechanism.GeneralInput.N); } [Test] public void ReadAsGrassCoverErosionOutwardsFailureMechanism_WithSectionsSet_ReturnsNewGrassCoverErosionOutwardsFailureMechanismWithFailureMechanismSectionsAdded() { // Setup FailureMechanismSectionEntity failureMechanismSectionEntity = CreateSimpleFailureMechanismSectionEntity(); var grassCoverErosionOutwardsSectionResultEntity = new GrassCoverErosionOutwardsSectionResultEntity { FailureMechanismSectionEntity = failureMechanismSectionEntity }; failureMechanismSectionEntity.GrassCoverErosionOutwardsSectionResultEntities.Add(grassCoverErosionOutwardsSectionResultEntity); var entity = new FailureMechanismEntity { FailureMechanismSectionEntities = { failureMechanismSectionEntity }, GrassCoverErosionOutwardsFailureMechanismMetaEntities = { new GrassCoverErosionOutwardsFailureMechanismMetaEntity { N = 1 } }, CalculationGroupEntity = new CalculationGroupEntity() }; var collector = new ReadConversionCollector(); var failureMechanism = new GrassCoverErosionOutwardsFailureMechanism(); // Call entity.ReadAsGrassCoverErosionOutwardsFailureMechanism(failureMechanism, collector); // Assert Assert.AreEqual(1, failureMechanism.Sections.Count()); } [Test] public void ReadAsGrassCoverErosionOutwardsFailureMechanism_WithWaveConditionsCalculationGroup_ReturnsNewGrassCoverErosionInwardsFailureMechanismWithCalculationGroupSet() { // Setup var entity = new FailureMechanismEntity { CalculationGroupEntity = new CalculationGroupEntity { IsEditable = 0, Name = "Berekeningen", Order = 0, CalculationGroupEntity1 = { new CalculationGroupEntity { IsEditable = 1, Name = "Child1", Order = 0 }, new CalculationGroupEntity { IsEditable = 1, Name = "Child2", Order = 1 }, } }, GrassCoverErosionOutwardsFailureMechanismMetaEntities = { new GrassCoverErosionOutwardsFailureMechanismMetaEntity { N = 1 } } }; var collector = new ReadConversionCollector(); var failureMechanism = new GrassCoverErosionOutwardsFailureMechanism(); // Call entity.ReadAsGrassCoverErosionOutwardsFailureMechanism(failureMechanism, collector); // Assert Assert.AreEqual(2, failureMechanism.WaveConditionsCalculationGroup.Children.Count); ICalculationBase child1 = failureMechanism.WaveConditionsCalculationGroup.Children[0]; Assert.AreEqual("Child1", child1.Name); ICalculationBase child2 = failureMechanism.WaveConditionsCalculationGroup.Children[1]; Assert.AreEqual("Child2", child2.Name); } [Test] public void ReadAsGrassCoverErosionOutwardsFailureMechanism_WithHydraulicBoundaryLocations_ReturnsNewGrassCoverErosionInwardsFailureMechanismWithLocationsSet() { // Setup var locationAName = "Location A"; var locationBName = "Location B"; var entity = new FailureMechanismEntity { CalculationGroupEntity = new CalculationGroupEntity(), GrassCoverErosionOutwardsFailureMechanismMetaEntities = { new GrassCoverErosionOutwardsFailureMechanismMetaEntity { N = 1 } }, GrassCoverErosionOutwardsHydraulicLocationEntities = { new GrassCoverErosionOutwardsHydraulicLocationEntity { Order = 1, Name = locationBName }, new GrassCoverErosionOutwardsHydraulicLocationEntity { Order = 0, Name = locationAName } } }; var collector = new ReadConversionCollector(); var failureMechanism = new GrassCoverErosionOutwardsFailureMechanism(); // Call entity.ReadAsGrassCoverErosionOutwardsFailureMechanism(failureMechanism, collector); // Assert var hydraulicBoundaryLocations = failureMechanism.HydraulicBoundaryLocations; Assert.AreEqual(2, hydraulicBoundaryLocations.Count); Assert.AreEqual(locationAName, hydraulicBoundaryLocations[0].Name); Assert.AreEqual(locationBName, hydraulicBoundaryLocations[1].Name); } #endregion #region Stability Stone Cover [Test] public void ReadAsStabilityStoneCoverFailureMechanism_WithWaveConditionsCalculationGroup_ReturnsNewStabilityStoneCoverFailureMechanismWithCalculationGroupSet() { // Setup var entity = new FailureMechanismEntity { CalculationGroupEntity = new CalculationGroupEntity { IsEditable = 0, Name = "Berekeningen", Order = 0, CalculationGroupEntity1 = { new CalculationGroupEntity { IsEditable = 1, Name = "Child1", Order = 1 }, new CalculationGroupEntity { IsEditable = 1, Name = "Child2", Order = 0 }, } } }; var collector = new ReadConversionCollector(); var failureMechanism = new StabilityStoneCoverFailureMechanism(); // Call entity.ReadAsStabilityStoneCoverFailureMechanism(failureMechanism, collector); // Assert Assert.AreEqual(2, failureMechanism.WaveConditionsCalculationGroup.Children.Count); ICalculationBase child1 = failureMechanism.WaveConditionsCalculationGroup.Children[0]; Assert.AreEqual("Child2", child1.Name); ICalculationBase child2 = failureMechanism.WaveConditionsCalculationGroup.Children[1]; Assert.AreEqual("Child1", child2.Name); } [Test] public void ReadAsStabilityStoneCoverFailureMechanism_WithForeshoreProfiles_ReturnsNewStabilityStoneCoverFailureMechanismWithForeshoreProfilesSet() { // Setup var entity = new FailureMechanismEntity { CalculationGroupEntity = new CalculationGroupEntity(), ForeshoreProfileEntities = { new ForeshoreProfileEntity { Name = "Child1", GeometryXml = new Point2DXmlSerializer().ToXml(Enumerable.Empty()), Order = 1 }, new ForeshoreProfileEntity { Name = "Child2", GeometryXml = new Point2DXmlSerializer().ToXml(Enumerable.Empty()), Order = 0 }, } }; var collector = new ReadConversionCollector(); var failureMechanism = new StabilityStoneCoverFailureMechanism(); // Call entity.ReadAsStabilityStoneCoverFailureMechanism(failureMechanism, collector); // Assert Assert.AreEqual(2, failureMechanism.ForeshoreProfiles.Count); ForeshoreProfile child1 = failureMechanism.ForeshoreProfiles[0]; Assert.AreEqual("Child2", child1.Name); ForeshoreProfile child2 = failureMechanism.ForeshoreProfiles[1]; Assert.AreEqual("Child1", child2.Name); } #endregion #region Wave Impact Asphalt Cover [Test] public void ReadAsWaveImpactAsphaltCoverFailureMechanism_WithWaveConditionsCalculationGroup_ReturnsNewWaveImpactAsphaltCoverFailureMechanismWithCalculationGroupSet() { // Setup var entity = new FailureMechanismEntity { CalculationGroupEntity = new CalculationGroupEntity { IsEditable = 0, Name = "Berekeningen", Order = 0, CalculationGroupEntity1 = { new CalculationGroupEntity { IsEditable = 1, Name = "Child1", Order = 1 }, new CalculationGroupEntity { IsEditable = 1, Name = "Child2", Order = 0 }, } } }; var collector = new ReadConversionCollector(); var failureMechanism = new WaveImpactAsphaltCoverFailureMechanism(); // Call entity.ReadAsWaveImpactAsphaltCoverFailureMechanism(failureMechanism, collector); // Assert Assert.AreEqual(2, failureMechanism.WaveConditionsCalculationGroup.Children.Count); ICalculationBase child1 = failureMechanism.WaveConditionsCalculationGroup.Children[0]; Assert.AreEqual("Child2", child1.Name); ICalculationBase child2 = failureMechanism.WaveConditionsCalculationGroup.Children[1]; Assert.AreEqual("Child1", child2.Name); } [Test] public void ReadAsWaveImpactAsphaltCoverFailureMechanism_WithForeshoreProfiles_ReturnsNewWaveImpactAsphaltCoverFailureMechanismWithForeshoreProfilesSet() { // Setup var entity = new FailureMechanismEntity { CalculationGroupEntity = new CalculationGroupEntity(), ForeshoreProfileEntities = { new ForeshoreProfileEntity { Name = "Child1", GeometryXml = new Point2DXmlSerializer().ToXml(Enumerable.Empty()), Order = 1 }, new ForeshoreProfileEntity { Name = "Child2", GeometryXml = new Point2DXmlSerializer().ToXml(Enumerable.Empty()), Order = 0 }, } }; var collector = new ReadConversionCollector(); var failureMechanism = new WaveImpactAsphaltCoverFailureMechanism(); // Call entity.ReadAsWaveImpactAsphaltCoverFailureMechanism(failureMechanism, collector); // Assert Assert.AreEqual(2, failureMechanism.ForeshoreProfiles.Count); ForeshoreProfile child1 = failureMechanism.ForeshoreProfiles[0]; Assert.AreEqual("Child2", child1.Name); ForeshoreProfile child2 = failureMechanism.ForeshoreProfiles[1]; Assert.AreEqual("Child1", child2.Name); } #endregion #region Height Structures [Test] public void ReadAsHeightStructuresFailureMechanism_WithForshoreProfiles_ReturnFailureMechanismWithForeshoreProfilesSet() { // Setup const int generalInputN = 7; var entity = new FailureMechanismEntity { CalculationGroupEntity = new CalculationGroupEntity(), ForeshoreProfileEntities = { new ForeshoreProfileEntity { Name = "Child1", GeometryXml = new Point2DXmlSerializer().ToXml(Enumerable.Empty()), Order = 1 }, new ForeshoreProfileEntity { Name = "Child2", GeometryXml = new Point2DXmlSerializer().ToXml(Enumerable.Empty()), Order = 0 }, }, HeightStructuresFailureMechanismMetaEntities = { new HeightStructuresFailureMechanismMetaEntity { N = generalInputN } } }; var collector = new ReadConversionCollector(); var failureMechanism = new HeightStructuresFailureMechanism(); // Call entity.ReadAsHeightStructuresFailureMechanism(failureMechanism, collector); // Assert Assert.AreEqual(2, failureMechanism.ForeshoreProfiles.Count); ForeshoreProfile child1 = failureMechanism.ForeshoreProfiles[0]; Assert.AreEqual("Child2", child1.Name); ForeshoreProfile child2 = failureMechanism.ForeshoreProfiles[1]; Assert.AreEqual("Child1", child2.Name); Assert.AreEqual(generalInputN, failureMechanism.GeneralInput.N); } [Test] public void ReadAsHeightStructuresFailureMechanism_WithHeightStructures_ReturnFailureMechanismWithHeightStructuresSet() { // Setup var entity = new FailureMechanismEntity { CalculationGroupEntity = new CalculationGroupEntity(), HeightStructureEntities = { new HeightStructureEntity { Order = 2, Name = "Child1", Id = "a" }, new HeightStructureEntity { Order = 1, Name = "Child2", Id = "b" } }, HeightStructuresFailureMechanismMetaEntities = { new HeightStructuresFailureMechanismMetaEntity { N = 7 } } }; var collector = new ReadConversionCollector(); var failureMechanism = new HeightStructuresFailureMechanism(); // Call entity.ReadAsHeightStructuresFailureMechanism(failureMechanism, collector); // Assert Assert.AreEqual(2, failureMechanism.HeightStructures.Count); HeightStructure child1 = failureMechanism.HeightStructures[0]; Assert.AreEqual("Child2", child1.Name); HeightStructure child2 = failureMechanism.HeightStructures[1]; Assert.AreEqual("Child1", child2.Name); } #endregion #region Closing Structures [Test] public void ReadAsClosingStructuresFailureMechanism_WithForshoreProfiles_ReturnFailureMechanismWithForeshoreProfilesSet() { // Setup const int generalInputN2A = 3; var entity = new FailureMechanismEntity { CalculationGroupEntity = new CalculationGroupEntity(), ForeshoreProfileEntities = { new ForeshoreProfileEntity { Name = "Child1", GeometryXml = new Point2DXmlSerializer().ToXml(Enumerable.Empty()), Order = 1 }, new ForeshoreProfileEntity { Name = "Child2", GeometryXml = new Point2DXmlSerializer().ToXml(Enumerable.Empty()), Order = 0 } }, ClosingStructureFailureMechanismMetaEntities = { new ClosingStructureFailureMechanismMetaEntity { N2A = generalInputN2A } } }; var collector = new ReadConversionCollector(); var failureMechanism = new ClosingStructuresFailureMechanism(); // Call entity.ReadAsClosingStructuresFailureMechanism(failureMechanism, collector); // Assert Assert.AreEqual(2, failureMechanism.ForeshoreProfiles.Count); ForeshoreProfile child1 = failureMechanism.ForeshoreProfiles[0]; Assert.AreEqual("Child2", child1.Name); ForeshoreProfile child2 = failureMechanism.ForeshoreProfiles[1]; Assert.AreEqual("Child1", child2.Name); Assert.AreEqual(generalInputN2A, failureMechanism.GeneralInput.N2A); } #endregion #region Stability Point Structures [Test] public void ReadAsStabilityPointStructuresFailureMechanism_WithForshoreProfiles_ReturnFailureMechanismWithForeshoreProfilesSet() { // Setup const int generalInputN = 5; var entity = new FailureMechanismEntity { CalculationGroupEntity = new CalculationGroupEntity(), ForeshoreProfileEntities = { new ForeshoreProfileEntity { Name = "Child1", GeometryXml = new Point2DXmlSerializer().ToXml(Enumerable.Empty()), Order = 1 }, new ForeshoreProfileEntity { Name = "Child2", GeometryXml = new Point2DXmlSerializer().ToXml(Enumerable.Empty()), Order = 0 } }, StabilityPointStructuresFailureMechanismMetaEntities = { new StabilityPointStructuresFailureMechanismMetaEntity { N = generalInputN } } }; var collector = new ReadConversionCollector(); var failureMechanism = new StabilityPointStructuresFailureMechanism(); // Call entity.ReadAsStabilityPointStructuresFailureMechanism(failureMechanism, collector); // Assert Assert.AreEqual(2, failureMechanism.ForeshoreProfiles.Count); ForeshoreProfile child1 = failureMechanism.ForeshoreProfiles[0]; Assert.AreEqual("Child2", child1.Name); ForeshoreProfile child2 = failureMechanism.ForeshoreProfiles[1]; Assert.AreEqual("Child1", child2.Name); Assert.AreEqual(generalInputN, failureMechanism.GeneralInput.N); } #endregion } }