// 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.Collections.Generic;
using System.Linq;
using System.Windows.Forms;
using Core.Common.Base;
using Core.Common.Base.Geometry;
using Core.Components.Charting.Data;
using Core.Components.Charting.Forms;
using Core.Components.OxyPlot.Forms;
using NUnit.Framework;
using Ringtoets.Piping.Data;
using Ringtoets.Piping.Forms.Properties;
using Ringtoets.Piping.Forms.Views;
using Ringtoets.Piping.Primitives;
using RingtoetsCommonFormsResources = Ringtoets.Common.Forms.Properties.Resources;
using PipingDataResources = Ringtoets.Piping.Data.Properties.Resources;
namespace Ringtoets.Piping.Forms.Test.Views
{
[TestFixture]
public class PipingInputViewTest
{
[Test]
public void DefaultConstructor_DefaultValues()
{
// Call
using (PipingInputView view = new PipingInputView())
{
// Assert
Assert.IsInstanceOf(view);
Assert.IsInstanceOf(view);
Assert.IsInstanceOf(view);
Assert.IsNotNull(view.Chart);
Assert.IsNull(view.Data);
}
}
[Test]
public void DefaultConstructor_Always_AddChartControlWithEmptyCollectionData()
{
// Call
using (PipingInputView view = new PipingInputView())
{
// Assert
Assert.AreEqual(1, view.Controls.Count);
ChartControl chartControl = view.Controls[0] as ChartControl;
Assert.IsNotNull(chartControl);
Assert.AreEqual(DockStyle.Fill, chartControl.Dock);
Assert.IsNotNull(chartControl.Data);
CollectionAssert.IsEmpty(chartControl.Data.List);
Assert.AreEqual(RingtoetsCommonFormsResources.InputView_Distance_DisplayName, chartControl.BottomAxisTitle);
Assert.AreEqual(RingtoetsCommonFormsResources.InputView_Height_DisplayName, chartControl.LeftAxisTitle);
}
}
[Test]
public void Data_PipingInput_DataSet()
{
// Setup
using (PipingInputView view = new PipingInputView())
{
PipingInput input = new PipingInput(new GeneralPipingInput());
// Call
view.Data = input;
// Assert
Assert.AreSame(input, view.Data);
}
}
[Test]
public void Data_OtherThanPipingInput_DataNull()
{
// Setup
using (PipingInputView view = new PipingInputView())
{
object input = new object();
// Call
view.Data = input;
// Assert
Assert.IsNull(view.Data);
}
}
[Test]
public void Data_SetToNull_ChartDataCleared()
{
// Setup
using (PipingInputView view = new PipingInputView())
{
var surfaceLine = GetSurfaceLineWithGeometry();
var input = new PipingInput(new GeneralPipingInput())
{
SurfaceLine = surfaceLine
};
view.Data = input;
// Precondition
Assert.AreEqual(9, view.Chart.Data.List.Count);
// Call
view.Data = null;
// Assert
Assert.IsNull(view.Data);
Assert.IsNull(view.Chart.Data);
}
}
[Test]
public void Calculation_Always_SetsCalculationAndUpdateChartTitle()
{
// Setup
using (PipingInputView view = new PipingInputView())
{
PipingCalculationScenario calculation = new PipingCalculationScenario(new GeneralPipingInput())
{
Name = "Test name"
};
// Call
view.Calculation = calculation;
// Assert
Assert.AreSame(calculation, view.Calculation);
Assert.AreEqual(calculation.Name, view.Chart.ChartTitle);
}
}
[Test]
public void Calculation_SetToNull_ChartTitleCleared()
{
// Setup
using (PipingInputView view = new PipingInputView())
{
PipingCalculationScenario calculation = new PipingCalculationScenario(new GeneralPipingInput())
{
Name = "Test name"
};
view.Calculation = calculation;
// Precondition
Assert.AreSame(calculation, view.Calculation);
Assert.AreEqual(calculation.Name, view.Chart.ChartTitle);
// Call
view.Calculation = null;
// Assert
Assert.IsNull(view.Calculation);
Assert.AreEqual(string.Empty, view.Chart.ChartTitle);
}
}
[Test]
public void Data_SetChartData_ChartDataSet()
{
// Setup
using (PipingInputView view = new PipingInputView())
{
var surfaceLine = GetSurfaceLineWithGeometry();
surfaceLine.SetDitchDikeSideAt(new Point3D(1.2, 2.3, 4.0));
surfaceLine.SetBottomDitchDikeSideAt(new Point3D(1.2, 2.3, 4.0));
surfaceLine.SetDitchPolderSideAt(new Point3D(1.2, 2.3, 4.0));
surfaceLine.SetBottomDitchPolderSideAt(new Point3D(1.2, 2.3, 4.0));
surfaceLine.SetDikeToeAtPolderAt(new Point3D(1.2, 2.3, 4.0));
surfaceLine.SetDikeToeAtRiverAt(new Point3D(1.2, 2.3, 4.0));
var pipingInput = new PipingInput(new GeneralPipingInput())
{
SurfaceLine = surfaceLine
};
// Call
view.Data = pipingInput;
// Assert
Assert.AreSame(pipingInput, view.Data);
Assert.IsInstanceOf(view.Chart.Data);
var chartData = view.Chart.Data;
Assert.IsNotNull(chartData);
Assert.AreEqual(Resources.PipingInputContext_NodeDisplayName, chartData.Name);
Assert.AreEqual(9, chartData.List.Count);
AssertSurfaceLineChartData(surfaceLine, chartData.List[surfaceLineIndex]);
AssertEntryPointLPointchartData(pipingInput, surfaceLine, chartData.List[entryPointIndex]);
AssertCharacteristicPoints(surfaceLine, chartData.List);
}
}
[Test]
public void Data_WithoutSurfaceLine_CollectionOfEmptyChartDataSet()
{
// Setup
using (PipingInputView view = new PipingInputView())
{
var pipingInput = new PipingInput(new GeneralPipingInput());
// Call
view.Data = pipingInput;
// Assert
Assert.AreSame(pipingInput, view.Data);
Assert.IsInstanceOf(view.Chart.Data);
var chartData = view.Chart.Data;
Assert.IsNotNull(chartData);
Assert.AreEqual(Resources.PipingInputContext_NodeDisplayName, chartData.Name);
Assert.AreEqual(9, chartData.List.Count);
var lineData = (ChartLineData) chartData.List[surfaceLineIndex];
var entryPointData = (ChartPointData) chartData.List[entryPointIndex];
var exitPointData = (ChartPointData) chartData.List[exitPointIndex];
var ditchDikeSideData = (ChartPointData) chartData.List[ditchDikeSideIndex];
var bottomDitchDikeSideData = (ChartPointData) chartData.List[bottomDitchDikeSideIndex];
var ditchPolderSideData = (ChartPointData) chartData.List[ditchPolderSideIndex];
var bottomDitchPolderSideData = (ChartPointData) chartData.List[bottomDitchPolderSideIndex];
var dikeToeAtPolderData = (ChartPointData) chartData.List[dikeToeAtPolderIndex];
var dikeToeAtRiverData = (ChartPointData) chartData.List[dikeToeAtRiverIndex];
CollectionAssert.IsEmpty(lineData.Points);
CollectionAssert.IsEmpty(entryPointData.Points);
CollectionAssert.IsEmpty(exitPointData.Points);
CollectionAssert.IsEmpty(ditchDikeSideData.Points);
CollectionAssert.IsEmpty(bottomDitchDikeSideData.Points);
CollectionAssert.IsEmpty(ditchPolderSideData.Points);
CollectionAssert.IsEmpty(bottomDitchPolderSideData.Points);
CollectionAssert.IsEmpty(dikeToeAtPolderData.Points);
CollectionAssert.IsEmpty(dikeToeAtRiverData.Points);
Assert.AreEqual(Resources.RingtoetsPipingSurfaceLine_DisplayName, lineData.Name);
Assert.AreEqual(Resources.PipingInput_EntryPointL_DisplayName, entryPointData.Name);
Assert.AreEqual(Resources.PipingInput_ExitPointL_DisplayName, exitPointData.Name);
Assert.AreEqual(PipingDataResources.CharacteristicPoint_DitchDikeSide, ditchDikeSideData.Name);
Assert.AreEqual(PipingDataResources.CharacteristicPoint_BottomDitchDikeSide, bottomDitchDikeSideData.Name);
Assert.AreEqual(PipingDataResources.CharacteristicPoint_DitchPolderSide, ditchPolderSideData.Name);
Assert.AreEqual(PipingDataResources.CharacteristicPoint_BottomDitchPolderSide, bottomDitchPolderSideData.Name);
Assert.AreEqual(PipingDataResources.CharacteristicPoint_DikeToeAtPolder, dikeToeAtPolderData.Name);
Assert.AreEqual(PipingDataResources.CharacteristicPoint_DikeToeAtRiver, dikeToeAtRiverData.Name);
}
}
[Test]
public void UpdateObservers_CalculationNotSet_ChartTitleSetToEmptyString()
{
// Setup
using (PipingInputView view = new PipingInputView())
{
var pipingInput = new PipingInput(new GeneralPipingInput());
view.Data = pipingInput;
// Precondition
Assert.IsNull(view.Chart.ChartTitle);
// Call
pipingInput.NotifyObservers();
// Assert
Assert.AreEqual(string.Empty, view.Chart.ChartTitle);
}
}
[Test]
public void UpdateObservers_CalculationNameUpdated_ChartTitleUpdated()
{
// Setup
using (PipingInputView view = new PipingInputView())
{
var initialName = "Initial name";
var updatedName = "Updated name";
var calculation = new PipingCalculationScenario(new GeneralPipingInput())
{
Name = initialName
};
view.Calculation = calculation;
// Precondition
Assert.AreEqual(initialName, view.Chart.ChartTitle);
calculation.Name = updatedName;
// Call
calculation.NotifyObservers();
// Assert
Assert.AreEqual(updatedName, view.Chart.ChartTitle);
}
}
[Test]
public void UpdateObservers_OtherCalculationNameUpdated_ChartTitleNotUpdated()
{
// Setup
using (PipingInputView view = new PipingInputView())
{
var initialName = "Initial name";
var updatedName = "Updated name";
var calculation1 = new PipingCalculationScenario(new GeneralPipingInput())
{
Name = initialName
};
var calculation2 = new PipingCalculationScenario(new GeneralPipingInput())
{
Name = initialName
};
view.Calculation = calculation1;
// Precondition
Assert.AreEqual(initialName, view.Chart.ChartTitle);
calculation2.Name = updatedName;
// Call
calculation1.NotifyObservers();
// Assert
Assert.AreEqual(initialName, view.Chart.ChartTitle);
}
}
[Test]
public void UpdateObservers_CalculationUpdatedNotifyObserversOnOldData_NoUpdateInViewData()
{
// Setup
using (PipingInputView view = new PipingInputView())
{
var initialName = "Initial name";
var updatedName = "Updated name";
var calculation = new PipingCalculationScenario(new GeneralPipingInput())
{
Name = initialName
};
view.Calculation = calculation;
// Precondition
Assert.AreEqual(initialName, view.Chart.ChartTitle);
var calculation2 = new PipingCalculationScenario(new GeneralPipingInput())
{
Name = initialName
};
view.Calculation = calculation2;
calculation.Name = updatedName;
// Call
calculation.NotifyObservers();
// Assert
Assert.AreEqual(initialName, view.Chart.ChartTitle);
}
}
[Test]
public void UpdateObservers_CalculationSurfaceLineUpdated_SetNewChartData()
{
// Setup
using (PipingInputView view = new PipingInputView())
{
var characteristicPoint = new Point3D(1.2, 2.3, 4.0);
var surfaceLine = GetSurfaceLineWithGeometry();
surfaceLine.SetDitchDikeSideAt(characteristicPoint);
surfaceLine.SetBottomDitchDikeSideAt(characteristicPoint);
surfaceLine.SetDitchPolderSideAt(characteristicPoint);
surfaceLine.SetBottomDitchPolderSideAt(characteristicPoint);
surfaceLine.SetDikeToeAtPolderAt(characteristicPoint);
surfaceLine.SetDikeToeAtRiverAt(characteristicPoint);
var pipingInput = new PipingInput(new GeneralPipingInput())
{
SurfaceLine = surfaceLine
};
view.Data = pipingInput;
ChartLineData oldSurfaceLineChartData = (ChartLineData) view.Chart.Data.List[surfaceLineIndex];
ChartPointData oldEntryPointChartData = (ChartPointData) view.Chart.Data.List[entryPointIndex];
ChartPointData oldExitPointChartData = (ChartPointData) view.Chart.Data.List[exitPointIndex];
ChartPointData oldDitchDikeSideData = (ChartPointData) view.Chart.Data.List[ditchDikeSideIndex];
ChartPointData oldBottomDitchDikeSideData = (ChartPointData) view.Chart.Data.List[bottomDitchDikeSideIndex];
ChartPointData oldDitchPolderSideData = (ChartPointData) view.Chart.Data.List[ditchPolderSideIndex];
ChartPointData oldBottomDitchPolderSideData = (ChartPointData) view.Chart.Data.List[bottomDitchPolderSideIndex];
ChartPointData oldDikeToeAtPolderData = (ChartPointData) view.Chart.Data.List[dikeToeAtPolderIndex];
ChartPointData oldDikeToeAtRiverData = (ChartPointData) view.Chart.Data.List[dikeToeAtRiverIndex];
var characteristicPoint2 = new Point3D(3.5, 2.3, 8.0);
var surfaceLine2 = GetSecondSurfaceLineWithGeometry();
surfaceLine2.SetDitchDikeSideAt(characteristicPoint2);
surfaceLine2.SetBottomDitchDikeSideAt(characteristicPoint2);
surfaceLine2.SetDitchPolderSideAt(characteristicPoint2);
surfaceLine2.SetBottomDitchPolderSideAt(characteristicPoint2);
surfaceLine2.SetDikeToeAtPolderAt(characteristicPoint2);
surfaceLine2.SetDikeToeAtRiverAt(characteristicPoint2);
pipingInput.SurfaceLine = surfaceLine2;
// Call
pipingInput.NotifyObservers();
// Assert
ChartLineData newSurfaceLineChartData = (ChartLineData) view.Chart.Data.List[surfaceLineIndex];
Assert.AreNotEqual(oldSurfaceLineChartData, newSurfaceLineChartData);
AssertSurfaceLineChartData(surfaceLine2, newSurfaceLineChartData);
ChartPointData newEntryPointChartData = (ChartPointData) view.Chart.Data.List[entryPointIndex];
Assert.AreNotEqual(oldEntryPointChartData, newEntryPointChartData);
AssertEntryPointLPointchartData(pipingInput, surfaceLine2, newEntryPointChartData);
ChartPointData newExitPointChartData = (ChartPointData) view.Chart.Data.List[exitPointIndex];
Assert.AreNotEqual(oldExitPointChartData, newExitPointChartData);
AssertExitPointLPointchartData(pipingInput, surfaceLine2, newExitPointChartData);
ChartPointData newDitchDikeSideData = (ChartPointData) view.Chart.Data.List[ditchDikeSideIndex];
Assert.AreNotEqual(oldDitchDikeSideData, newDitchDikeSideData);
ChartPointData newBottomDitchDikeSideData = (ChartPointData) view.Chart.Data.List[bottomDitchDikeSideIndex];
Assert.AreNotEqual(oldBottomDitchDikeSideData, newBottomDitchDikeSideData);
ChartPointData newDitchPolderSideData = (ChartPointData) view.Chart.Data.List[ditchPolderSideIndex];
Assert.AreNotEqual(oldDitchPolderSideData, newDitchPolderSideData);
ChartPointData newBottomDitchPolderSideData = (ChartPointData) view.Chart.Data.List[bottomDitchPolderSideIndex];
Assert.AreNotEqual(oldBottomDitchPolderSideData, newBottomDitchPolderSideData);
ChartPointData newDikeToeAtPolderData = (ChartPointData) view.Chart.Data.List[dikeToeAtPolderIndex];
Assert.AreNotEqual(oldDikeToeAtPolderData, newDikeToeAtPolderData);
ChartPointData newDikeToeAtRiverData = (ChartPointData) view.Chart.Data.List[dikeToeAtRiverIndex];
Assert.AreNotEqual(oldDikeToeAtRiverData, newDikeToeAtRiverData);
AssertCharacteristicPoints(surfaceLine2, view.Chart.Data.List);
}
}
[Test]
public void UpdateObserver_OtherPipingInputUpdated_ChartDataNotUpdated()
{
// Setup
using (PipingInputView view = new PipingInputView())
{
var surfaceLine = GetSurfaceLineWithGeometry();
var input1 = new PipingInput(new GeneralPipingInput())
{
SurfaceLine = surfaceLine
};
var input2 = new PipingInput(new GeneralPipingInput())
{
SurfaceLine = surfaceLine
};
view.Data = input1;
var surfaceLine2 = GetSecondSurfaceLineWithGeometry();
input2.SurfaceLine = surfaceLine2;
// Call
input2.NotifyObservers();
// Assert
Assert.AreEqual(input1, view.Data);
}
}
[Test]
public void NotifyObservers_DataUpdatedNotifyObserversOnOldData_NoUpdateInViewData()
{
// Setup
using (PipingInputView view = new PipingInputView())
{
var surfaceLine = GetSurfaceLineWithGeometry();
var input1 = new PipingInput(new GeneralPipingInput())
{
SurfaceLine = surfaceLine
};
var input2 = new PipingInput(new GeneralPipingInput());
view.Data = input1;
ChartData dataBeforeUpdate = view.Chart.Data;
view.Data = input2;
var surfaceLine2 = GetSecondSurfaceLineWithGeometry();
input1.SurfaceLine = surfaceLine2;
// Call
input1.NotifyObservers();
// Assert
Assert.AreEqual(dataBeforeUpdate, view.Chart.Data);
}
}
private const int surfaceLineIndex = 0;
private const int ditchPolderSideIndex = 1;
private const int bottomDitchPolderSideIndex = 2;
private const int bottomDitchDikeSideIndex = 3;
private const int ditchDikeSideIndex = 4;
private const int dikeToeAtPolderIndex = 5;
private const int dikeToeAtRiverIndex = 6;
private const int exitPointIndex = 7;
private const int entryPointIndex = 8;
private static RingtoetsPipingSurfaceLine GetSurfaceLineWithGeometry()
{
var points = new[]
{
new Point3D(1.2, 2.3, 4.0),
new Point3D(2.7, 2.8, 6.0)
};
return GetSurfaceLine(points);
}
private static RingtoetsPipingSurfaceLine GetSecondSurfaceLineWithGeometry()
{
var points = new[]
{
new Point3D(3.5, 2.3, 8.0),
new Point3D(6.9, 2.0, 2.0)
};
return GetSurfaceLine(points);
}
private static RingtoetsPipingSurfaceLine GetSurfaceLine(Point3D[] points)
{
var surfaceLine = new RingtoetsPipingSurfaceLine
{
Name = "Surface line name"
};
surfaceLine.SetGeometry(points);
return surfaceLine;
}
private void AssertSurfaceLineChartData(RingtoetsPipingSurfaceLine surfaceLine, ChartData chartData)
{
Assert.IsInstanceOf(chartData);
ChartLineData surfaceLineChartData = (ChartLineData) chartData;
Assert.AreEqual(surfaceLine.Points.Length, surfaceLineChartData.Points.Count());
CollectionAssert.AreEqual(surfaceLine.ProjectGeometryToLZ(), surfaceLineChartData.Points);
Assert.AreEqual(surfaceLine.Name, chartData.Name);
}
private void AssertEntryPointLPointchartData(PipingInput pipingInput, RingtoetsPipingSurfaceLine surfaceLine, ChartData chartData)
{
Assert.IsInstanceOf(chartData);
ChartPointData entryPointChartData = (ChartPointData) chartData;
Assert.AreEqual(1, entryPointChartData.Points.Count());
Point2D entryPoint = new Point2D(pipingInput.EntryPointL, surfaceLine.GetZAtL(pipingInput.EntryPointL));
CollectionAssert.AreEqual(new[]
{
entryPoint
}, entryPointChartData.Points);
Assert.AreEqual(Resources.PipingInput_EntryPointL_DisplayName, entryPointChartData.Name);
}
private void AssertExitPointLPointchartData(PipingInput pipingInput, RingtoetsPipingSurfaceLine surfaceLine, ChartData chartData)
{
Assert.IsInstanceOf(chartData);
ChartPointData exitPointChartData = (ChartPointData) chartData;
Assert.AreEqual(1, exitPointChartData.Points.Count());
Point2D exitPoint = new Point2D(pipingInput.ExitPointL, surfaceLine.GetZAtL(pipingInput.ExitPointL));
CollectionAssert.AreEqual(new[]
{
exitPoint
}, exitPointChartData.Points);
Assert.AreEqual(Resources.PipingInput_ExitPointL_DisplayName, exitPointChartData.Name);
}
private void AssertCharacteristicPoints(RingtoetsPipingSurfaceLine surfaceLine, IList characteristicPoints)
{
Point3D first = surfaceLine.Points.First();
Point3D last = surfaceLine.Points.Last();
Point2D firstPoint = new Point2D(first.X, first.Y);
Point2D lastPoint = new Point2D(last.X, last.Y);
var ditchDikeSideData = (ChartPointData) characteristicPoints[ditchDikeSideIndex];
Assert.AreEqual(1, ditchDikeSideData.Points.Count());
CollectionAssert.AreEqual(new[]
{
surfaceLine.DitchDikeSide.ProjectIntoLocalCoordinates(firstPoint, lastPoint)
}, ditchDikeSideData.Points);
Assert.AreEqual(PipingDataResources.CharacteristicPoint_DitchDikeSide, ditchDikeSideData.Name);
var bottomDitchDikeSideData = (ChartPointData) characteristicPoints[bottomDitchDikeSideIndex];
Assert.AreEqual(1, bottomDitchDikeSideData.Points.Count());
CollectionAssert.AreEqual(new[]
{
surfaceLine.BottomDitchDikeSide.ProjectIntoLocalCoordinates(firstPoint, lastPoint)
}, bottomDitchDikeSideData.Points);
Assert.AreEqual(PipingDataResources.CharacteristicPoint_BottomDitchDikeSide, bottomDitchDikeSideData.Name);
var ditchPolderSideData = (ChartPointData) characteristicPoints[ditchPolderSideIndex];
Assert.AreEqual(1, ditchPolderSideData.Points.Count());
CollectionAssert.AreEqual(new[]
{
surfaceLine.DitchPolderSide.ProjectIntoLocalCoordinates(firstPoint, lastPoint)
}, ditchPolderSideData.Points);
Assert.AreEqual(PipingDataResources.CharacteristicPoint_DitchPolderSide, ditchPolderSideData.Name);
var bottomDitchPolderSideData = (ChartPointData) characteristicPoints[bottomDitchPolderSideIndex];
Assert.AreEqual(1, bottomDitchPolderSideData.Points.Count());
CollectionAssert.AreEqual(new[]
{
surfaceLine.BottomDitchPolderSide.ProjectIntoLocalCoordinates(firstPoint, lastPoint)
}, bottomDitchPolderSideData.Points);
Assert.AreEqual(PipingDataResources.CharacteristicPoint_BottomDitchPolderSide, bottomDitchPolderSideData.Name);
var dikeToeAtPolderData = (ChartPointData) characteristicPoints[dikeToeAtPolderIndex];
Assert.AreEqual(1, dikeToeAtPolderData.Points.Count());
CollectionAssert.AreEqual(new[]
{
surfaceLine.DikeToeAtPolder.ProjectIntoLocalCoordinates(firstPoint, lastPoint)
}, dikeToeAtPolderData.Points);
Assert.AreEqual(PipingDataResources.CharacteristicPoint_DikeToeAtPolder, dikeToeAtPolderData.Name);
var dikeToeAtRiverData = (ChartPointData) characteristicPoints[dikeToeAtRiverIndex];
Assert.AreEqual(1, dikeToeAtRiverData.Points.Count());
CollectionAssert.AreEqual(new[]
{
surfaceLine.DikeToeAtRiver.ProjectIntoLocalCoordinates(firstPoint, lastPoint)
}, dikeToeAtRiverData.Points);
Assert.AreEqual(PipingDataResources.CharacteristicPoint_DikeToeAtRiver, dikeToeAtRiverData.Name);
}
}
}