// 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 System.Linq; 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 barebones implementation of . /// public class ObservableTestAssessmentSectionStub : Observable, IAssessmentSection { 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 ObservableTestAssessmentSectionStub() { FailureMechanismContribution = new FailureMechanismContribution(Enumerable.Empty(), 0, 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; } } /// /// Adds a hydraulic boundary location to the assessment section stub. /// /// The hydraulic boundary location to add. public void AddHydraulicBoundaryLocation(HydraulicBoundaryLocation hydraulicBoundaryLocation) { HydraulicBoundaryDatabase.Locations.Add(hydraulicBoundaryLocation); waterLevelCalculationsForFactorizedSignalingNorm.Add(new HydraulicBoundaryLocationCalculation(hydraulicBoundaryLocation)); waterLevelCalculationsForSignalingNorm.Add(new HydraulicBoundaryLocationCalculation(hydraulicBoundaryLocation)); waterLevelCalculationsForLowerLimitNorm.Add(new HydraulicBoundaryLocationCalculation(hydraulicBoundaryLocation)); waterLevelCalculationsForFactorizedLowerLimitNorm.Add(new HydraulicBoundaryLocationCalculation(hydraulicBoundaryLocation)); waveHeightCalculationsForFactorizedSignalingNorm.Add(new HydraulicBoundaryLocationCalculation(hydraulicBoundaryLocation)); waveHeightCalculationsForSignalingNorm.Add(new HydraulicBoundaryLocationCalculation(hydraulicBoundaryLocation)); waveHeightCalculationsForLowerLimitNorm.Add(new HydraulicBoundaryLocationCalculation(hydraulicBoundaryLocation)); waveHeightCalculationsForFactorizedLowerLimitNorm.Add(new HydraulicBoundaryLocationCalculation(hydraulicBoundaryLocation)); } public IEnumerable GetFailureMechanisms() { yield break; } public void ChangeComposition(AssessmentSectionComposition newComposition) { throw new NotImplementedException("Stub only verifies Observable and basic behaviour, use a proper stub when this function is necessary."); } } }