// 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.BinaryConverters; using Application.Ringtoets.Storage.DbContext; using Application.Ringtoets.Storage.Read; using Core.Common.Base.Geometry; using NUnit.Framework; using Ringtoets.Common.Data.Calculation; using Ringtoets.Common.Data.TestUtil; using Ringtoets.GrassCoverErosionInwards.Data; using Ringtoets.Piping.Data; namespace Application.Ringtoets.Storage.Test.Read { [TestFixture] public class FailureMechanismEntityReadExtensionsTest { #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 entityId = new Random(21).Next(1, 502); var entity = new FailureMechanismEntity { FailureMechanismEntityId = entityId, IsRelevant = Convert.ToByte(isRelevant), Comments = "Some comment", CalculationGroupEntity = new CalculationGroupEntity { CalculationGroupEntityId = 2 }, PipingFailureMechanismMetaEntities = new[] { new PipingFailureMechanismMetaEntity { PipingFailureMechanismMetaEntityId = 3, A = 0.95 } } }; var collector = new ReadConversionCollector(); var failureMechanism = new PipingFailureMechanism(); // Call entity.ReadAsPipingFailureMechanism(failureMechanism, collector); // Assert Assert.IsNotNull(failureMechanism); Assert.AreEqual(entityId, failureMechanism.StorageId); 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.PipingFailureMechanismMetaEntityId, failureMechanism.PipingProbabilityAssessmentInput.StorageId); Assert.AreEqual(probabilityAssessmentInput.A, failureMechanism.PipingProbabilityAssessmentInput.A); } [Test] public void ReadAsPipingFailureMechanism_WithStochasticSoilModelsSet_ReturnsNewPipingFailureMechanismWithStochasticSoilModelsSet() { // Setup var entity = new FailureMechanismEntity { CalculationGroupEntity = new CalculationGroupEntity { CalculationGroupEntityId = 3 }, StochasticSoilModelEntities = { new StochasticSoilModelEntity(), new StochasticSoilModelEntity() } }; var collector = new ReadConversionCollector(); var failureMechanism = new PipingFailureMechanism(); // Call entity.ReadAsPipingFailureMechanism(failureMechanism, collector); // Assert Assert.AreEqual(2, failureMechanism.StochasticSoilModels.Count); } [Test] public void ReadAsPipingFailureMechanism_WithSurfaceLines_ReturnsNewPipingFailureMechanismWithSurfaceLinesSet() { // Setup var entity = new FailureMechanismEntity { CalculationGroupEntity = new CalculationGroupEntity { CalculationGroupEntityId = 6 }, SurfaceLineEntities = { new SurfaceLineEntity(), new SurfaceLineEntity() } }; var collector = new ReadConversionCollector(); var failureMechanism = new PipingFailureMechanism(); // Call entity.ReadAsPipingFailureMechanism(failureMechanism, collector); // Assert Assert.AreEqual(2, failureMechanism.SurfaceLines.Count); } [Test] public void ReadAsPipingFailureMechanism_WithSectionsSet_ReturnsNewPipingFailureMechanismWithFailureMechanismSectionsSet() { // Setup var entityId = new Random(21).Next(1, 502); var failureMechanismSectionEntity = new FailureMechanismSectionEntity { Name = "section", FailureMechanismSectionPointEntities = { new FailureMechanismSectionPointEntity() } }; var pipingSectionResultEntity = new PipingSectionResultEntity { PipingSectionResultEntityId = entityId, FailureMechanismSectionEntity = failureMechanismSectionEntity }; failureMechanismSectionEntity.PipingSectionResultEntities.Add(pipingSectionResultEntity); var entity = new FailureMechanismEntity { FailureMechanismEntityId = 1, CalculationGroupEntity = new CalculationGroupEntity { CalculationGroupEntityId = 1 }, FailureMechanismSectionEntities = { failureMechanismSectionEntity } }; var collector = new ReadConversionCollector(); var failureMechanism = new PipingFailureMechanism(); // Call entity.ReadAsPipingFailureMechanism(failureMechanism, collector); // Assert Assert.AreEqual(1, failureMechanism.Sections.Count()); Assert.AreEqual(entityId, failureMechanism.SectionResults.First().StorageId); } [Test] public void ReadAsPipingFailureMechanism_WithCalculationGroup_ReturnsNewPipingFailureMechanismWithCalculationGroupSet() { // Setup var entityId = new Random(1328).Next(1, 502); const int rootGroupId = 5; const int childGroup1Id = 7; const int childGroup2Id = 9; var entity = new FailureMechanismEntity { FailureMechanismEntityId = entityId, CalculationGroupEntity = new CalculationGroupEntity { CalculationGroupEntityId = rootGroupId, IsEditable = 0, Name = "Berekeningen", Order = 0, CalculationGroupEntity1 = { new CalculationGroupEntity { CalculationGroupEntityId = childGroup1Id, IsEditable = 1, Name = "Child1", Order = 0 }, new CalculationGroupEntity { CalculationGroupEntityId = childGroup2Id, IsEditable = 1, Name = "Child2", Order = 1 }, } } }; var collector = new ReadConversionCollector(); var failureMechanism = new PipingFailureMechanism(); // Call entity.ReadAsPipingFailureMechanism(failureMechanism, collector); // Assert Assert.AreEqual(rootGroupId, failureMechanism.CalculationsGroup.StorageId); Assert.AreEqual(2, failureMechanism.CalculationsGroup.Children.Count); ICalculationBase child1 = failureMechanism.CalculationsGroup.Children[0]; Assert.AreEqual("Child1", child1.Name); Assert.AreEqual(childGroup1Id, ((CalculationGroup)child1).StorageId); ICalculationBase child2 = failureMechanism.CalculationsGroup.Children[1]; Assert.AreEqual("Child2", child2.Name); Assert.AreEqual(childGroup2Id, ((CalculationGroup)child2).StorageId); } #endregion #region Grass Cover Erosion Inwards [Test] [TestCase(true)] [TestCase(false)] public void ReadAsGrassCoverErosionInwardsFailureMechanism_WithCollector_ReturnsNewGrassCoverErosionInwardsFailureMechanismWithPropertiesSet(bool isRelevant) { // Setup var random = new Random(21); var entityId = random.Next(1, 502); var inputId = random.Next(1, 57893); var entity = new FailureMechanismEntity { FailureMechanismEntityId = entityId, IsRelevant = Convert.ToByte(isRelevant), Comments = "Some comment", GrassCoverErosionInwardsFailureMechanismMetaEntities = { new GrassCoverErosionInwardsFailureMechanismMetaEntity { GrassCoverErosionInwardsFailureMechanismMetaEntityId = inputId, N = 3 } }, CalculationGroupEntity = new CalculationGroupEntity { CalculationGroupEntityId = 456 } }; var collector = new ReadConversionCollector(); var failureMechanism = new GrassCoverErosionInwardsFailureMechanism(); // Call entity.ReadAsGrassCoverErosionInwardsFailureMechanism(failureMechanism, collector); // Assert Assert.IsNotNull(failureMechanism); Assert.AreEqual(entityId, failureMechanism.StorageId); Assert.AreEqual(isRelevant, failureMechanism.IsRelevant); Assert.AreEqual(entity.Comments, failureMechanism.Comments); Assert.IsEmpty(failureMechanism.Sections); Assert.AreEqual(inputId, failureMechanism.GeneralInput.StorageId); Assert.AreEqual(3, failureMechanism.GeneralInput.N); } [Test] public void ReadAsGrassCoverErosionInwardsFailureMechanism_WithDikeProfilesSet_ReturnsGrassCoverErosionInwardsFailureMechanismWithDikeProfilesAdded() { // Setup const int id1 = 4578; const int id2 = 384729847; byte[] emptyDikeGeometryBinaryData = new RoughnessPointBinaryConverter().ToBytes(new RoughnessPoint[0]); byte[] emptyForeshoreBinaryData = new Point2DBinaryConverter().ToBytes(new Point2D[0]); var entity = new FailureMechanismEntity { FailureMechanismEntityId = 1, GrassCoverErosionInwardsFailureMechanismMetaEntities = { new GrassCoverErosionInwardsFailureMechanismMetaEntity { GrassCoverErosionInwardsFailureMechanismMetaEntityId = 2, N = 3 } }, DikeProfileEntities = { new DikeProfileEntity { DikeProfileEntityId = id1, DikeGeometryData = emptyDikeGeometryBinaryData, ForeShoreData = emptyForeshoreBinaryData }, new DikeProfileEntity { DikeProfileEntityId = id2, DikeGeometryData = emptyDikeGeometryBinaryData, ForeShoreData = emptyForeshoreBinaryData } }, CalculationGroupEntity = new CalculationGroupEntity { CalculationGroupEntityId = 567 } }; GrassCoverErosionInwardsFailureMechanism failureMechanism = new GrassCoverErosionInwardsFailureMechanism(); ReadConversionCollector collector = new ReadConversionCollector(); // Call entity.ReadAsGrassCoverErosionInwardsFailureMechanism(failureMechanism, collector); // Assert Assert.AreEqual(2, failureMechanism.DikeProfiles.Count); Assert.AreEqual(id1, failureMechanism.DikeProfiles[0].StorageId); Assert.AreEqual(id2, failureMechanism.DikeProfiles[1].StorageId); } [Test] public void ReadAsGrassCoverErosionInwardsFailureMechanism_WithSectionsSet_ReturnsNewGrassCoverErosionInwardsFailureMechanismWithFailureMechanismSectionsAdded() { // Setup var entityId = new Random(21).Next(1, 502); var failureMechanismSectionEntity = new FailureMechanismSectionEntity { Name = "section", FailureMechanismSectionPointEntities = { new FailureMechanismSectionPointEntity() } }; var grassCoverErosionInwardsSectionResultEntity = new GrassCoverErosionInwardsSectionResultEntity { GrassCoverErosionInwardsSectionResultEntityId = entityId, FailureMechanismSectionEntity = failureMechanismSectionEntity }; failureMechanismSectionEntity.GrassCoverErosionInwardsSectionResultEntities.Add(grassCoverErosionInwardsSectionResultEntity); var entity = new FailureMechanismEntity { FailureMechanismEntityId = 1, FailureMechanismSectionEntities = { failureMechanismSectionEntity }, GrassCoverErosionInwardsFailureMechanismMetaEntities = { new GrassCoverErosionInwardsFailureMechanismMetaEntity { GrassCoverErosionInwardsFailureMechanismMetaEntityId = 2, N = 1 } }, CalculationGroupEntity = new CalculationGroupEntity { CalculationGroupEntityId = 9867 } }; var collector = new ReadConversionCollector(); var failureMechanism = new GrassCoverErosionInwardsFailureMechanism(); // Call entity.ReadAsGrassCoverErosionInwardsFailureMechanism(failureMechanism, collector); // Assert Assert.AreEqual(1, failureMechanism.Sections.Count()); Assert.AreEqual(entityId, failureMechanism.SectionResults.First().StorageId); } [Test] public void ReadAsGrassCoverErosionInwardsFailureMechanism_WithCalculationGroup_ReturnsNewGrassCoverErosionInwardsFailureMechanismWithCalculationGroupSet() { // Setup var entityId = new Random(984356).Next(1, 502); const int rootGroupId = 1; const int childGroup1Id = 2; const int childGroup2Id = 3; var entity = new FailureMechanismEntity { FailureMechanismEntityId = entityId, CalculationGroupEntity = new CalculationGroupEntity { CalculationGroupEntityId = rootGroupId, IsEditable = 0, Name = "Berekeningen", Order = 0, CalculationGroupEntity1 = { new CalculationGroupEntity { CalculationGroupEntityId = childGroup1Id, IsEditable = 1, Name = "Child1", Order = 0 }, new CalculationGroupEntity { CalculationGroupEntityId = childGroup2Id, IsEditable = 1, Name = "Child2", Order = 1 }, } }, GrassCoverErosionInwardsFailureMechanismMetaEntities = { new GrassCoverErosionInwardsFailureMechanismMetaEntity { GrassCoverErosionInwardsFailureMechanismMetaEntityId = 3456, N = 1 } } }; var collector = new ReadConversionCollector(); var failureMechanism = new GrassCoverErosionInwardsFailureMechanism(); // Call entity.ReadAsGrassCoverErosionInwardsFailureMechanism(failureMechanism, collector); // Assert Assert.AreEqual(rootGroupId, failureMechanism.CalculationsGroup.StorageId); Assert.AreEqual(2, failureMechanism.CalculationsGroup.Children.Count); ICalculationBase child1 = failureMechanism.CalculationsGroup.Children[0]; Assert.AreEqual("Child1", child1.Name); Assert.AreEqual(childGroup1Id, ((CalculationGroup)child1).StorageId); ICalculationBase child2 = failureMechanism.CalculationsGroup.Children[1]; Assert.AreEqual("Child2", child2.Name); Assert.AreEqual(childGroup2Id, ((CalculationGroup)child2).StorageId); } #endregion [Test] [TestCase(true)] [TestCase(false)] public void ReadAsStandAloneFailureMechanism_WithoutSectionsSet_ReturnsNewStandAloneFailureMechanism(bool isRelevant) { // Setup var entityId = new Random(21).Next(1, 502); var entity = new FailureMechanismEntity { FailureMechanismEntityId = entityId, 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(entityId, failureMechanism.StorageId); Assert.AreEqual(isRelevant, failureMechanism.IsRelevant); Assert.AreEqual(entity.Comments, failureMechanism.Comments); Assert.IsEmpty(failureMechanism.Sections); } [Test] public void ReadAsStandAloneFailureMechanism_WithSectionsSet_ReturnsNewStandAloneFailureMechanismWithFailureMechanismSections() { // Setup var entityId = new Random(21).Next(1, 502); var entity = new FailureMechanismEntity { FailureMechanismEntityId = entityId, FailureMechanismSectionEntities = { new FailureMechanismSectionEntity { Name = "section", FailureMechanismSectionPointEntities = { new FailureMechanismSectionPointEntity() } } } }; var collector = new ReadConversionCollector(); var failureMechanism = new TestFailureMechanism(); // Call entity.ReadCommonFailureMechanismProperties(failureMechanism, collector); // Assert Assert.AreEqual(1, failureMechanism.Sections.Count()); } } }