Fisheye: Tag 389b49bc5b93cd0fdadb53338ccc409024da6785 refers to a dead (removed) revision in file `Riskeer/AssemblyTool/test/Riskeer.AssemblyTool.KernelWrapper.Test/Calculators/Categories/AssemblyGroupBoundariesCalculatorTest.cs'. Fisheye: No comparison available. Pass `N' to diff? Index: Riskeer/AssemblyTool/test/Riskeer.AssemblyTool.KernelWrapper.Test/Calculators/Categories/FailureMechanismSectionAssemblyGroupBoundariesCalculatorTest.cs =================================================================== diff -u --- Riskeer/AssemblyTool/test/Riskeer.AssemblyTool.KernelWrapper.Test/Calculators/Categories/FailureMechanismSectionAssemblyGroupBoundariesCalculatorTest.cs (revision 0) +++ Riskeer/AssemblyTool/test/Riskeer.AssemblyTool.KernelWrapper.Test/Calculators/Categories/FailureMechanismSectionAssemblyGroupBoundariesCalculatorTest.cs (revision 389b49bc5b93cd0fdadb53338ccc409024da6785) @@ -0,0 +1,222 @@ +// Copyright (C) Stichting Deltares 2021. 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 Assembly.Kernel.Exceptions; +using Assembly.Kernel.Model; +using Assembly.Kernel.Model.AssessmentSection; +using Assembly.Kernel.Model.Categories; +using Core.Common.TestUtil; +using NUnit.Framework; +using Rhino.Mocks; +using Riskeer.AssemblyTool.Data; +using Riskeer.AssemblyTool.KernelWrapper.Calculators.Categories; +using Riskeer.AssemblyTool.KernelWrapper.Creators; +using Riskeer.AssemblyTool.KernelWrapper.Kernels; +using Riskeer.AssemblyTool.KernelWrapper.TestUtil; +using Riskeer.AssemblyTool.KernelWrapper.TestUtil.Kernels; +using Riskeer.AssemblyTool.KernelWrapper.TestUtil.Kernels.Categories; + +namespace Riskeer.AssemblyTool.KernelWrapper.Test.Calculators.Categories +{ + [TestFixture] + public class FailureMechanismSectionAssemblyGroupBoundariesCalculatorTest + { + [Test] + public void Constructor_ExpectedValues() + { + // Setup + var mocks = new MockRepository(); + var factory = mocks.Stub(); + mocks.ReplayAll(); + + // Call + var calculator = new FailureMechanismSectionAssemblyGroupBoundariesCalculator(factory); + + // Assert + Assert.IsInstanceOf(calculator); + mocks.VerifyAll(); + } + + [Test] + public void Constructor_FactoryNull_ThrowsArgumentNullException() + { + // Call + void Call() => new FailureMechanismSectionAssemblyGroupBoundariesCalculator(null); + + // Assert + var exception = Assert.Throws(Call); + Assert.AreEqual("factory", exception.ParamName); + } + + [Test] + public void CalculateFailureMechanismSectionAssemblyGroupBoundaries_WithValidInput_InputCorrectlySendToKernel() + { + // Setup + const double lowerLimitNorm = 0.001; + const double signalingNorm = 0.0001; + + using (new AssemblyToolKernelFactoryConfig()) + { + var factory = (TestAssemblyToolKernelFactory) AssemblyToolKernelFactory.Instance; + AssemblyCategoryLimitsKernelStub categoryLimitsKernel = factory.LastCreatedAssemblyCategoryLimitsKernel; + CategoriesList categoryLimits = CreateCategoryLimits(); + categoryLimitsKernel.InterpretationCategoryLimits = categoryLimits; + + var calculator = new FailureMechanismSectionAssemblyGroupBoundariesCalculator(factory); + + // Call + calculator.CalculateFailureMechanismSectionAssemblyGroupBoundaries(signalingNorm, lowerLimitNorm); + + // Assert + AssessmentSection assessmentSection = categoryLimitsKernel.AssessmentSection; + ProbabilityAssert.AreEqual(lowerLimitNorm, assessmentSection.FailureProbabilityLowerLimit); + ProbabilityAssert.AreEqual(signalingNorm, assessmentSection.FailureProbabilitySignallingLimit); + } + } + + [Test] + public void CalculateFailureMechanismSectionAssemblyGroupBoundaries_KernelWithCompleteOutput_ReturnsExpectedFailureMechanismSectionAssembly() + { + // Setup + const double lowerLimitNorm = 0.001; + const double signalingNorm = 0.0001; + + using (new AssemblyToolKernelFactoryConfig()) + { + var factory = (TestAssemblyToolKernelFactory) AssemblyToolKernelFactory.Instance; + AssemblyCategoryLimitsKernelStub categoryLimitsKernel = factory.LastCreatedAssemblyCategoryLimitsKernel; + CategoriesList categoryLimits = CreateCategoryLimits(); + categoryLimitsKernel.InterpretationCategoryLimits = categoryLimits; + + var calculator = new FailureMechanismSectionAssemblyGroupBoundariesCalculator(factory); + + // Call + IEnumerable result = + calculator.CalculateFailureMechanismSectionAssemblyGroupBoundaries(signalingNorm, lowerLimitNorm); + + // Assert + Assert.IsTrue(categoryLimitsKernel.Calculated); + + AssemblyGroupBoundariesAssert.AssertFailureMechanismSectionAssemblyGroupBoundaries(categoryLimits, result); + } + } + + [Test] + public void CalculateFailureMechanismSectionAssemblyGroupBoundaries_KernelWithInCompleteOutput_ThrowsAssemblyGroupBoundariesCalculatorException() + { + // Setup + const double lowerLimitNorm = 0.001; + const double signalingNorm = 0.0001; + + using (new AssemblyToolKernelFactoryConfig()) + { + var factory = (TestAssemblyToolKernelFactory) AssemblyToolKernelFactory.Instance; + AssemblyCategoryLimitsKernelStub categoryLimitsKernel = factory.LastCreatedAssemblyCategoryLimitsKernel; + var categoryLimits = new CategoriesList(new[] + { + new InterpretationCategory((EInterpretationCategory) 99, new Probability(0), new Probability(1)) + }); + categoryLimitsKernel.InterpretationCategoryLimits = categoryLimits; + + var calculator = new FailureMechanismSectionAssemblyGroupBoundariesCalculator(factory); + + // Call + void Call() => calculator.CalculateFailureMechanismSectionAssemblyGroupBoundaries(signalingNorm, lowerLimitNorm); + + // Assert + var exception = Assert.Throws(Call); + Assert.IsInstanceOf(exception.InnerException); + Assert.AreEqual(AssemblyErrorMessageCreator.CreateGenericErrorMessage(), exception.Message); + + Assert.IsTrue(categoryLimitsKernel.Calculated); + } + } + + [Test] + public void CalculateFailureMechanismSectionAssemblyGroupBoundaries_KernelThrowsException_ThrowsAssemblyGroupBoundariesCalculatorException() + { + // Setup + const double lowerLimitNorm = 0.001; + const double signalingNorm = 0.0001; + + using (new AssemblyToolKernelFactoryConfig()) + { + var factory = (TestAssemblyToolKernelFactory) AssemblyToolKernelFactory.Instance; + AssemblyCategoryLimitsKernelStub categoryLimitsKernel = factory.LastCreatedAssemblyCategoryLimitsKernel; + categoryLimitsKernel.ThrowExceptionOnCalculate = true; + + var calculator = new FailureMechanismSectionAssemblyGroupBoundariesCalculator(factory); + + // Call + void Call() => calculator.CalculateFailureMechanismSectionAssemblyGroupBoundaries(signalingNorm, lowerLimitNorm); + + // Assert + Assert.IsFalse(categoryLimitsKernel.Calculated); + + var exception = Assert.Throws(Call); + Assert.IsInstanceOf(exception.InnerException); + Assert.AreEqual(AssemblyErrorMessageCreator.CreateGenericErrorMessage(), exception.Message); + } + } + + [Test] + public void CalculateFailureMechanismSectionAssemblyGroupBoundaries_KernelThrowsAssemblyException_ThrowsAssemblyGroupBoundariesCalculatorException() + { + // Setup + const double lowerLimitNorm = 0.001; + const double signalingNorm = 0.0001; + + using (new AssemblyToolKernelFactoryConfig()) + { + var factory = (TestAssemblyToolKernelFactory) AssemblyToolKernelFactory.Instance; + AssemblyCategoryLimitsKernelStub categoryLimitsKernel = factory.LastCreatedAssemblyCategoryLimitsKernel; + categoryLimitsKernel.ThrowAssemblyExceptionOnCalculate = true; + + var calculator = new FailureMechanismSectionAssemblyGroupBoundariesCalculator(factory); + + // Call + void Call() => calculator.CalculateFailureMechanismSectionAssemblyGroupBoundaries(signalingNorm, lowerLimitNorm); + + // Assert + Assert.IsFalse(categoryLimitsKernel.Calculated); + + var exception = Assert.Throws(Call); + var innerException = exception.InnerException as AssemblyException; + Assert.IsNotNull(innerException); + Assert.AreEqual(AssemblyErrorMessageCreator.CreateErrorMessage(innerException.Errors), exception.Message); + } + } + + private static CategoriesList CreateCategoryLimits() + { + var random = new Random(21); + return new CategoriesList(new[] + { + new InterpretationCategory(random.NextEnumValue(), new Probability(0), new Probability(0.25)), + new InterpretationCategory(random.NextEnumValue(), new Probability(0.25), new Probability(0.5)), + new InterpretationCategory(random.NextEnumValue(), new Probability(0.5), new Probability(0.75)), + new InterpretationCategory(random.NextEnumValue(), new Probability(0.75), new Probability(1)) + }); + } + } +} \ No newline at end of file