// 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());
}
}
}