// 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.Collections.Generic; using Core.Common.Base; using Ringtoets.Common.Data.AssessmentSection; using Ringtoets.Common.Data.Contribution; using Ringtoets.Common.Data.FailureMechanism; using Ringtoets.Common.Data.Hydraulics; namespace Ringtoets.Common.Data.TestUtil { /// /// This class is a stub implementation of . /// public class AssessmentSectionStub : Observable, IAssessmentSection { private static readonly Random random = new Random(21); private readonly IEnumerable failureMechanisms; private readonly ObservableList waterLevelCalculationsForFactorizedSignalingNorm; private readonly ObservableList waterLevelCalculationsForSignalingNorm; private readonly ObservableList waterLevelCalculationsForLowerLimitNorm; private readonly ObservableList waterLevelCalculationsForFactorizedLowerLimitNorm; private readonly ObservableList waveHeightCalculationsForFactorizedSignalingNorm; private readonly ObservableList waveHeightCalculationsForSignalingNorm; private readonly ObservableList waveHeightCalculationsForLowerLimitNorm; private readonly ObservableList waveHeightCalculationsForFactorizedLowerLimitNorm; public AssessmentSectionStub() : this(new IFailureMechanism[0]) {} public AssessmentSectionStub(IEnumerable failureMechanisms) { this.failureMechanisms = failureMechanisms; FailureMechanismContribution = new FailureMechanismContribution(1.0 / 30000, 1.0 / 30000); BackgroundData = new BackgroundData(new WmtsBackgroundDataConfiguration()) { Name = "Background data" }; HydraulicBoundaryDatabase = new HydraulicBoundaryDatabase(); waterLevelCalculationsForFactorizedSignalingNorm = new ObservableList(); waterLevelCalculationsForSignalingNorm = new ObservableList(); waterLevelCalculationsForLowerLimitNorm = new ObservableList(); waterLevelCalculationsForFactorizedLowerLimitNorm = new ObservableList(); waveHeightCalculationsForFactorizedSignalingNorm = new ObservableList(); waveHeightCalculationsForSignalingNorm = new ObservableList(); waveHeightCalculationsForLowerLimitNorm = new ObservableList(); waveHeightCalculationsForFactorizedLowerLimitNorm = new ObservableList(); } public string Id { get; } public string Name { get; set; } public Comment Comments { get; } public AssessmentSectionComposition Composition { get; } public ReferenceLine ReferenceLine { get; set; } public FailureMechanismContribution FailureMechanismContribution { get; } public HydraulicBoundaryDatabase HydraulicBoundaryDatabase { get; } public BackgroundData BackgroundData { get; set; } public IObservableEnumerable WaterLevelCalculationsForFactorizedSignalingNorm { get { return waterLevelCalculationsForFactorizedSignalingNorm; } } public IObservableEnumerable WaterLevelCalculationsForSignalingNorm { get { return waterLevelCalculationsForSignalingNorm; } } public IObservableEnumerable WaterLevelCalculationsForLowerLimitNorm { get { return waterLevelCalculationsForLowerLimitNorm; } } public IObservableEnumerable WaterLevelCalculationsForFactorizedLowerLimitNorm { get { return waterLevelCalculationsForFactorizedLowerLimitNorm; } } public IObservableEnumerable WaveHeightCalculationsForFactorizedSignalingNorm { get { return waveHeightCalculationsForFactorizedSignalingNorm; } } public IObservableEnumerable WaveHeightCalculationsForSignalingNorm { get { return waveHeightCalculationsForSignalingNorm; } } public IObservableEnumerable WaveHeightCalculationsForLowerLimitNorm { get { return waveHeightCalculationsForLowerLimitNorm; } } public IObservableEnumerable WaveHeightCalculationsForFactorizedLowerLimitNorm { get { return waveHeightCalculationsForFactorizedLowerLimitNorm; } } /// /// Sets the hydraulic boundary locations on the assessment section stub. /// /// The hydraulic boundary locations to set. /// Whether to set dummy output for the automatically generated /// hydraulic boundary location calculations. public void SetHydraulicBoundaryLocationCalculations(IEnumerable hydraulicBoundaryLocations, bool setCalculationOutput = false) { HydraulicBoundaryDatabase.Locations.Clear(); waterLevelCalculationsForFactorizedSignalingNorm.Clear(); waterLevelCalculationsForSignalingNorm.Clear(); waterLevelCalculationsForLowerLimitNorm.Clear(); waterLevelCalculationsForFactorizedLowerLimitNorm.Clear(); waveHeightCalculationsForFactorizedSignalingNorm.Clear(); waveHeightCalculationsForSignalingNorm.Clear(); waveHeightCalculationsForLowerLimitNorm.Clear(); waveHeightCalculationsForFactorizedLowerLimitNorm.Clear(); foreach (HydraulicBoundaryLocation hydraulicBoundaryLocation in hydraulicBoundaryLocations) { AddHydraulicBoundaryLocation(hydraulicBoundaryLocation, setCalculationOutput); } } public IEnumerable GetFailureMechanisms() { yield break; } public IEnumerable GetContributingFailureMechanisms() { return failureMechanisms; } public void ChangeComposition(AssessmentSectionComposition newComposition) { throw new NotImplementedException("Stub only verifies Observable and basic behaviour, use a proper stub when this function is necessary."); } private void AddHydraulicBoundaryLocation(HydraulicBoundaryLocation hydraulicBoundaryLocation, bool setCalculationOutput) { HydraulicBoundaryDatabase.Locations.Add(hydraulicBoundaryLocation); waterLevelCalculationsForFactorizedSignalingNorm.Add(CreateHydraulicBoundaryLocationCalculation(hydraulicBoundaryLocation, setCalculationOutput)); waterLevelCalculationsForSignalingNorm.Add(CreateHydraulicBoundaryLocationCalculation(hydraulicBoundaryLocation, setCalculationOutput)); waterLevelCalculationsForLowerLimitNorm.Add(CreateHydraulicBoundaryLocationCalculation(hydraulicBoundaryLocation, setCalculationOutput)); waterLevelCalculationsForFactorizedLowerLimitNorm.Add(CreateHydraulicBoundaryLocationCalculation(hydraulicBoundaryLocation, setCalculationOutput)); waveHeightCalculationsForFactorizedSignalingNorm.Add(CreateHydraulicBoundaryLocationCalculation(hydraulicBoundaryLocation, setCalculationOutput)); waveHeightCalculationsForSignalingNorm.Add(CreateHydraulicBoundaryLocationCalculation(hydraulicBoundaryLocation, setCalculationOutput)); waveHeightCalculationsForLowerLimitNorm.Add(CreateHydraulicBoundaryLocationCalculation(hydraulicBoundaryLocation, setCalculationOutput)); waveHeightCalculationsForFactorizedLowerLimitNorm.Add(CreateHydraulicBoundaryLocationCalculation(hydraulicBoundaryLocation, setCalculationOutput)); } private static HydraulicBoundaryLocationCalculation CreateHydraulicBoundaryLocationCalculation(HydraulicBoundaryLocation hydraulicBoundaryLocation, bool setCalculationOutput) { var hydraulicBoundaryLocationCalculation = new HydraulicBoundaryLocationCalculation(hydraulicBoundaryLocation); if (setCalculationOutput) { hydraulicBoundaryLocationCalculation.Output = new TestHydraulicBoundaryLocationCalculationOutput(random.NextDouble()); } return hydraulicBoundaryLocationCalculation; } } }