Fisheye: Tag f185449911cb5fcdd20c902ab231dcac3d843dcb refers to a dead (removed) revision in file `Riskeer/Piping/test/Riskeer.Piping.Forms.Test/PresentationObjects/Probabilistic/ProbabilisticPipingCalculationContextTest.cs'. Fisheye: No comparison available. Pass `N' to diff? Index: Riskeer/Piping/test/Riskeer.Piping.Forms.Test/PresentationObjects/Probabilistic/ProbabilisticPipingCalculationScenarioContextTest.cs =================================================================== diff -u --- Riskeer/Piping/test/Riskeer.Piping.Forms.Test/PresentationObjects/Probabilistic/ProbabilisticPipingCalculationScenarioContextTest.cs (revision 0) +++ Riskeer/Piping/test/Riskeer.Piping.Forms.Test/PresentationObjects/Probabilistic/ProbabilisticPipingCalculationScenarioContextTest.cs (revision f185449911cb5fcdd20c902ab231dcac3d843dcb) @@ -0,0 +1,190 @@ +// Copyright (C) Stichting Deltares 2019. All rights reserved. +// +// This file is part of Riskeer. +// +// Riskeer 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.TestUtil; +using NUnit.Framework; +using Rhino.Mocks; +using Riskeer.Common.Data.AssessmentSection; +using Riskeer.Common.Data.Calculation; +using Riskeer.Common.Forms.PresentationObjects; +using Riskeer.Piping.Data; +using Riskeer.Piping.Data.Probabilistic; +using Riskeer.Piping.Data.SoilProfile; +using Riskeer.Piping.Data.TestUtil; +using Riskeer.Piping.Forms.PresentationObjects; +using Riskeer.Piping.Forms.PresentationObjects.Probabilistic; +using Riskeer.Piping.Primitives; + +namespace Riskeer.Piping.Forms.Test.PresentationObjects.Probabilistic +{ + [TestFixture] + public class ProbabilisticPipingCalculationScenarioContextTest + { + [Test] + public void ConstructorWithData_Always_ExpectedPropertiesSet() + { + // Setup + var mocks = new MockRepository(); + var assessmentSection = mocks.Stub(); + mocks.ReplayAll(); + + var surfaceLines = new[] + { + new PipingSurfaceLine(string.Empty) + }; + PipingStochasticSoilModel[] soilModels = + { + PipingStochasticSoilModelTestFactory.CreatePipingStochasticSoilModel() + }; + var calculation = new ProbabilisticPipingCalculationScenario(); + var failureMechanism = new PipingFailureMechanism(); + var parent = new CalculationGroup(); + + // Call + var presentationObject = new ProbabilisticPipingCalculationScenarioContext(calculation, + parent, + surfaceLines, + soilModels, + failureMechanism, + assessmentSection); + + // Assert + Assert.IsInstanceOf>(presentationObject); + Assert.IsInstanceOf>(presentationObject); + Assert.AreSame(calculation, presentationObject.WrappedData); + Assert.AreSame(parent, presentationObject.Parent); + Assert.AreSame(surfaceLines, presentationObject.AvailablePipingSurfaceLines); + Assert.AreSame(soilModels, presentationObject.AvailableStochasticSoilModels); + Assert.AreSame(failureMechanism, presentationObject.FailureMechanism); + Assert.AreSame(assessmentSection, presentationObject.AssessmentSection); + mocks.VerifyAll(); + } + + [Test] + public void ParameteredConstructor_ParentNull_ThrowsArgumentNullException() + { + // Setup + var mocks = new MockRepository(); + var assessmentSection = mocks.Stub(); + mocks.ReplayAll(); + + var surfaceLines = new[] + { + new PipingSurfaceLine(string.Empty) + }; + PipingStochasticSoilModel[] soilModels = + { + PipingStochasticSoilModelTestFactory.CreatePipingStochasticSoilModel() + }; + var calculation = new ProbabilisticPipingCalculationScenario(); + var failureMechanism = new PipingFailureMechanism(); + + // Call + TestDelegate call = () => new ProbabilisticPipingCalculationScenarioContext(calculation, + null, + surfaceLines, + soilModels, + failureMechanism, + assessmentSection); + + // Assert + var exception = Assert.Throws(call); + Assert.AreEqual("parent", exception.ParamName); + mocks.VerifyAll(); + } + + [TestFixture] + private class PipingCalculationScenarioContextEqualsTest + : EqualsTestFixture + { + private static readonly MockRepository mocks = new MockRepository(); + + private static readonly IAssessmentSection assessmentSection = mocks.Stub(); + private static readonly ProbabilisticPipingCalculationScenario calculation = new ProbabilisticPipingCalculationScenario(); + private static readonly IEnumerable surfaceLines = new PipingSurfaceLine[0]; + private static readonly IEnumerable stochasticSoilModels = new PipingStochasticSoilModel[0]; + private static readonly PipingFailureMechanism failureMechanism = new PipingFailureMechanism(); + private static readonly CalculationGroup parent = new CalculationGroup(); + + [SetUp] + public void SetUp() + { + mocks.ReplayAll(); + } + + [TearDown] + public void TearDown() + { + mocks.VerifyAll(); + } + + protected override ProbabilisticPipingCalculationScenarioContext CreateObject() + { + return new ProbabilisticPipingCalculationScenarioContext(calculation, + parent, + surfaceLines, + stochasticSoilModels, + failureMechanism, + assessmentSection); + } + + protected override DerivedProbabilisticPipingCalculationScenarioContext CreateDerivedObject() + { + return new DerivedProbabilisticPipingCalculationScenarioContext(calculation, + parent, + surfaceLines, + stochasticSoilModels, + failureMechanism, + assessmentSection); + } + + private static IEnumerable GetUnequalTestCases() + { + yield return new TestCaseData(new ProbabilisticPipingCalculationScenarioContext(new ProbabilisticPipingCalculationScenario(), + parent, + surfaceLines, + stochasticSoilModels, + failureMechanism, + assessmentSection)) + .SetName("Calculation"); + yield return new TestCaseData(new ProbabilisticPipingCalculationScenarioContext(calculation, + new CalculationGroup(), + surfaceLines, + stochasticSoilModels, + failureMechanism, + assessmentSection)) + .SetName("Parent"); + } + } + + private class DerivedProbabilisticPipingCalculationScenarioContext : ProbabilisticPipingCalculationScenarioContext + { + public DerivedProbabilisticPipingCalculationScenarioContext(ProbabilisticPipingCalculationScenario calculation, + CalculationGroup parent, + IEnumerable surfaceLines, + IEnumerable stochasticSoilModels, + PipingFailureMechanism pipingFailureMechanism, IAssessmentSection assessmentSection) + : base(calculation, parent, surfaceLines, stochasticSoilModels, pipingFailureMechanism, assessmentSection) {} + } + } +} \ No newline at end of file