// 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.ComponentModel; using Core.Common.Gui.PropertyBag; using Core.Common.TestUtil; using Core.Common.Utils; using NUnit.Framework; using Ringtoets.Common.Data.Hydraulics; using Ringtoets.Common.Data.TestUtil; using Ringtoets.Common.Forms.Helpers; using Ringtoets.Revetment.Data; using Ringtoets.Revetment.Forms.PropertyClasses; namespace Ringtoets.Revetment.Forms.Test.PropertyClasses { [TestFixture] public class WaveConditionsOutputPropertiesTest { private const int requiredWaterLevelPropertyIndex = 0; private const int requiredWaveHeightPropertyIndex = 1; private const int requiredWavePeakPeriodPropertyIndex = 2; private const int requiredWaveDirectionPropertyIndex = 3; private const int requiredWaveAnglePropertyIndex = 4; private const int requiredTargetProbabilityPropertyIndex = 5; private const int requiredTargetReliabilityPropertyIndex = 6; private const int requiredCalculatedProbabilityPropertyIndex = 7; private const int requiredCalculatedReliabilityPropertyIndex = 8; private const int requiredConvergencePropertyIndex = 9; [Test] public void GetProperties_ValidData_ReturnsExpectedValues() { // Setup const double waterLevel = 3.09378; const double waveHeight = 4.29884; const double wavePeakPeriod = 0.19435; const double waveAngle = 180.62353; const double waveDirection = 230.5326; const double targetProbability = 0.5; const double targetReliability = 3000; const double calculatedProbability = 0.4; const double calculatedReliability = 6000; const CalculationConvergence convergence = CalculationConvergence.NotCalculated; // Call var properties = new WaveConditionsOutputProperties { Data = new WaveConditionsOutput(waterLevel, waveHeight, wavePeakPeriod, waveAngle, waveDirection, targetProbability, targetReliability, calculatedProbability, calculatedReliability, convergence) }; // Assert Assert.AreEqual(waterLevel, properties.WaterLevel, properties.WaterLevel.GetAccuracy()); Assert.AreEqual(waveHeight, properties.WaveHeight, properties.WaveHeight.GetAccuracy()); Assert.AreEqual(wavePeakPeriod, properties.WavePeakPeriod, properties.WavePeakPeriod.GetAccuracy()); Assert.AreEqual(waveAngle, properties.WaveAngle, properties.WaveAngle.GetAccuracy()); Assert.AreEqual(waveDirection, properties.WaveDirection, properties.WaveDirection.GetAccuracy()); Assert.AreEqual(ProbabilityFormattingHelper.Format(targetProbability), properties.TargetProbability); Assert.AreEqual(targetReliability, properties.TargetReliability, properties.TargetReliability.GetAccuracy()); Assert.AreEqual(ProbabilityFormattingHelper.Format(calculatedProbability), properties.CalculatedProbability); Assert.AreEqual(calculatedReliability, properties.CalculatedReliability, properties.CalculatedReliability.GetAccuracy()); string convergenceValue = new EnumDisplayWrapper(convergence).DisplayName; Assert.AreEqual(convergenceValue, properties.Convergence); } [Test] public void Constructor_Always_PropertiesHaveExpectedAttributesValues() { // Setup const double waterLevel = 3.09378; const double waveHeight = 4.29884; const double wavePeakPeriod = 0.19435; const double waveAngle = 180.62353; const double waveDirection = 230.5326; const double targetProbability = 0.5; const double targetReliability = 3000; const double calculatedProbability = 0.4; const double calculatedReliability = 6000; // Call var properties = new WaveConditionsOutputProperties { Data = new WaveConditionsOutput(waterLevel, waveHeight, wavePeakPeriod, waveAngle, waveDirection, targetProbability, targetReliability, calculatedProbability, calculatedReliability, CalculationConvergence.NotCalculated) }; // Assert TypeConverter classTypeConverter = TypeDescriptor.GetConverter(properties, true); var propertyBag = new DynamicPropertyBag(properties); PropertyDescriptorCollection dynamicProperties = propertyBag.GetProperties(new Attribute[] { new BrowsableAttribute(true) }); Assert.AreEqual(10, dynamicProperties.Count); Assert.IsInstanceOf(classTypeConverter); PropertyDescriptor waterLevelProperty = dynamicProperties[requiredWaterLevelPropertyIndex]; PropertiesTestHelper.AssertRequiredPropertyDescriptorProperties(waterLevelProperty, "Algemeen", "Waterstand [m+NAP]", "De waterstand waarvoor de golfhoogte, -periode en -richting zijn berekend.", true); PropertyDescriptor waveHeightProperty = dynamicProperties[requiredWaveHeightPropertyIndex]; PropertiesTestHelper.AssertRequiredPropertyDescriptorProperties(waveHeightProperty, "Algemeen", "Golfhoogte (Hs) [m]", "Berekende golfhoogte.", true); PropertyDescriptor wavePeakPeriodProperty = dynamicProperties[requiredWavePeakPeriodPropertyIndex]; PropertiesTestHelper.AssertRequiredPropertyDescriptorProperties(wavePeakPeriodProperty, "Algemeen", "Golfperiode (Tp) [s]", "Berekende golfperiode.", true); PropertyDescriptor waveDirectionProperty = dynamicProperties[requiredWaveDirectionPropertyIndex]; PropertiesTestHelper.AssertRequiredPropertyDescriptorProperties(waveDirectionProperty, "Algemeen", "Golfrichting t.o.v. Noord [°]", "Berekende maatgevende golfrichting ten opzichte van het noorden.", true); PropertyDescriptor waveAngleProperty = dynamicProperties[requiredWaveAnglePropertyIndex]; PropertiesTestHelper.AssertRequiredPropertyDescriptorProperties(waveAngleProperty, "Algemeen", "Golfrichting t.o.v. dijknormaal [°]", "Berekende maatgevende golfrichting ten opzichte van de dijknormaal.", true); PropertyDescriptor targetProbabilityProperty = dynamicProperties[requiredTargetProbabilityPropertyIndex]; PropertiesTestHelper.AssertRequiredPropertyDescriptorProperties(targetProbabilityProperty, "Algemeen", "Doelkans [1/jaar]", "De opgegeven kans waarvoor het resultaat is berekend.", true); PropertyDescriptor targetReliabilityProperty = dynamicProperties[requiredTargetReliabilityPropertyIndex]; PropertiesTestHelper.AssertRequiredPropertyDescriptorProperties(targetReliabilityProperty, "Algemeen", "Betrouwbaarheidsindex doelkans [-]", "Betrouwbaarheidsindex van de opgegeven kans waarvoor het resultaat is berekend.", true); PropertyDescriptor calculatedProbabilityProperty = dynamicProperties[requiredCalculatedProbabilityPropertyIndex]; PropertiesTestHelper.AssertRequiredPropertyDescriptorProperties(calculatedProbabilityProperty, "Algemeen", "Berekende kans [1/jaar]", "De berekende kans van voorkomen van het resultaat.", true); PropertyDescriptor calculatedReliabilityProperty = dynamicProperties[requiredCalculatedReliabilityPropertyIndex]; PropertiesTestHelper.AssertRequiredPropertyDescriptorProperties(calculatedReliabilityProperty, "Algemeen", "Betrouwbaarheidsindex berekende kans [-]", "Betrouwbaarheidsindex van de berekende kans van voorkomen van het resultaat.", true); PropertyDescriptor calculationConvergenceProperty = dynamicProperties[requiredConvergencePropertyIndex]; PropertiesTestHelper.AssertRequiredPropertyDescriptorProperties(calculationConvergenceProperty, "Algemeen", "Convergentie", "Is convergentie bereikt voor de berekening?", true); } } }