// 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 Core.Common.Base.Geometry; using NUnit.Framework; using Ringtoets.Common.Data.FailureMechanism; using Ringtoets.Common.Data.Probability; using Ringtoets.Common.Data.TestUtil; using Ringtoets.Common.Data.TestUtil.Probability; using Ringtoets.Common.Forms.Views; namespace Ringtoets.Common.Forms.Test.Views { [TestFixture] public class FailureMechanismSectionProbabilityAssessmentRowTest { [Test] public void Constructor_ProbabilityAssessmentInputNull_ThrowsArgumentNullException() { // Setup FailureMechanismSection section = GetTestFailureMechanismSection(); // Call TestDelegate test = () => new FailureMechanismSectionProbabilityAssessmentRow(section, null); // Assert string paramName = Assert.Throws(test).ParamName; Assert.AreEqual("probabilityAssessmentInput", paramName); } [Test] public void Constructor_ValidParameters_ExpectedValues() { // Setup var random = new Random(39); FailureMechanismSection section = GetTestFailureMechanismSection(); var probabilityAssessmentInput = new TestProbabilityAssessmentInput(random.NextDouble(), random.NextDouble()); // Call var sectionRow = new FailureMechanismSectionProbabilityAssessmentRow(section, probabilityAssessmentInput); // Assert Assert.IsInstanceOf(sectionRow); Assert.AreEqual(section.Name, sectionRow.Name); Assert.AreEqual(2, sectionRow.Length.NumberOfDecimalPlaces); Assert.AreEqual(section.Length, sectionRow.Length, sectionRow.Length.GetAccuracy()); Assert.AreEqual(2, sectionRow.N.NumberOfDecimalPlaces); AssertLengthEffect(probabilityAssessmentInput, section, sectionRow); } [Test] public void GivenRow_WhenProbabilityAssessmentInputChanged_ThenNChangedAccordingly() { // Given var random = new Random(39); FailureMechanismSection section = GetTestFailureMechanismSection(); var probabilityAssessmentInput = new TestProbabilityAssessmentInput(random.NextDouble(), random.NextDouble()); var sectionRow = new FailureMechanismSectionProbabilityAssessmentRow(section, probabilityAssessmentInput); // Precondition AssertLengthEffect(probabilityAssessmentInput, section, sectionRow); // When probabilityAssessmentInput.A = random.NextDouble(); // Then AssertLengthEffect(probabilityAssessmentInput, section, sectionRow); } private static FailureMechanismSection GetTestFailureMechanismSection() { var random = new Random(); return new FailureMechanismSection("test", new[] { new Point2D(random.NextDouble(), random.NextDouble()), new Point2D(random.NextDouble(), random.NextDouble()) }); } private static void AssertLengthEffect(ProbabilityAssessmentInput probabilityAssessmentInput, FailureMechanismSection section, FailureMechanismSectionProbabilityAssessmentRow sectionRow) { Assert.AreEqual(probabilityAssessmentInput.GetN(section.Length), sectionRow.N, sectionRow.N.GetAccuracy()); } } }