// 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.ComponentModel; using System.Globalization; using System.Linq; using Core.Common.Base; using Core.Common.Gui.Commands; using Core.Common.Gui.PropertyBag; using Core.Common.TestUtil; using Core.Common.Utils; using NUnit.Extensions.Forms; using NUnit.Framework; using Rhino.Mocks; using Ringtoets.Common.Data.AssessmentSection; using Ringtoets.Common.Data.Contribution; using Ringtoets.Common.Data.FailureMechanism; using Ringtoets.Common.Forms.Helpers; using Ringtoets.Common.Forms.PropertyClasses; using Ringtoets.Common.Forms.TestUtil; using Ringtoets.Integration.Data; using Ringtoets.Integration.Forms.PropertyClasses; using Ringtoets.Integration.Plugin.Handlers; namespace Ringtoets.Integration.Forms.Test.PropertyClasses { [TestFixture] public class FailureMechanismContributionPropertiesTest : NUnitFormTest { [Test] public void Constructor_FailureMechanismContributionNull_ThrowsArgumentNullException() { // Setup var mockRepository = new MockRepository(); var assessmentSection = mockRepository.Stub(); var failureMechanismChangeHandler = mockRepository.Stub(); var assessmentSectionChangeHandler = mockRepository.Stub(); mockRepository.ReplayAll(); // Call TestDelegate test = () => new FailureMechanismContributionProperties( null, assessmentSection, failureMechanismChangeHandler, assessmentSectionChangeHandler); // Assert string paramName = Assert.Throws(test).ParamName; Assert.AreEqual("failureMechanismContribution", paramName); mockRepository.VerifyAll(); } [Test] public void Constructor_AssessmentSectionNull_ThrowsArgumentNullException() { // Setup var mockRepository = new MockRepository(); var failureMechanismChangeHandler = mockRepository.Stub(); var assessmentSectionChangeHandler = mockRepository.Stub(); mockRepository.ReplayAll(); FailureMechanismContribution failureMechanismContribution = CreateFailureMechanismContribution(); // Call TestDelegate test = () => new FailureMechanismContributionProperties( failureMechanismContribution, null, failureMechanismChangeHandler, assessmentSectionChangeHandler); // Assert string paramName = Assert.Throws(test).ParamName; Assert.AreEqual("assessmentSection", paramName); mockRepository.VerifyAll(); } [Test] public void Constructor_FailureMechanismContributionNormChangeHandlerNull_ThrowsArgumentNullException() { // Setup var mockRepository = new MockRepository(); var assessmentSection = mockRepository.Stub(); var assessmentSectionChangeHandler = mockRepository.Stub(); mockRepository.ReplayAll(); FailureMechanismContribution failureMechanismContribution = CreateFailureMechanismContribution(); // Call TestDelegate test = () => new FailureMechanismContributionProperties( failureMechanismContribution, assessmentSection, null, assessmentSectionChangeHandler); // Assert string paramName = Assert.Throws(test).ParamName; Assert.AreEqual("normChangeHandler", paramName); mockRepository.VerifyAll(); } [Test] public void Constructor_AssessmentSectionCompositionChangeHandlerNull_ThrowsArgumentNullException() { // Setup var mockRepository = new MockRepository(); var assessmentSection = mockRepository.Stub(); var failureMechanismChangeHandler = mockRepository.Stub(); mockRepository.ReplayAll(); FailureMechanismContribution failureMechanismContribution = CreateFailureMechanismContribution(); // Call TestDelegate test = () => new FailureMechanismContributionProperties( failureMechanismContribution, assessmentSection, failureMechanismChangeHandler, null); // Assert string paramName = Assert.Throws(test).ParamName; Assert.AreEqual("compositionChangeHandler", paramName); mockRepository.VerifyAll(); } [Test] public void Constructor_WithValidParameters_DataSet() { // Setup var mockRepository = new MockRepository(); var assessmentSection = mockRepository.Stub(); var failureMechanismChangeHandler = mockRepository.Stub(); var assessmentSectionChangeHandler = mockRepository.Stub(); mockRepository.ReplayAll(); FailureMechanismContribution failureMechanismContribution = CreateFailureMechanismContribution(); // Call var properties = new FailureMechanismContributionProperties( failureMechanismContribution, assessmentSection, failureMechanismChangeHandler, assessmentSectionChangeHandler); // Assert Assert.IsInstanceOf>(properties); Assert.AreSame(failureMechanismContribution, properties.Data); PropertyDescriptorCollection dynamicProperties = PropertiesTestHelper.GetAllVisiblePropertyDescriptors(properties); Assert.AreEqual(4, dynamicProperties.Count); const string expectedCategory = "Algemeen"; PropertyDescriptor compositionProperty = dynamicProperties[0]; PropertiesTestHelper.AssertRequiredPropertyDescriptorProperties(compositionProperty, expectedCategory, "Trajecttype", "Selecteer het type traject, bepalend voor de faalkansbegroting."); PropertyDescriptor signalingNormProperty = dynamicProperties[1]; PropertiesTestHelper.AssertRequiredPropertyDescriptorProperties(signalingNormProperty, expectedCategory, "Signaleringswaarde [1/jaar]", "Overstromingskans van het dijktraject waarvan overschrijding gemeld moet worden aan de Minister van I en M."); PropertyDescriptor lowerLevelNormProperty = dynamicProperties[2]; PropertiesTestHelper.AssertRequiredPropertyDescriptorProperties(lowerLevelNormProperty, expectedCategory, "Ondergrens [1/jaar]", "Overstromingskans van het dijktraject die hoort bij het minimale beschermingsniveau dat de kering moet bieden."); PropertyDescriptor normativeNormProperty = dynamicProperties[3]; Assert.IsInstanceOf(normativeNormProperty.Converter); PropertiesTestHelper.AssertRequiredPropertyDescriptorProperties(normativeNormProperty, expectedCategory, "Norm van het dijktraject", "De kans die wordt gebruikt als de norm van het dijktraject."); } [Test] public void GetProperties_WithData_ReturnExpectedValues() { // Setup var mocks = new MockRepository(); const AssessmentSectionComposition assessmentSectionComposition = AssessmentSectionComposition.DikeAndDune; var assessmentSection = mocks.Stub(); assessmentSection.Stub(section => section.Composition).Return(assessmentSectionComposition); var failureMechanismChangeHandler = mocks.Stub(); var assessmentSectionChangeHandler = mocks.Stub(); mocks.ReplayAll(); var contribution = new FailureMechanismContribution(Enumerable.Empty(), 1.1); // Call var properties = new FailureMechanismContributionProperties( contribution, assessmentSection, failureMechanismChangeHandler, assessmentSectionChangeHandler); // Assert string expectedLowerLimitNorm = ProbabilityFormattingHelper.Format(contribution.LowerLimitNorm); string expectedSignalingNorm = ProbabilityFormattingHelper.Format(contribution.SignalingNorm); Assert.AreEqual(assessmentSectionComposition, properties.AssessmentSectionComposition); Assert.AreEqual(expectedLowerLimitNorm, properties.LowerLimitNorm); Assert.AreEqual(expectedSignalingNorm, properties.SignalingNorm); Assert.AreEqual(contribution.NormativeNorm, properties.NormativeNorm); mocks.VerifyAll(); } [Test] [SetCulture("nl-NL")] [TestCase("0,1")] [TestCase("1/100")] [TestCase("1e-2")] public void LowerLimitNorm_Always_ContributionNotifiedAndPropertyChangedCalled(string norm) { SetPropertyAndVerifyNotifcationsAndOutputForCalculation(properties => properties.LowerLimitNorm = norm); } [Test] [TestCase(double.MinValue)] [TestCase(double.MaxValue)] public void LowerLimitNorm_InvalidValues_ThrowsArgumentException(double newValue) { // Setup const int overflow = 1; string newProbabilityString = string.Concat(newValue.ToString("r", CultureInfo.CurrentCulture), overflow); // Call TestDelegate call = () => SetPropertyAndVerifyNotifcationsAndOutputForCalculation(properties => properties.LowerLimitNorm = newProbabilityString); // Assert const string expectedMessage = "De waarde is te groot of te klein."; TestHelper.AssertThrowsArgumentExceptionAndTestMessage(call, expectedMessage); } [Test] [TestCase("no double value")] [TestCase("")] [TestCase("1/aaa")] public void LowerLimitNorm_ValuesUnableToParse_ThrowsArgumentException(string newValue) { // Call TestDelegate call = () => SetPropertyAndVerifyNotifcationsAndOutputForCalculation(properties => properties.LowerLimitNorm = newValue); // Assert const string expectedMessage = "De waarde kon niet geïnterpreteerd worden als een kans."; TestHelper.AssertThrowsArgumentExceptionAndTestMessage(call, expectedMessage); } [Test] public void LowerLimitNorm_NullValue_ThrowsArgumentNullException() { // Call TestDelegate call = () => SetPropertyAndVerifyNotifcationsAndOutputForCalculation(properties => properties.LowerLimitNorm = null); // Assert const string expectedMessage = "De waarde voor de faalkans moet ingevuld zijn."; TestHelper.AssertThrowsArgumentExceptionAndTestMessage(call, expectedMessage); } [Test] [TestCase(double.MinValue)] [TestCase(double.MaxValue)] public void SignalingNorm_InvalidValues_ThrowsArgumentException(double newValue) { // Setup const int overflow = 1; string newProbabilityString = string.Concat(newValue.ToString("r", CultureInfo.CurrentCulture), overflow); // Call TestDelegate call = () => SetPropertyAndVerifyNotifcationsAndOutputForCalculation(properties => properties.SignalingNorm = newProbabilityString); // Assert const string expectedMessage = "De waarde is te groot of te klein."; TestHelper.AssertThrowsArgumentExceptionAndTestMessage(call, expectedMessage); } [Test] [TestCase("no double value")] [TestCase("")] [TestCase("1/aaa")] public void SignalingNorm_ValuesUnableToParse_ThrowsArgumentException(string newValue) { // Call TestDelegate call = () => SetPropertyAndVerifyNotifcationsAndOutputForCalculation(properties => properties.SignalingNorm = newValue); // Assert const string expectedMessage = "De waarde kon niet geïnterpreteerd worden als een kans."; TestHelper.AssertThrowsArgumentExceptionAndTestMessage(call, expectedMessage); } [Test] public void SignalingNorm_NullValue_ThrowsArgumentNullException() { // Call TestDelegate call = () => SetPropertyAndVerifyNotifcationsAndOutputForCalculation(properties => properties.SignalingNorm = null); // Assert const string expectedMessage = "De waarde voor de faalkans moet ingevuld zijn."; TestHelper.AssertThrowsArgumentExceptionAndTestMessage(call, expectedMessage); } [Test] [SetCulture("nl-NL")] [TestCase("0,00001")] [TestCase("1/30000")] [TestCase("1e-5")] public void SignalingNorm_Always_ContributionNotifiedAndPropertyChangedCalled(string norm) { SetPropertyAndVerifyNotifcationsAndOutputForCalculation(properties => properties.SignalingNorm = norm); } [Test] public void NormativeNorm_Always_ContributionNotifiedAndPropertyChangedCalled() { SetPropertyAndVerifyNotifcationsAndOutputForCalculation(properties => properties.NormativeNorm = NormType.Signaling); } [Test] public void GivenAssessmentSectionComposition_WhenConfirmingCompositionValueChange_ThenAssessmentSectionCompositionSetAndNotifiesObserver() { // Given const AssessmentSectionComposition originalComposition = AssessmentSectionComposition.Dike; var assessmentSection = new AssessmentSection(originalComposition); FailureMechanismContribution failureMechanismContribution = assessmentSection.FailureMechanismContribution; var mocks = new MockRepository(); var normChangeHandler = mocks.Stub(); var observer = mocks.StrictMock(); failureMechanismContribution.Attach(observer); observer.Expect(o => o.UpdateObserver()); var viewCommands = mocks.Stub(); mocks.ReplayAll(); var compositionChangeHandler = new AssessmentSectionCompositionChangeHandler(viewCommands); var properties = new FailureMechanismContributionProperties( failureMechanismContribution, assessmentSection, normChangeHandler, compositionChangeHandler); DialogBoxHandler = (name, wnd) => { var messageBox = new MessageBoxTester(wnd); messageBox.ClickOk(); }; // When const AssessmentSectionComposition newComposition = AssessmentSectionComposition.DikeAndDune; properties.AssessmentSectionComposition = newComposition; // Then Assert.AreEqual(newComposition, properties.AssessmentSectionComposition); Assert.AreEqual(newComposition, assessmentSection.Composition); mocks.VerifyAll(); } [Test] public void GivenAssessmentSectionComposition_WhenCancelingCompositionValueChange__ThenDataSameObserversNotNotified() { // Given const AssessmentSectionComposition originalComposition = AssessmentSectionComposition.Dike; var assessmentSection = new AssessmentSection(originalComposition); FailureMechanismContribution failureMechanismContribution = assessmentSection.FailureMechanismContribution; var mocks = new MockRepository(); var normChangeHandler = mocks.Stub(); var observer = mocks.StrictMock(); failureMechanismContribution.Attach(observer); var viewCommands = mocks.Stub(); mocks.ReplayAll(); var compositionChangeHandler = new AssessmentSectionCompositionChangeHandler(viewCommands); var properties = new FailureMechanismContributionProperties( failureMechanismContribution, assessmentSection, normChangeHandler, compositionChangeHandler); DialogBoxHandler = (name, wnd) => { var messageBox = new MessageBoxTester(wnd); messageBox.ClickCancel(); }; // When const AssessmentSectionComposition newComposition = AssessmentSectionComposition.DikeAndDune; properties.AssessmentSectionComposition = newComposition; // Then Assert.AreEqual(originalComposition, properties.AssessmentSectionComposition); Assert.AreEqual(originalComposition, assessmentSection.Composition); mocks.VerifyAll(); } [Test] [TestCase(AssessmentSectionComposition.Dike, AssessmentSectionComposition.Dune)] [TestCase(AssessmentSectionComposition.Dike, AssessmentSectionComposition.DikeAndDune)] [TestCase(AssessmentSectionComposition.Dune, AssessmentSectionComposition.Dike)] [TestCase(AssessmentSectionComposition.Dune, AssessmentSectionComposition.DikeAndDune)] [TestCase(AssessmentSectionComposition.DikeAndDune, AssessmentSectionComposition.Dike)] [TestCase(AssessmentSectionComposition.DikeAndDune, AssessmentSectionComposition.Dune)] public void AssessmentSectionComposition_CompositionValueChanges_NotifiesChangedObjectsInAssessmentSection( AssessmentSectionComposition initialComposition, AssessmentSectionComposition newComposition) { // Setup var assessmentSection = new AssessmentSection(initialComposition); var mocks = new MockRepository(); var observable1 = mocks.StrictMock(); observable1.Expect(o => o.NotifyObservers()); var observable2 = mocks.StrictMock(); observable2.Expect(o => o.NotifyObservers()); var compositionChangeHandler = mocks.StrictMock(); compositionChangeHandler.Expect(h => h.ConfirmCompositionChange()) .Return(true); compositionChangeHandler.Expect(h => h.ChangeComposition(assessmentSection, newComposition)) .Return(new[] { observable1, observable2 }); mocks.ReplayAll(); var properties = new FailureMechanismContributionProperties( assessmentSection.FailureMechanismContribution, assessmentSection, new FailureMechanismContributionNormChangeHandler(assessmentSection), compositionChangeHandler); // Call properties.AssessmentSectionComposition = newComposition; // Assert mocks.VerifyAll(); } private static void SetPropertyAndVerifyNotifcationsAndOutputForCalculation(Action setProperty) { // Setup var assessmentSection = new AssessmentSection(AssessmentSectionComposition.Dike); FailureMechanismContribution failureMechanismContribution = assessmentSection.FailureMechanismContribution; var mocks = new MockRepository(); var compositionChangeHandler = mocks.Stub(); var observable = mocks.StrictMock(); observable.Expect(o => o.NotifyObservers()); mocks.ReplayAll(); var handler = new SetPropertyValueAfterConfirmationParameterTester(new[] { observable }); var properties = new FailureMechanismContributionProperties( failureMechanismContribution, assessmentSection, handler, compositionChangeHandler); // Call setProperty(properties); // Assert Assert.IsTrue(handler.Called); mocks.VerifyAll(); } private static FailureMechanismContribution CreateFailureMechanismContribution() { return new FailureMechanismContribution(Enumerable.Empty(), new Random(21).Next(0, 100)); } } }