Index: Ringtoets/Common/src/Ringtoets.Common.Forms/Properties/Resources.Designer.cs =================================================================== diff -u -rd803d27376ed059f1a1829292bf8048d40206604 -r6dbb29ed12c28b66db763ff603f3ab8e28a0adf4 --- Ringtoets/Common/src/Ringtoets.Common.Forms/Properties/Resources.Designer.cs (.../Resources.Designer.cs) (revision d803d27376ed059f1a1829292bf8048d40206604) +++ Ringtoets/Common/src/Ringtoets.Common.Forms/Properties/Resources.Designer.cs (.../Resources.Designer.cs) (revision 6dbb29ed12c28b66db763ff603f3ab8e28a0adf4) @@ -181,7 +181,7 @@ } /// - /// Looks up a localized string similar to Valideer en voer alle berekeningen binnen deze berekeningsmap uit.. + /// Looks up a localized string similar to Voer alle berekeningen binnen deze berekeningsmap uit.. /// public static string CalculationGroup_CalculateAll_ToolTip { get { @@ -304,15 +304,6 @@ } /// - /// Looks up a localized string similar to Voeg een nieuwe berekeningsmap toe aan dit faalmechanisme.. - /// - public static string FailureMechanism_Add_CalculationGroup_Tooltip { - get { - return ResourceManager.GetString("FailureMechanism_Add_CalculationGroup_Tooltip", resourceCulture); - } - } - - /// /// Looks up a localized string similar to Invoer. /// public static string FailureMechanism_Inputs_DisplayName { Index: Ringtoets/Common/src/Ringtoets.Common.Forms/Properties/Resources.resx =================================================================== diff -u -rd803d27376ed059f1a1829292bf8048d40206604 -r6dbb29ed12c28b66db763ff603f3ab8e28a0adf4 --- Ringtoets/Common/src/Ringtoets.Common.Forms/Properties/Resources.resx (.../Resources.resx) (revision d803d27376ed059f1a1829292bf8048d40206604) +++ Ringtoets/Common/src/Ringtoets.Common.Forms/Properties/Resources.resx (.../Resources.resx) (revision 6dbb29ed12c28b66db763ff603f3ab8e28a0adf4) @@ -280,9 +280,6 @@ Voeg een nieuwe berekeningsmap toe aan deze berekeningsmap. - - Voeg een nieuwe berekeningsmap toe aan dit faalmechanisme. - &Berekening toevoegen Index: Ringtoets/GrassCoverErosionInwards/src/Ringtoets.GrassCoverErosionInwards.Forms/Properties/Resources.Designer.cs =================================================================== diff -u -r88e4b60f9055cf9153fc5c7b618537accfc3f3fa -r6dbb29ed12c28b66db763ff603f3ab8e28a0adf4 --- Ringtoets/GrassCoverErosionInwards/src/Ringtoets.GrassCoverErosionInwards.Forms/Properties/Resources.Designer.cs (.../Resources.Designer.cs) (revision 88e4b60f9055cf9153fc5c7b618537accfc3f3fa) +++ Ringtoets/GrassCoverErosionInwards/src/Ringtoets.GrassCoverErosionInwards.Forms/Properties/Resources.Designer.cs (.../Resources.Designer.cs) (revision 6dbb29ed12c28b66db763ff603f3ab8e28a0adf4) @@ -343,16 +343,6 @@ } /// - /// Looks up a localized string similar to Voeg een nieuwe grasbekleding erosie kruin en binnentalud berekening toe aan dit faalmechanisme.. - /// - public static string GrassCoverErosionInwardsFailureMechanism_Add_GrassCoverErosionInwardsCalculation_Tooltip { - get { - return ResourceManager.GetString("GrassCoverErosionInwardsFailureMechanism_Add_GrassCoverErosionInwardsCalculation_" + - "Tooltip", resourceCulture); - } - } - - /// /// Looks up a localized string similar to Het label van het toetsspoor.. /// public static string GrassCoverErosionInwardsInput_Code_Description { Index: Ringtoets/GrassCoverErosionInwards/src/Ringtoets.GrassCoverErosionInwards.Forms/Properties/Resources.resx =================================================================== diff -u -r88e4b60f9055cf9153fc5c7b618537accfc3f3fa -r6dbb29ed12c28b66db763ff603f3ab8e28a0adf4 --- Ringtoets/GrassCoverErosionInwards/src/Ringtoets.GrassCoverErosionInwards.Forms/Properties/Resources.resx (.../Resources.resx) (revision 88e4b60f9055cf9153fc5c7b618537accfc3f3fa) +++ Ringtoets/GrassCoverErosionInwards/src/Ringtoets.GrassCoverErosionInwards.Forms/Properties/Resources.resx (.../Resources.resx) (revision 6dbb29ed12c28b66db763ff603f3ab8e28a0adf4) @@ -136,9 +136,6 @@ Het grasbekleding erosie kruin en binnentalud faalmechanisme - - Voeg een nieuwe grasbekleding erosie kruin en binnentalud berekening toe aan dit faalmechanisme. - Het label van het toetsspoor. Index: Ringtoets/GrassCoverErosionInwards/src/Ringtoets.GrassCoverErosionInwards.Plugin/GrassCoverErosionInwardsGuiPlugin.cs =================================================================== diff -u -r88e4b60f9055cf9153fc5c7b618537accfc3f3fa -r6dbb29ed12c28b66db763ff603f3ab8e28a0adf4 --- Ringtoets/GrassCoverErosionInwards/src/Ringtoets.GrassCoverErosionInwards.Plugin/GrassCoverErosionInwardsGuiPlugin.cs (.../GrassCoverErosionInwardsGuiPlugin.cs) (revision 88e4b60f9055cf9153fc5c7b618537accfc3f3fa) +++ Ringtoets/GrassCoverErosionInwards/src/Ringtoets.GrassCoverErosionInwards.Plugin/GrassCoverErosionInwardsGuiPlugin.cs (.../GrassCoverErosionInwardsGuiPlugin.cs) (revision 6dbb29ed12c28b66db763ff603f3ab8e28a0adf4) @@ -32,7 +32,6 @@ using Ringtoets.Common.Data; using Ringtoets.Common.Data.AssessmentSection; using Ringtoets.Common.Data.Calculation; -using Ringtoets.Common.Data.FailureMechanism; using Ringtoets.Common.Forms.Helpers; using Ringtoets.Common.Forms.PresentationObjects; using Ringtoets.Common.Forms.TreeNodeInfos; @@ -251,34 +250,11 @@ } ); - var addCalculationGroupItem = new StrictContextMenuItem( - RingtoetsCommonFormsResources.CalculationGroup_Add_CalculationGroup, - RingtoetsCommonFormsResources.FailureMechanism_Add_CalculationGroup_Tooltip, - RingtoetsCommonFormsResources.AddFolderIcon, - (o, args) => AddCalculationGroup(grassCoverErosionInwardsFailureMechanismContext.WrappedData) - ) - { - Enabled = false - }; - - var addCalculationItem = new StrictContextMenuItem( - RingtoetsCommonFormsResources.CalculationGroup_Add_Calculation, - GrassCoverErosionInwardsFormsResources.GrassCoverErosionInwardsFailureMechanism_Add_GrassCoverErosionInwardsCalculation_Tooltip, - GrassCoverErosionInwardsFormsResources.CalculationIcon, - (s, e) => AddCalculation(grassCoverErosionInwardsFailureMechanismContext.WrappedData, grassCoverErosionInwardsFailureMechanismContext.WrappedData.CalculationsGroup) - ) - { - Enabled = false - }; - return Gui.Get(grassCoverErosionInwardsFailureMechanismContext, treeViewControl) .AddOpenItem() .AddSeparator() .AddCustomItem(changeRelevancyItem) .AddSeparator() - .AddCustomItem(addCalculationGroupItem) - .AddCustomItem(addCalculationItem) - .AddSeparator() .AddImportItem() .AddExportItem() .AddSeparator() @@ -287,26 +263,16 @@ .Build(); } - private static void AddCalculationGroup(ICalculatableFailureMechanism failureMechanism) + private static void AddCalculation(GrassCoverErosionInwardsCalculationGroupContext context) { - var calculation = new CalculationGroup + var calculation = new GrassCoverErosionInwardsCalculation(context.FailureMechanism.GeneralInput) { - Name = NamingHelper.GetUniqueName(failureMechanism.CalculationsGroup.Children, RingtoetsCommonDataResources.CalculationGroup_DefaultName, c => c.Name) + Name = NamingHelper.GetUniqueName(context.WrappedData.Children, GrassCoverErosionInwardsDataResources.GrassCoverErosionInwardsCalculation_DefaultName, c => c.Name) }; - failureMechanism.CalculationsGroup.Children.Add(calculation); - failureMechanism.CalculationsGroup.NotifyObservers(); + context.WrappedData.Children.Add(calculation); + context.WrappedData.NotifyObservers(); } - private static void AddCalculation(GrassCoverErosionInwardsFailureMechanism failureMechanism, CalculationGroup calculationGroup) - { - var calculation = new GrassCoverErosionInwardsCalculation(failureMechanism.GeneralInput) - { - Name = NamingHelper.GetUniqueName(calculationGroup.Children, GrassCoverErosionInwardsDataResources.GrassCoverErosionInwardsCalculation_DefaultName, c => c.Name) - }; - calculationGroup.Children.Add(calculation); - calculationGroup.NotifyObservers(); - } - #endregion #region CalculationGroupContext TreeNodeInfo @@ -355,7 +321,7 @@ } CalculationTreeNodeInfoFactory.AddCreateCalculationGroupItem(builder, group); - CalculationTreeNodeInfoFactory.AddCreateCalculationItem(builder, nodeData, context => AddCalculation(context.FailureMechanism, context.WrappedData)); + CalculationTreeNodeInfoFactory.AddCreateCalculationItem(builder, nodeData, AddCalculation); builder.AddSeparator(); if (isNestedGroup) Index: Ringtoets/GrassCoverErosionInwards/test/Ringtoets.GrassCoverErosionInwards.Forms.Test/TreeNodeInfos/GrassCoverErosionInwardsFailureMechanismContextTreeNodeInfoTest.cs =================================================================== diff -u -ra9f78bc9a33e6fe9ad5cc56d6f45142ad9b96b5c -r6dbb29ed12c28b66db763ff603f3ab8e28a0adf4 --- Ringtoets/GrassCoverErosionInwards/test/Ringtoets.GrassCoverErosionInwards.Forms.Test/TreeNodeInfos/GrassCoverErosionInwardsFailureMechanismContextTreeNodeInfoTest.cs (.../GrassCoverErosionInwardsFailureMechanismContextTreeNodeInfoTest.cs) (revision a9f78bc9a33e6fe9ad5cc56d6f45142ad9b96b5c) +++ Ringtoets/GrassCoverErosionInwards/test/Ringtoets.GrassCoverErosionInwards.Forms.Test/TreeNodeInfos/GrassCoverErosionInwardsFailureMechanismContextTreeNodeInfoTest.cs (.../GrassCoverErosionInwardsFailureMechanismContextTreeNodeInfoTest.cs) (revision 6dbb29ed12c28b66db763ff603f3ab8e28a0adf4) @@ -167,9 +167,6 @@ menuBuilderMock.Expect(mb => mb.AddSeparator()).Return(menuBuilderMock); menuBuilderMock.Expect(mb => mb.AddCustomItem(null)).IgnoreArguments().Return(menuBuilderMock); menuBuilderMock.Expect(mb => mb.AddSeparator()).Return(menuBuilderMock); - menuBuilderMock.Expect(mb => mb.AddCustomItem(null)).IgnoreArguments().Return(menuBuilderMock); - menuBuilderMock.Expect(mb => mb.AddCustomItem(null)).IgnoreArguments().Return(menuBuilderMock); - menuBuilderMock.Expect(mb => mb.AddSeparator()).Return(menuBuilderMock); menuBuilderMock.Expect(mb => mb.AddImportItem()).Return(menuBuilderMock); menuBuilderMock.Expect(mb => mb.AddExportItem()).Return(menuBuilderMock); menuBuilderMock.Expect(mb => mb.AddSeparator()).Return(menuBuilderMock); @@ -218,16 +215,6 @@ RingtoetsCommonFormsResources.FailureMechanismContextMenuStrip_Is_relevant, RingtoetsCommonFormsResources.FailureMechanismContextMenuStrip_Is_relevant_Tooltip, RingtoetsCommonFormsResources.Checkbox_ticked); - TestHelper.AssertContextMenuStripContainsItem(menu, 3, - RingtoetsCommonFormsResources.CalculationGroup_Add_CalculationGroup, - RingtoetsCommonFormsResources.FailureMechanism_Add_CalculationGroup_Tooltip, - RingtoetsCommonFormsResources.AddFolderIcon, - false); - TestHelper.AssertContextMenuStripContainsItem(menu, 4, - RingtoetsCommonFormsResources.CalculationGroup_Add_Calculation, - GrassCoverErosionInwardsFormsResources.GrassCoverErosionInwardsFailureMechanism_Add_GrassCoverErosionInwardsCalculation_Tooltip, - GrassCoverErosionInwardsFormsResources.CalculationIcon, - false); mocksRepository.VerifyAll(); } Index: Ringtoets/Piping/src/Ringtoets.Piping.Forms/Properties/Resources.Designer.cs =================================================================== diff -u -rb6993e964bc966bd9fa07dc8962dca7f6fbaab70 -r6dbb29ed12c28b66db763ff603f3ab8e28a0adf4 --- Ringtoets/Piping/src/Ringtoets.Piping.Forms/Properties/Resources.Designer.cs (.../Resources.Designer.cs) (revision b6993e964bc966bd9fa07dc8962dca7f6fbaab70) +++ Ringtoets/Piping/src/Ringtoets.Piping.Forms/Properties/Resources.Designer.cs (.../Resources.Designer.cs) (revision 6dbb29ed12c28b66db763ff603f3ab8e28a0adf4) @@ -796,15 +796,6 @@ } /// - /// Looks up a localized string similar to Voeg een nieuwe piping berekening toe aan dit faalmechanisme.. - /// - public static string PipingFailureMechanism_Add_PipingCalculation_Tooltip { - get { - return ResourceManager.GetString("PipingFailureMechanism_Add_PipingCalculation_Tooltip", resourceCulture); - } - } - - /// /// Looks up a localized string similar to Er zijn geen berekeningen om uit te voeren.. /// public static string PipingFailureMechanism_CreateCalculateAllItem_No_calculations_to_run { Index: Ringtoets/Piping/src/Ringtoets.Piping.Forms/Properties/Resources.resx =================================================================== diff -u -rb6993e964bc966bd9fa07dc8962dca7f6fbaab70 -r6dbb29ed12c28b66db763ff603f3ab8e28a0adf4 --- Ringtoets/Piping/src/Ringtoets.Piping.Forms/Properties/Resources.resx (.../Resources.resx) (revision b6993e964bc966bd9fa07dc8962dca7f6fbaab70) +++ Ringtoets/Piping/src/Ringtoets.Piping.Forms/Properties/Resources.resx (.../Resources.resx) (revision 6dbb29ed12c28b66db763ff603f3ab8e28a0adf4) @@ -349,9 +349,6 @@ Ondergrondschematisatie - - Voeg een nieuwe piping berekening toe aan dit faalmechanisme. - Lognormale verdeling Index: Ringtoets/Piping/src/Ringtoets.Piping.Plugin/PipingGuiPlugin.cs =================================================================== diff -u -rd803d27376ed059f1a1829292bf8048d40206604 -r6dbb29ed12c28b66db763ff603f3ab8e28a0adf4 --- Ringtoets/Piping/src/Ringtoets.Piping.Plugin/PipingGuiPlugin.cs (.../PipingGuiPlugin.cs) (revision d803d27376ed059f1a1829292bf8048d40206604) +++ Ringtoets/Piping/src/Ringtoets.Piping.Plugin/PipingGuiPlugin.cs (.../PipingGuiPlugin.cs) (revision 6dbb29ed12c28b66db763ff603f3ab8e28a0adf4) @@ -296,20 +296,6 @@ } ); - var addCalculationGroupItem = new StrictContextMenuItem( - RingtoetsCommonFormsResources.CalculationGroup_Add_CalculationGroup, - RingtoetsCommonFormsResources.FailureMechanism_Add_CalculationGroup_Tooltip, - RingtoetsCommonFormsResources.AddFolderIcon, - (o, args) => AddCalculationGroup(pipingFailureMechanismContext.WrappedData) - ); - - var addCalculationItem = new StrictContextMenuItem( - RingtoetsCommonFormsResources.CalculationGroup_Add_Calculation, - PipingFormsResources.PipingFailureMechanism_Add_PipingCalculation_Tooltip, - PipingFormsResources.PipingIcon, - (s, e) => AddCalculation(pipingFailureMechanismContext.WrappedData) - ); - var validateAllItem = CreateValidateAllItem(pipingFailureMechanismContext.WrappedData); var calculateAllItem = CreateCalculateAllItem(pipingFailureMechanismContext.WrappedData); @@ -332,9 +318,6 @@ .AddSeparator() .AddCustomItem(changeRelevancyItem) .AddSeparator() - .AddCustomItem(addCalculationGroupItem) - .AddCustomItem(addCalculationItem) - .AddSeparator() .AddCustomItem(validateAllItem) .AddCustomItem(calculateAllItem) .AddCustomItem(clearAllItem) @@ -415,26 +398,6 @@ ActivityProgressDialogRunner.Run(Gui.MainWindow, GetAllPipingCalculations(failureMechanism).Select(calc => new PipingCalculationActivity(calc))); } - private void AddCalculationGroup(PipingFailureMechanism failureMechanism) - { - var calculation = new CalculationGroup - { - Name = NamingHelper.GetUniqueName(failureMechanism.CalculationsGroup.Children, RingtoetsCommonDataResources.CalculationGroup_DefaultName, c => c.Name) - }; - failureMechanism.CalculationsGroup.Children.Add(calculation); - failureMechanism.CalculationsGroup.NotifyObservers(); - } - - private void AddCalculation(PipingFailureMechanism failureMechanism) - { - var calculation = new PipingCalculationScenario(failureMechanism.GeneralInput, failureMechanism.NormProbabilityInput) - { - Name = NamingHelper.GetUniqueName(failureMechanism.CalculationsGroup.Children, PipingDataResources.PipingCalculation_DefaultName, c => c.Name) - }; - failureMechanism.CalculationsGroup.Children.Add(calculation); - failureMechanism.CalculationsGroup.NotifyObservers(); - } - private object[] FailureMechanismChildNodeObjects(PipingFailureMechanismContext pipingFailureMechanismContext) { PipingFailureMechanism wrappedData = pipingFailureMechanismContext.WrappedData; Index: Ringtoets/Piping/test/Ringtoets.Piping.Forms.Test/Ringtoets.Piping.Forms.Test.csproj =================================================================== diff -u -r23a37b025a5d0358c1f30fb31de41a2c284519a5 -r6dbb29ed12c28b66db763ff603f3ab8e28a0adf4 --- Ringtoets/Piping/test/Ringtoets.Piping.Forms.Test/Ringtoets.Piping.Forms.Test.csproj (.../Ringtoets.Piping.Forms.Test.csproj) (revision 23a37b025a5d0358c1f30fb31de41a2c284519a5) +++ Ringtoets/Piping/test/Ringtoets.Piping.Forms.Test/Ringtoets.Piping.Forms.Test.csproj (.../Ringtoets.Piping.Forms.Test.csproj) (revision 6dbb29ed12c28b66db763ff603f3ab8e28a0adf4) @@ -78,7 +78,7 @@ - + Index: Ringtoets/Piping/test/Ringtoets.Piping.Forms.Test/TreeNodeInfos/PipingFailureMechanismContextTreeNodeInfoTest.cs =================================================================== diff -u --- Ringtoets/Piping/test/Ringtoets.Piping.Forms.Test/TreeNodeInfos/PipingFailureMechanismContextTreeNodeInfoTest.cs (revision 0) +++ Ringtoets/Piping/test/Ringtoets.Piping.Forms.Test/TreeNodeInfos/PipingFailureMechanismContextTreeNodeInfoTest.cs (revision 6dbb29ed12c28b66db763ff603f3ab8e28a0adf4) @@ -0,0 +1,593 @@ +// Copyright (C) Stichting Deltares 2016. 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.Linq; +using System.Windows.Forms; +using Core.Common.Base; +using Core.Common.Controls.TreeView; +using Core.Common.Gui; +using Core.Common.Gui.Commands; +using Core.Common.Gui.ContextMenu; +using Core.Common.Gui.Forms.MainWindow; +using Core.Common.Gui.TestUtil.ContextMenu; +using Core.Common.TestUtil; +using NUnit.Extensions.Forms; +using NUnit.Framework; +using Rhino.Mocks; +using Ringtoets.Common.Data; +using Ringtoets.Common.Data.AssessmentSection; +using Ringtoets.Common.Data.Calculation; +using Ringtoets.Common.Forms.PresentationObjects; +using Ringtoets.Piping.Data; +using Ringtoets.Piping.Data.TestUtil; +using Ringtoets.Piping.Forms.PresentationObjects; +using Ringtoets.Piping.KernelWrapper.TestUtil; +using Ringtoets.Piping.Plugin; +using RingtoetsFormsResources = Ringtoets.Common.Forms.Properties.Resources; +using RingtoetsDataResources = Ringtoets.Common.Data.Properties.Resources; +using PipingFormsResources = Ringtoets.Piping.Forms.Properties.Resources; +using CoreCommonGuiResources = Core.Common.Gui.Properties.Resources; +using RingtoetsCommonFormsResources = Ringtoets.Common.Forms.Properties.Resources; + +namespace Ringtoets.Piping.Forms.Test.TreeNodeInfos +{ + [TestFixture] + public class PipingFailureMechanismContextTreeNodeInfoTest : NUnitFormTest + { + private MockRepository mocks; + private PipingGuiPlugin plugin; + private TreeNodeInfo info; + + private const int contextMenuRelevancyIndex = 1; + private const int contextMenuValidateAllIndex = 3; + private const int contextMenuCalculateAllIndex = 4; + private const int contextMenuClearIndex = 5; + + [SetUp] + public void SetUp() + { + mocks = new MockRepository(); + plugin = new PipingGuiPlugin(); + info = plugin.GetTreeNodeInfos().First(tni => tni.TagType == typeof(PipingFailureMechanismContext)); + } + + [Test] + public void Initialized_Always_ExpectedPropertiesSet() + { + // Assert + Assert.AreEqual(typeof(PipingFailureMechanismContext), info.TagType); + Assert.IsNotNull(info.ForeColor); + Assert.IsNull(info.EnsureVisibleOnCreate); + Assert.IsNull(info.CanRename); + Assert.IsNull(info.OnNodeRenamed); + Assert.IsNull(info.CanRemove); + Assert.IsNull(info.OnNodeRemoved); + Assert.IsNull(info.CanCheck); + Assert.IsNull(info.IsChecked); + Assert.IsNull(info.OnNodeChecked); + Assert.IsNull(info.CanDrag); + Assert.IsNull(info.CanDrop); + Assert.IsNull(info.CanInsert); + Assert.IsNull(info.OnDrop); + } + + [Test] + public void Text_Always_ReturnsName() + { + // Setup + var assessmentSection = mocks.Stub(); + mocks.ReplayAll(); + + var mechanism = new PipingFailureMechanism(); + var mechanismContext = new PipingFailureMechanismContext(mechanism, assessmentSection); + + // Call + var text = info.Text(mechanismContext); + + // Assert + Assert.AreEqual("Dijken - Piping", text); + mocks.VerifyAll(); + } + + [Test] + public void Image_Always_ReturnsPlaceHolderIcon() + { + // Call + var image = info.Image(null); + + // Assert + TestHelper.AssertImagesAreEqual(PipingFormsResources.PipingIcon, image); + } + + [Test] + public void ChildNodeObjects_Always_ReturnChildDataNodes() + { + // Setup + var assessmentSection = mocks.Stub(); + mocks.ReplayAll(); + + var pipingFailureMechanism = new PipingFailureMechanism(); + var generalInputParameters = new GeneralPipingInput(); + var semiProbabilisticInputParameters = new NormProbabilityPipingInput(); + pipingFailureMechanism.CalculationsGroup.Children.Add(new PipingCalculationScenario(generalInputParameters, semiProbabilisticInputParameters)); + pipingFailureMechanism.CalculationsGroup.Children.Add(new PipingCalculationScenario(generalInputParameters, semiProbabilisticInputParameters)); + + var pipingFailureMechanismContext = new PipingFailureMechanismContext(pipingFailureMechanism, assessmentSection); + + // Call + var children = info.ChildNodeObjects(pipingFailureMechanismContext).ToArray(); + + // Assert + Assert.AreEqual(3, children.Length); + var inputsFolder = (CategoryTreeFolder) children[0]; + Assert.AreEqual("Invoer", inputsFolder.Name); + Assert.AreEqual(TreeFolderCategory.Input, inputsFolder.Category); + + Assert.AreEqual(4, inputsFolder.Contents.Count); + var failureMechanismSectionsContext = (FailureMechanismSectionsContext) inputsFolder.Contents[0]; + CollectionAssert.AreEqual(pipingFailureMechanism.Sections, failureMechanismSectionsContext.WrappedData); + Assert.AreSame(pipingFailureMechanism, failureMechanismSectionsContext.ParentFailureMechanism); + Assert.AreSame(assessmentSection, failureMechanismSectionsContext.ParentAssessmentSection); + + var surfaceLinesContext = (RingtoetsPipingSurfaceLinesContext) inputsFolder.Contents[1]; + Assert.AreSame(pipingFailureMechanism, surfaceLinesContext.FailureMechanism); + Assert.AreSame(assessmentSection, surfaceLinesContext.AssessmentSection); + + var stochasticSoilModelContext = (StochasticSoilModelContext) inputsFolder.Contents[2]; + Assert.AreSame(pipingFailureMechanism, stochasticSoilModelContext.FailureMechanism); + Assert.AreSame(assessmentSection, stochasticSoilModelContext.AssessmentSection); + + var commentContext = (CommentContext) inputsFolder.Contents[3]; + Assert.AreSame(pipingFailureMechanism, commentContext.CommentContainer); + + var calculationsFolder = (PipingCalculationGroupContext) children[1]; + Assert.AreEqual("Berekeningen", calculationsFolder.WrappedData.Name); + CollectionAssert.AreEqual(pipingFailureMechanism.CalculationsGroup.Children, calculationsFolder.WrappedData.Children); + Assert.AreSame(pipingFailureMechanism.SurfaceLines, calculationsFolder.AvailablePipingSurfaceLines); + Assert.AreEqual(pipingFailureMechanism.StochasticSoilModels, calculationsFolder.AvailableStochasticSoilModels); + Assert.AreSame(pipingFailureMechanism, calculationsFolder.FailureMechanism); + + var outputsFolder = (CategoryTreeFolder) children[2]; + Assert.AreEqual("Uitvoer", outputsFolder.Name); + Assert.AreEqual(TreeFolderCategory.Output, outputsFolder.Category); + + var failureMechanismResultsContext = (FailureMechanismSectionResultContext) outputsFolder.Contents[0]; + Assert.AreSame(pipingFailureMechanism, failureMechanismResultsContext.FailureMechanism); + Assert.AreSame(pipingFailureMechanism.SectionResults, failureMechanismResultsContext.SectionResults); + mocks.VerifyAll(); + } + + [Test] + [TestCase(false)] + [TestCase(true)] + public void GivenMultiplePipingCalculationsWithOutput_WhenClearingOutputFromContextMenu_ThenPipingOutputCleared(bool confirm) + { + // Given + var gui = mocks.StrictMock(); + var treeViewControl = mocks.StrictMock(); + var menuBuilder = new CustomItemsOnlyContextMenuBuilder(); + var generalInputParameters = new GeneralPipingInput(); + var semiProbabilisticInputParameters = new NormProbabilityPipingInput(); + var pipingCalculation1 = new PipingCalculationScenario(generalInputParameters, semiProbabilisticInputParameters) + { + Output = new TestPipingOutput() + }; + var pipingCalculation2 = new PipingCalculationScenario(generalInputParameters, semiProbabilisticInputParameters) + { + Output = new TestPipingOutput() + }; + + var observer = mocks.StrictMock(); + if (confirm) + { + observer.Expect(o => o.UpdateObserver()).Repeat.Twice(); + } + + var failureMechanism = new PipingFailureMechanism(); + failureMechanism.CalculationsGroup.Children.Add(pipingCalculation1); + failureMechanism.CalculationsGroup.Children.Add(pipingCalculation2); + + var assessmentSection = mocks.Stub(); + var failureMechanismContext = new PipingFailureMechanismContext(failureMechanism, assessmentSection); + + gui.Expect(cmp => cmp.Get(failureMechanismContext, treeViewControl)).Return(menuBuilder); + + mocks.ReplayAll(); + + plugin.Gui = gui; + + failureMechanism.CalculationsGroup.Children.Clear(); + failureMechanism.CalculationsGroup.Children.Add(pipingCalculation1); + failureMechanism.CalculationsGroup.Children.Add(pipingCalculation2); + failureMechanism.CalculationsGroup.Children.ElementAt(0).Attach(observer); + failureMechanism.CalculationsGroup.Children.ElementAt(1).Attach(observer); + + ContextMenuStrip contextMenuAdapter = info.ContextMenuStrip(failureMechanismContext, null, treeViewControl); + + string messageBoxTitle = null, messageBoxText = null; + DialogBoxHandler = (name, wnd) => + { + var messageBox = new MessageBoxTester(wnd); + + messageBoxText = messageBox.Text; + messageBoxTitle = messageBox.Title; + + if (confirm) + { + messageBox.ClickOk(); + } + else + { + messageBox.ClickCancel(); + } + }; + + // When + contextMenuAdapter.Items[contextMenuClearIndex].PerformClick(); + + // Then + foreach (var calc in failureMechanism.CalculationsGroup.Children.OfType()) + { + Assert.AreNotEqual(confirm, calc.HasOutput); + } + + Assert.AreEqual("Bevestigen", messageBoxTitle); + Assert.AreEqual("Weet u zeker dat u alle uitvoer wilt wissen?", messageBoxText); + mocks.VerifyAll(); + } + + [Test] + public void ContextMenuStrip_HasCalculationWithOutput_ReturnsContextMenuWithCommonItems() + { + // Setup + var treeViewControl = mocks.StrictMock(); + var failureMechanism = new PipingFailureMechanism(); + var pipingCalculation = new PipingCalculationScenario(failureMechanism.GeneralInput, failureMechanism.NormProbabilityInput) + { + Output = new TestPipingOutput() + }; + failureMechanism.CalculationsGroup.Children.Add(pipingCalculation); + + var assessmentSection = mocks.Stub(); + var failureMechanismContext = new PipingFailureMechanismContext(failureMechanism, assessmentSection); + + var applicationFeatureCommandHandler = mocks.Stub(); + var exportImportHandler = mocks.Stub(); + var viewCommandsHandler = mocks.Stub(); + + var menuBuilder = new ContextMenuBuilder(applicationFeatureCommandHandler, exportImportHandler, viewCommandsHandler, failureMechanismContext, treeViewControl); + + var gui = mocks.StrictMock(); + gui.Expect(cmp => cmp.Get(failureMechanismContext, treeViewControl)).Return(menuBuilder); + treeViewControl.Expect(tvc => tvc.CanExpandOrCollapseForData(failureMechanismContext)).Repeat.Twice().Return(false); + + mocks.ReplayAll(); + + plugin.Gui = gui; + + // Call + ContextMenuStrip menu = info.ContextMenuStrip(failureMechanismContext, null, treeViewControl); + + // Assert + Assert.AreEqual(13, menu.Items.Count); + + TestHelper.AssertContextMenuStripContainsItem(menu, 0, CoreCommonGuiResources.Open, CoreCommonGuiResources.Open_ToolTip, CoreCommonGuiResources.OpenIcon, false); + + TestHelper.AssertContextMenuStripContainsItem(menu, 2, RingtoetsCommonFormsResources.FailureMechanismContextMenuStrip_Is_relevant, RingtoetsCommonFormsResources.FailureMechanismContextMenuStrip_Is_relevant_Tooltip, RingtoetsCommonFormsResources.Checkbox_ticked); + + TestHelper.AssertContextMenuStripContainsItem(menu, 4, RingtoetsFormsResources.Validate_all, RingtoetsFormsResources.Validate_all_ToolTip, RingtoetsFormsResources.ValidateAllIcon); + TestHelper.AssertContextMenuStripContainsItem(menu, 5, RingtoetsFormsResources.Calculate_all, RingtoetsFormsResources.Calculate_all_ToolTip, RingtoetsFormsResources.CalculateAllIcon); + TestHelper.AssertContextMenuStripContainsItem(menu, 6, RingtoetsFormsResources.Clear_all_output, RingtoetsFormsResources.Clear_all_output_ToolTip, RingtoetsFormsResources.ClearIcon); + + TestHelper.AssertContextMenuStripContainsItem(menu, 8, CoreCommonGuiResources.Import, CoreCommonGuiResources.Import_ToolTip, CoreCommonGuiResources.ImportIcon, false); + TestHelper.AssertContextMenuStripContainsItem(menu, 9, CoreCommonGuiResources.Export, CoreCommonGuiResources.Export_ToolTip, CoreCommonGuiResources.ExportIcon, false); + + TestHelper.AssertContextMenuStripContainsItem(menu, 11, CoreCommonGuiResources.Expand_all, CoreCommonGuiResources.Expand_all_ToolTip, CoreCommonGuiResources.ExpandAllIcon, false); + TestHelper.AssertContextMenuStripContainsItem(menu, 12, CoreCommonGuiResources.Collapse_all, CoreCommonGuiResources.Collapse_all_ToolTip, CoreCommonGuiResources.CollapseAllIcon, false); + + CollectionAssert.AllItemsAreInstancesOfType(new[] + { + menu.Items[1], + menu.Items[3], + menu.Items[7], + menu.Items[10] + }, typeof(ToolStripSeparator)); + + mocks.VerifyAll(); + } + + [Test] + public void ContextMenuStrip_PipingFailureMechanismNoOutput_ClearAllOutputDisabled() + { + // Setup + var treeViewControl = mocks.StrictMock(); + var menuBuilder = new CustomItemsOnlyContextMenuBuilder(); + + var dataMock = mocks.StrictMock(); + dataMock.Stub(dm => dm.Calculations).Return(new ICalculation[0]); + + var assessmentSection = mocks.Stub(); + var failureMechanismContext = new PipingFailureMechanismContext(dataMock, assessmentSection); + + var gui = mocks.StrictMock(); + gui.Expect(cmp => cmp.Get(failureMechanismContext, treeViewControl)).Return(menuBuilder); + + mocks.ReplayAll(); + + plugin.Gui = gui; + + // Call + ContextMenuStrip contextMenu = info.ContextMenuStrip(failureMechanismContext, null, treeViewControl); + + // Assert + ToolStripItem clearOutputItem = contextMenu.Items[contextMenuClearIndex]; + Assert.IsFalse(clearOutputItem.Enabled); + Assert.AreEqual("Er zijn geen berekeningen met uitvoer om te wissen.", clearOutputItem.ToolTipText); + + mocks.VerifyAll(); // Expect no calls on arguments + } + + [Test] + public void ContextMenuStrip_PipingFailureMechanismWithOutput_ClearAllOutputEnabled() + { + // Setup + var treeViewControl = mocks.StrictMock(); + var menuBuilder = new CustomItemsOnlyContextMenuBuilder(); + var pipingCalculation = new PipingCalculationScenario(new GeneralPipingInput(), new NormProbabilityPipingInput()) + { + Output = new TestPipingOutput() + }; + + var failureMechanism = new PipingFailureMechanism(); + failureMechanism.CalculationsGroup.Children.Add(pipingCalculation); + + var assessmentSection = mocks.Stub(); + var failureMechanismContext = new PipingFailureMechanismContext(failureMechanism, assessmentSection); + + var gui = mocks.StrictMock(); + gui.Expect(cmp => cmp.Get(failureMechanismContext, treeViewControl)).Return(menuBuilder); + + mocks.ReplayAll(); + + plugin.Gui = gui; + + failureMechanism.CalculationsGroup.Children.Add(pipingCalculation); + + // Call + ContextMenuStrip contextMenu = info.ContextMenuStrip(failureMechanismContext, null, treeViewControl); + + // Assert + ToolStripItem clearOutputItem = contextMenu.Items[contextMenuClearIndex]; + Assert.IsTrue(clearOutputItem.Enabled); + Assert.AreEqual(RingtoetsFormsResources.Clear_all_output_ToolTip, clearOutputItem.ToolTipText); + + mocks.VerifyAll(); // Expect no calls on arguments + } + + [Test] + public void ContextMenuStrip_PipingFailureMechanismWithNoCalculations_ValidateAndCalculateAllDisabled() + { + // Setup + var treeViewControl = mocks.StrictMock(); + var menuBuilder = new CustomItemsOnlyContextMenuBuilder(); + + var dataMock = new PipingFailureMechanism(); + + var assessmentSection = mocks.Stub(); + var failureMechanismContext = new PipingFailureMechanismContext(dataMock, assessmentSection); + + var gui = mocks.StrictMock(); + gui.Expect(cmp => cmp.Get(failureMechanismContext, treeViewControl)).Return(menuBuilder); + + mocks.ReplayAll(); + + plugin.Gui = gui; + + dataMock.CalculationsGroup.Children.Clear(); + + // Call + ContextMenuStrip contextMenu = info.ContextMenuStrip(failureMechanismContext, null, treeViewControl); + + // Assert + ToolStripItem validateItem = contextMenu.Items[contextMenuValidateAllIndex]; + ToolStripItem calculateItem = contextMenu.Items[contextMenuCalculateAllIndex]; + Assert.IsFalse(validateItem.Enabled); + Assert.IsFalse(calculateItem.Enabled); + Assert.AreEqual(PipingFormsResources.PipingFailureMechanism_CreateCalculateAllItem_No_calculations_to_run, calculateItem.ToolTipText); + Assert.AreEqual(PipingFormsResources.PipingFailureMechanism_CreateValidateAllItem_No_calculations_to_validate, validateItem.ToolTipText); + + mocks.VerifyAll(); // Expect no calls on arguments + } + + [Test] + public void ContextMenuStrip_Always_CallsContextMenuBuilderMethods() + { + // Setup + var pipingFailureMechanism = new PipingFailureMechanism(); + var assessmentSection = mocks.Stub(); + var pipingFailureMechanismContext = new PipingFailureMechanismContext(pipingFailureMechanism, assessmentSection); + + var gui = mocks.StrictMock(); + var treeViewControl = mocks.StrictMock(); + var menuBuilder = mocks.StrictMock(); + + menuBuilder.Expect(mb => mb.AddOpenItem()).Return(menuBuilder); + menuBuilder.Expect(mb => mb.AddSeparator()).Return(menuBuilder); + menuBuilder.Expect(mb => mb.AddCustomItem(null)).IgnoreArguments().Return(menuBuilder); + menuBuilder.Expect(mb => mb.AddSeparator()).Return(menuBuilder); + menuBuilder.Expect(mb => mb.AddCustomItem(null)).IgnoreArguments().Return(menuBuilder); + menuBuilder.Expect(mb => mb.AddCustomItem(null)).IgnoreArguments().Return(menuBuilder); + menuBuilder.Expect(mb => mb.AddCustomItem(null)).IgnoreArguments().Return(menuBuilder); + menuBuilder.Expect(mb => mb.AddSeparator()).Return(menuBuilder); + menuBuilder.Expect(mb => mb.AddImportItem()).Return(menuBuilder); + menuBuilder.Expect(mb => mb.AddExportItem()).Return(menuBuilder); + menuBuilder.Expect(mb => mb.AddSeparator()).Return(menuBuilder); + menuBuilder.Expect(mb => mb.AddExpandAllItem()).Return(menuBuilder); + menuBuilder.Expect(mb => mb.AddCollapseAllItem()).Return(menuBuilder); + menuBuilder.Expect(mb => mb.Build()).Return(null); + + gui.Expect(cmp => cmp.Get(pipingFailureMechanismContext, treeViewControl)).Return(menuBuilder); + + mocks.ReplayAll(); + + plugin.Gui = gui; + + // Call + info.ContextMenuStrip(pipingFailureMechanismContext, null, treeViewControl); + + // Assert + mocks.VerifyAll(); + } + + [Test] + public void ContextMenuStrip_ClickOnValidateAllItem_ValidateAllChildCalculations() + { + // Setup + var gui = mocks.StrictMock(); + var treeViewControl = mocks.StrictMock(); + var menuBuilder = new CustomItemsOnlyContextMenuBuilder(); + + var failureMechanism = new PipingFailureMechanism(); + failureMechanism.CalculationsGroup.Children.Clear(); + + var validCalculation = PipingCalculationFactory.CreateCalculationWithValidInput(); + validCalculation.Name = "A"; + var invalidCalculation = PipingCalculationFactory.CreateCalculationWithInvalidData(); + invalidCalculation.Name = "B"; + + failureMechanism.CalculationsGroup.Children.Add(validCalculation); + failureMechanism.CalculationsGroup.Children.Add(invalidCalculation); + + var assessmentSection = mocks.Stub(); + var failureMechanismContext = new PipingFailureMechanismContext(failureMechanism, assessmentSection); + + gui.Expect(g => g.Get(failureMechanismContext, treeViewControl)).Return(menuBuilder); + + mocks.ReplayAll(); + + plugin.Gui = gui; + + var contextMenu = info.ContextMenuStrip(failureMechanismContext, null, treeViewControl); + + // Call + Action call = () => contextMenu.Items[contextMenuValidateAllIndex].PerformClick(); + + // Assert + TestHelper.AssertLogMessages(call, messages => + { + var msgs = messages.ToArray(); + Assert.AreEqual(6, msgs.Length); + StringAssert.StartsWith(String.Format("Validatie van '{0}' gestart om: ", validCalculation.Name), msgs[0]); + StringAssert.StartsWith(String.Format("Validatie van '{0}' beëindigd om: ", validCalculation.Name), msgs[1]); + + StringAssert.StartsWith(String.Format("Validatie van '{0}' gestart om: ", invalidCalculation.Name), msgs[2]); + // Some validation error from validation service + StringAssert.StartsWith(String.Format("Validatie van '{0}' beëindigd om: ", invalidCalculation.Name), msgs[5]); + }); + mocks.VerifyAll(); + } + + [Test] + public void ContextMenuStrip_ClickOnCalculateAllItem_ScheduleAllChildCalculations() + { + // Setup + var gui = mocks.StrictMock(); + var mainWindow = mocks.Stub(); + var treeViewControl = mocks.StrictMock(); + var menuBuilder = new CustomItemsOnlyContextMenuBuilder(); + + var failureMechanism = new PipingFailureMechanism(); + failureMechanism.CalculationsGroup.Children.Clear(); + + var validCalculation = PipingCalculationFactory.CreateCalculationWithValidInput(); + validCalculation.Name = "A"; + var invalidCalculation = PipingCalculationFactory.CreateCalculationWithInvalidData(); + invalidCalculation.Name = "B"; + + failureMechanism.CalculationsGroup.Children.Add(validCalculation); + failureMechanism.CalculationsGroup.Children.Add(invalidCalculation); + + var assessmentSection = mocks.Stub(); + var failureMechanismContext = new PipingFailureMechanismContext(failureMechanism, assessmentSection); + + gui.Expect(g => g.Get(failureMechanismContext, treeViewControl)).Return(menuBuilder); + gui.Expect(g => g.MainWindow).Return(mainWindow); + + mocks.ReplayAll(); + + plugin.Gui = gui; + + var contextMenu = info.ContextMenuStrip(failureMechanismContext, null, treeViewControl); + + DialogBoxHandler = (name, wnd) => + { + // Don't care about dialogs in this test. + }; + + // Call + contextMenu.Items[contextMenuCalculateAllIndex].PerformClick(); + + // Assert + mocks.VerifyAll(); + } + + [Test] + public void ContextMenuStrip_ClickOnIsRelevantItem_MakeFailureMechanismNotRelevant() + { + // Setup + var failureMechanismObserver = mocks.Stub(); + failureMechanismObserver.Expect(o => o.UpdateObserver()); + + var failureMechanism = new PipingFailureMechanism + { + IsRelevant = true + }; + failureMechanism.Attach(failureMechanismObserver); + + var assessmentSection = mocks.Stub(); + var failureMechanismContext = new PipingFailureMechanismContext(failureMechanism, assessmentSection); + + var viewCommands = mocks.StrictMock(); + viewCommands.Expect(vs => vs.RemoveAllViewsForItem(failureMechanismContext)); + + var treeViewControl = mocks.StrictMock(); + var menuBuilder = new CustomItemsOnlyContextMenuBuilder(); + + var gui = mocks.StrictMock(); + gui.Stub(g => g.ViewCommands).Return(viewCommands); + gui.Expect(g => g.Get(failureMechanismContext, treeViewControl)).Return(menuBuilder); + + mocks.ReplayAll(); + + plugin.Gui = gui; + + var contextMenu = info.ContextMenuStrip(failureMechanismContext, null, treeViewControl); + + // Call + contextMenu.Items[contextMenuRelevancyIndex].PerformClick(); + + // Assert + Assert.IsFalse(failureMechanism.IsRelevant); + mocks.VerifyAll(); + } + } +} \ No newline at end of file Fisheye: Tag 6dbb29ed12c28b66db763ff603f3ab8e28a0adf4 refers to a dead (removed) revision in file `Ringtoets/Piping/test/Ringtoets.Piping.Forms.Test/TreeNodeInfos/PipingFailureMechanismTreeNodeInfoTest.cs'. Fisheye: No comparison available. Pass `N' to diff?