// 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.Drawing; using System.Linq; using Core.Common.Controls.Views; using Core.Common.Gui.Plugin; using Core.Common.TestUtil; using Core.Components.Chart.Data; using NUnit.Framework; using Ringtoets.Common.Data.Calculation; using Ringtoets.Common.Data.FailureMechanism; using Ringtoets.Common.Data.Hydraulics; using Ringtoets.Common.Data.TestUtil; using Ringtoets.Common.Forms.PresentationObjects; using Ringtoets.Common.Plugin.TestUtil; using Ringtoets.GrassCoverErosionOutwards.Data; using Ringtoets.GrassCoverErosionOutwards.Data.TestUtil; using Ringtoets.GrassCoverErosionOutwards.Forms.PresentationObjects; using Ringtoets.GrassCoverErosionOutwards.Forms.Views; using Ringtoets.Revetment.Data; using Ringtoets.Revetment.Forms.Views; using RingtoetsCommonFormsResources = Ringtoets.Common.Forms.Properties.Resources; namespace Ringtoets.GrassCoverErosionOutwards.Plugin.Test.ViewInfos { [TestFixture] public class GrassCoverErosionOutwardsWaveConditionsInputViewInfoTest : ShouldCloseViewWithCalculationDataTester { private const int lowerBoundaryRevetmentChartDataIndex = 1; private const int upperBoundaryRevetmentChartDataIndex = 2; private const int designWaterLevelChartDataIndex = 5; private const int revetmentBaseChartDataIndex = 7; private const int revetmentChartDataIndex = 8; private ViewInfo info; private GrassCoverErosionOutwardsPlugin plugin; [SetUp] public void SetUp() { plugin = new GrassCoverErosionOutwardsPlugin(); info = plugin.GetViewInfos().First(tni => tni.ViewType == typeof(WaveConditionsInputView)); } [TearDown] public void TearDown() { plugin.Dispose(); } [Test] public void Initialized_Always_ExpectedPropertiesSet() { // Assert Assert.AreEqual(typeof(GrassCoverErosionOutwardsWaveConditionsInputContext), info.DataType); Assert.AreEqual(typeof(ICalculation), info.ViewDataType); TestHelper.AssertImagesAreEqual(RingtoetsCommonFormsResources.GenericInputOutputIcon, info.Image); } [Test] public void GetViewName_Always_ReturnsInputResourceName() { // Call string viewName = info.GetViewName(null, null); // Assert Assert.AreEqual("Invoer", viewName); } [Test] public void CreateInstance_GrassCoverErosionOutwardsWaveConditionsInputContext_ReturnViewWithStylingApplied() { // Setup var random = new Random(21); var calculation = new GrassCoverErosionOutwardsWaveConditionsCalculation { InputParameters = { CategoryType = random.NextEnumValue() } }; var context = new GrassCoverErosionOutwardsWaveConditionsInputContext( new FailureMechanismCategoryWaveConditionsInput(), calculation, new AssessmentSectionStub(), new GrassCoverErosionOutwardsFailureMechanism()); // Call var view = (WaveConditionsInputView) info.CreateInstance(context); // Assert ChartDataCollection chartData = view.Chart.Data; var lowerBoundaryRevetmentChartData = (ChartLineData) chartData.Collection.ElementAt(lowerBoundaryRevetmentChartDataIndex); var upperBoundaryRevetmentChartData = (ChartLineData) chartData.Collection.ElementAt(upperBoundaryRevetmentChartDataIndex); var revetmentBaseChartData = (ChartLineData) chartData.Collection.ElementAt(revetmentBaseChartDataIndex); var revetmentChartData = (ChartLineData) chartData.Collection.ElementAt(revetmentChartDataIndex); Color revetmentLineColor = Color.Green; Assert.AreEqual(revetmentLineColor, lowerBoundaryRevetmentChartData.Style.Color); Assert.AreEqual(revetmentLineColor, upperBoundaryRevetmentChartData.Style.Color); Assert.AreEqual(Color.FromArgb(120, revetmentLineColor), revetmentBaseChartData.Style.Color); Assert.AreEqual(revetmentLineColor, revetmentChartData.Style.Color); } [Test] [TestCaseSource( typeof(GrassCoverErosionOutwardsAssessmentSectionTestHelper), nameof(GrassCoverErosionOutwardsAssessmentSectionTestHelper.GetHydraulicBoundaryLocationCalculationConfigurationPerFailureMechanismCategoryType))] public void CreateInstance_GrassCoverErosionOutwardsWaveConditionsInputContext_ReturnViewWithCorrespondingAssessmentLevel( AssessmentSectionStub assessmentSection, GrassCoverErosionOutwardsFailureMechanism failureMechanism, HydraulicBoundaryLocation hydraulicBoundaryLocation, FailureMechanismCategoryType categoryType, HydraulicBoundaryLocationCalculation expectedHydraulicBoundaryLocationCalculation) { var calculation = new GrassCoverErosionOutwardsWaveConditionsCalculation { InputParameters = { HydraulicBoundaryLocation = hydraulicBoundaryLocation, CategoryType = categoryType } }; var context = new GrassCoverErosionOutwardsWaveConditionsInputContext( calculation.InputParameters, calculation, assessmentSection, failureMechanism); // Call var view = (WaveConditionsInputView) info.CreateInstance(context); // Assert ChartDataCollection chartData = view.Chart.Data; var designWaterLevelChartData = (ChartLineData) chartData.Collection.ElementAt(designWaterLevelChartDataIndex); Assert.AreEqual(expectedHydraulicBoundaryLocationCalculation.Output.Result, designWaterLevelChartData.Points.First().Y); } #region ShouldCloseViewWithCalculationDataTester protected override bool ShouldCloseMethod(IView view, object o) { return info.CloseForData(view, o); } protected override IView GetView(ICalculation data) { return new WaveConditionsInputView((ICalculation) data, () => new HydraulicBoundaryLocationCalculation(new TestHydraulicBoundaryLocation()), new GrassCoverErosionOutwardsWaveConditionsInputViewStyle()); } protected override ICalculation GetCalculation() { return new GrassCoverErosionOutwardsWaveConditionsCalculation(); } protected override ICalculationContext GetCalculationContextWithCalculation() { return new GrassCoverErosionOutwardsWaveConditionsCalculationContext( new GrassCoverErosionOutwardsWaveConditionsCalculation(), new CalculationGroup(), new GrassCoverErosionOutwardsFailureMechanism(), new AssessmentSectionStub()); } protected override ICalculationContext GetCalculationGroupContextWithCalculation() { return new GrassCoverErosionOutwardsWaveConditionsCalculationGroupContext( new CalculationGroup { Children = { new GrassCoverErosionOutwardsWaveConditionsCalculation() } }, null, new GrassCoverErosionOutwardsFailureMechanism(), new AssessmentSectionStub()); } protected override IFailureMechanismContext GetFailureMechanismContextWithCalculation() { return new GrassCoverErosionOutwardsFailureMechanismContext( new GrassCoverErosionOutwardsFailureMechanism { WaveConditionsCalculationGroup = { Children = { new GrassCoverErosionOutwardsWaveConditionsCalculation() } } }, new AssessmentSectionStub()); } #endregion } }