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?