// 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.Geometry;
using Core.Components.Charting.Data;
using Core.Components.Charting.Forms;
using NUnit.Framework;
using Ringtoets.Piping.Data;
using Ringtoets.Piping.Forms.Views;
using Ringtoets.Piping.Primitives;
namespace Ringtoets.Piping.Forms.Test.Views
{
[TestFixture]
public class PipingInputViewTest
{
private const int soilProfileIndex = 0;
private const int surfaceLineIndex = 1;
private const int ditchPolderSideIndex = 2;
private const int bottomDitchPolderSideIndex = 3;
private const int bottomDitchDikeSideIndex = 4;
private const int ditchDikeSideIndex = 5;
private const int dikeToeAtPolderIndex = 6;
private const int dikeToeAtRiverIndex = 7;
private const int exitPointIndex = 8;
private const int entryPointIndex = 9;
[Test]
public void DefaultConstructor_DefaultValues()
{
// Call
using (var view = new PipingInputView())
{
// Assert
Assert.IsInstanceOf(view);
Assert.IsInstanceOf(view);
Assert.IsNotNull(view.Chart);
Assert.IsNull(view.Data);
}
}
[Test]
public void DefaultConstructor_Always_AddEmptyChartControl()
{
// Call
using (var view = new PipingInputView())
{
// Assert
Assert.AreEqual(1, view.Controls.Count);
Assert.AreSame(view.Chart, view.Controls[0]);
Assert.AreEqual(DockStyle.Fill, ((Control) view.Chart).Dock);
Assert.AreEqual("Afstand [m]", view.Chart.BottomAxisTitle);
Assert.AreEqual("Hoogte [m+NAP]", view.Chart.LeftAxisTitle);
Assert.IsNull(view.Chart.Data);
}
}
[Test]
public void Data_PipingCalculationScenario_DataSet()
{
// Setup
using (var view = new PipingInputView())
{
var calculation = new PipingCalculationScenario(new GeneralPipingInput());
// Call
view.Data = calculation;
// Assert
Assert.AreSame(calculation, view.Data);
}
}
[Test]
public void Data_OtherThanPipingCalculationScenario_DataNull()
{
// Setup
using (var view = new PipingInputView())
{
var data = new object();
// Call
view.Data = data;
// Assert
Assert.IsNull(view.Data);
}
}
[Test]
public void Data_SetToNull_ChartDataCleared()
{
// Setup
using (var view = new PipingInputView())
{
view.Data = new PipingCalculationScenario(new GeneralPipingInput());
// Precondition
Assert.AreEqual(10, view.Chart.Data.Collection.Count());
// Call
view.Data = null;
// Assert
Assert.IsNull(view.Data);
Assert.IsNull(view.Chart.Data);
}
}
[Test]
public void Data_EmptyGrassCoverErosionInwardsCalculation_NoMapDataSet()
{
// Setup
using (var view = new PipingInputView())
{
var calculation = new PipingCalculationScenario(new GeneralPipingInput());
// Call
view.Data = calculation;
// Assert
AssertEmptyChartData(view.Chart.Data);
}
}
[Test]
public void Data_WithSurfaceLineAndSoilProfile_DataUpdatedToCollectionOfFilledChartData()
{
// Setup
using (var view = new PipingInputView())
{
RingtoetsPipingSurfaceLine 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));
StochasticSoilProfile stochasticSoilProfile = GetStochasticSoilProfile();
var calculation = new PipingCalculationScenario(new GeneralPipingInput())
{
InputParameters =
{
SurfaceLine = surfaceLine,
StochasticSoilProfile = stochasticSoilProfile
}
};
// Call
view.Data = calculation;
// Assert
Assert.AreSame(calculation, view.Data);
var chartData = view.Chart.Data;
Assert.IsInstanceOf(chartData);
Assert.AreEqual(10, chartData.Collection.Count());
AssertSoilProfileChartData(stochasticSoilProfile, chartData.Collection.ElementAt(soilProfileIndex), true);
AssertSurfaceLineChartData(surfaceLine, chartData.Collection.ElementAt(surfaceLineIndex));
AssertEntryPointLPointchartData(calculation.InputParameters, surfaceLine, chartData.Collection.ElementAt(entryPointIndex));
AssertExitPointLPointchartData(calculation.InputParameters, surfaceLine, chartData.Collection.ElementAt(exitPointIndex));
AssertCharacteristicPoints(surfaceLine, chartData.Collection.ToList());
}
}
[Test]
public void Data_WithSurfaceLineWithoutStochasticSoilProfile_CollectionOfEmptyChartDataSetForSoilProfile()
{
// Setup
using (var view = new PipingInputView())
{
RingtoetsPipingSurfaceLine surfaceLine = GetSurfaceLineWithGeometry();
var calculation = new PipingCalculationScenario(new GeneralPipingInput())
{
InputParameters =
{
SurfaceLine = surfaceLine
}
};
// Call
view.Data = calculation;
// Assert
Assert.AreSame(calculation, view.Data);
var chartData = view.Chart.Data;
Assert.IsInstanceOf(chartData);
Assert.AreEqual(10, chartData.Collection.Count());
var soilProfileData = (ChartDataCollection) chartData.Collection.ElementAt(soilProfileIndex);
CollectionAssert.IsEmpty(soilProfileData.Collection);
Assert.AreEqual("Ondergrondschematisatie", soilProfileData.Name);
}
}
[Test]
public void Data_WithSurfaceLineWithoutSoilProfile_CollectionOfEmptyChartDataSetForSoilProfile()
{
// Setup
using (var view = new PipingInputView())
{
RingtoetsPipingSurfaceLine surfaceLine = GetSurfaceLineWithGeometry();
var calculation = new PipingCalculationScenario(new GeneralPipingInput())
{
InputParameters =
{
SurfaceLine = surfaceLine,
StochasticSoilProfile = new StochasticSoilProfile(0.5, SoilProfileType.SoilProfile1D, 1)
}
};
// Call
view.Data = calculation;
// Assert
Assert.AreSame(calculation, view.Data);
var chartData = view.Chart.Data;
Assert.IsInstanceOf(chartData);
Assert.AreEqual(10, chartData.Collection.Count());
var soilProfileData = (ChartDataCollection) chartData.Collection.ElementAt(soilProfileIndex);
CollectionAssert.IsEmpty(soilProfileData.Collection);
Assert.AreEqual("Ondergrondschematisatie", soilProfileData.Name);
}
}
[Test]
public void UpdateObserver_CalculationNameUpdated_ChartTitleUpdated()
{
// Setup
using (var view = new PipingInputView())
{
var initialName = "Initial name";
var updatedName = "Updated name";
var calculation = new PipingCalculationScenario(new GeneralPipingInput())
{
Name = initialName
};
view.Data = calculation;
// Precondition
Assert.AreEqual(initialName, view.Chart.ChartTitle);
calculation.Name = updatedName;
// Call
calculation.NotifyObservers();
// Assert
Assert.AreEqual(updatedName, view.Chart.ChartTitle);
}
}
[Test]
public void UpdateObserver_OtherCalculationUpdated_ChartTitleNotUpdated()
{
// Setup
using (var view = new PipingInputView())
{
var initialName = "Initial name";
var updatedName = "Updated name";
var calculation = new PipingCalculationScenario(new GeneralPipingInput())
{
Name = initialName
};
view.Data = calculation;
// Precondition
Assert.AreEqual(initialName, view.Chart.ChartTitle);
var calculation2 = new PipingCalculationScenario(new GeneralPipingInput())
{
Name = initialName
};
view.Data = calculation2;
calculation.Name = updatedName;
// Call
calculation.NotifyObservers();
// Assert
Assert.AreEqual(initialName, view.Chart.ChartTitle);
}
}
[Test]
public void UpdateObserver_CalculationSurfaceLineUpdated_ChartDataUpdated()
{
// Setup
using (var view = new PipingInputView())
{
var characteristicPoint = new Point3D(1.2, 2.3, 4.0);
RingtoetsPipingSurfaceLine surfaceLine = GetSurfaceLineWithGeometry();
surfaceLine.SetDitchDikeSideAt(characteristicPoint);
surfaceLine.SetBottomDitchDikeSideAt(characteristicPoint);
surfaceLine.SetDitchPolderSideAt(characteristicPoint);
surfaceLine.SetBottomDitchPolderSideAt(characteristicPoint);
surfaceLine.SetDikeToeAtPolderAt(characteristicPoint);
surfaceLine.SetDikeToeAtRiverAt(characteristicPoint);
var calculation = new PipingCalculationScenario(new GeneralPipingInput())
{
InputParameters =
{
SurfaceLine = surfaceLine
}
};
view.Data = calculation;
var chartDataList = view.Chart.Data.Collection.ToList();
var surfaceLineChartData = (ChartLineData) chartDataList[surfaceLineIndex];
var entryPointChartData = (ChartPointData) chartDataList[entryPointIndex];
var exitPointChartData = (ChartPointData) chartDataList[exitPointIndex];
var ditchDikeSideData = (ChartPointData) chartDataList[ditchDikeSideIndex];
var bottomDitchDikeSideData = (ChartPointData) chartDataList[bottomDitchDikeSideIndex];
var ditchPolderSideData = (ChartPointData) chartDataList[ditchPolderSideIndex];
var bottomDitchPolderSideData = (ChartPointData) chartDataList[bottomDitchPolderSideIndex];
var dikeToeAtPolderData = (ChartPointData) chartDataList[dikeToeAtPolderIndex];
var dikeToeAtRiverData = (ChartPointData) chartDataList[dikeToeAtRiverIndex];
var characteristicPoint2 = new Point3D(3.5, 2.3, 8.0);
RingtoetsPipingSurfaceLine surfaceLine2 = GetSecondSurfaceLineWithGeometry();
surfaceLine2.SetDitchDikeSideAt(characteristicPoint2);
surfaceLine2.SetBottomDitchDikeSideAt(characteristicPoint2);
surfaceLine2.SetDitchPolderSideAt(characteristicPoint2);
surfaceLine2.SetBottomDitchPolderSideAt(characteristicPoint2);
surfaceLine2.SetDikeToeAtPolderAt(characteristicPoint2);
surfaceLine2.SetDikeToeAtRiverAt(characteristicPoint2);
calculation.InputParameters.SurfaceLine = surfaceLine2;
// Call
calculation.InputParameters.NotifyObservers();
// Assert
chartDataList = view.Chart.Data.Collection.ToList();
Assert.AreSame(surfaceLineChartData, (ChartLineData) chartDataList[surfaceLineIndex]);
Assert.AreSame(entryPointChartData, (ChartPointData) chartDataList[entryPointIndex]);
Assert.AreSame(exitPointChartData, (ChartPointData) chartDataList[exitPointIndex]);
Assert.AreSame(ditchDikeSideData, (ChartPointData) chartDataList[ditchDikeSideIndex]);
Assert.AreSame(bottomDitchDikeSideData, (ChartPointData) chartDataList[bottomDitchDikeSideIndex]);
Assert.AreSame(ditchPolderSideData, (ChartPointData) chartDataList[ditchPolderSideIndex]);
Assert.AreSame(bottomDitchPolderSideData, (ChartPointData) chartDataList[bottomDitchPolderSideIndex]);
Assert.AreSame(dikeToeAtPolderData, (ChartPointData) chartDataList[dikeToeAtPolderIndex]);
Assert.AreSame(dikeToeAtRiverData, (ChartPointData) chartDataList[dikeToeAtRiverIndex]);
AssertSurfaceLineChartData(surfaceLine2, surfaceLineChartData);
AssertEntryPointLPointchartData(calculation.InputParameters, surfaceLine2, entryPointChartData);
AssertExitPointLPointchartData(calculation.InputParameters, surfaceLine2, exitPointChartData);
AssertCharacteristicPoints(surfaceLine2, chartDataList);
}
}
[Test]
public void UpdateObserver_StochasticSoilProfileUpdated_ChartDataUpdated()
{
// Setup
using (var view = new PipingInputView())
{
RingtoetsPipingSurfaceLine surfaceLine = GetSurfaceLineWithGeometry();
StochasticSoilProfile soilProfile = GetStochasticSoilProfile();
var soilProfile2 = new StochasticSoilProfile(0.5, SoilProfileType.SoilProfile1D, 1)
{
SoilProfile = new PipingSoilProfile("profile", -2, new[]
{
new PipingSoilLayer(0),
new PipingSoilLayer(2),
new PipingSoilLayer(3)
}, SoilProfileType.SoilProfile1D, 1)
};
var calculation = new PipingCalculationScenario(new GeneralPipingInput())
{
InputParameters =
{
SurfaceLine = surfaceLine,
StochasticSoilProfile = soilProfile
}
};
view.Data = calculation;
var soilProfileData = (ChartDataCollection) view.Chart.Data.Collection.ElementAt(soilProfileIndex);
calculation.InputParameters.StochasticSoilProfile = soilProfile2;
// Call
calculation.InputParameters.NotifyObservers();
// Assert
Assert.AreSame(soilProfileData, (ChartDataCollection) view.Chart.Data.Collection.ElementAt(soilProfileIndex));
AssertSoilProfileChartData(soilProfile2, soilProfileData, true);
}
}
[Test]
public void UpdateObserver_DataUpdated_ChartSeriesSameOrder()
{
// Setup
const int updatedSoilProfileIndex = soilProfileIndex;
const int updatedSurfaceLineIndex = surfaceLineIndex + 8;
const int updatedDitchPolderSideIndex = ditchPolderSideIndex - 1;
const int updatedBottomDitchPolderSideIndex = bottomDitchPolderSideIndex - 1;
const int updatedBottomDitchDikeSideIndex = bottomDitchDikeSideIndex - 1;
const int updatedDitchDikeSideIndex = ditchDikeSideIndex - 1;
const int updatedDikeToeAtPolderIndex = dikeToeAtPolderIndex - 1;
const int updatedDikeToeAtRiverIndex = dikeToeAtRiverIndex - 1;
const int updatedExitPointIndex = exitPointIndex - 1;
const int updatedEntryPointIndex = entryPointIndex - 1;
var calculation = new PipingCalculationScenario(new GeneralPipingInput());
using (var view = new PipingInputView
{
Data = calculation
})
{
var chartData = view.Chart.Data;
var dataToMove = chartData.Collection.ElementAt(surfaceLineIndex);
chartData.Remove(dataToMove);
chartData.Add(dataToMove);
var chartDataList = chartData.Collection.ToList();
var soilProfileData = (ChartDataCollection) chartDataList[updatedSoilProfileIndex];
var surfaceLineData = (ChartLineData) chartDataList[updatedSurfaceLineIndex];
var entryPointData = (ChartPointData) chartDataList[updatedEntryPointIndex];
var exitPointData = (ChartPointData) chartDataList[updatedExitPointIndex];
var ditchDikeSideData = (ChartPointData) chartDataList[updatedDitchDikeSideIndex];
var bottomDitchDikeSideData = (ChartPointData) chartDataList[updatedBottomDitchDikeSideIndex];
var ditchPolderSideData = (ChartPointData) chartDataList[updatedDitchPolderSideIndex];
var bottomDitchPolderSideData = (ChartPointData) chartDataList[updatedBottomDitchPolderSideIndex];
var dikeToeAtPolderData = (ChartPointData) chartDataList[updatedDikeToeAtPolderIndex];
var dikeToeAtRiverData = (ChartPointData) chartDataList[updatedDikeToeAtRiverIndex];
Assert.AreEqual("Ondergrondschematisatie", soilProfileData.Name);
Assert.AreEqual("Profielschematisatie", surfaceLineData.Name);
Assert.AreEqual("Intredepunt", entryPointData.Name);
Assert.AreEqual("Uittredepunt", exitPointData.Name);
Assert.AreEqual("Insteek sloot dijkzijde", ditchDikeSideData.Name);
Assert.AreEqual("Slootbodem dijkzijde", bottomDitchDikeSideData.Name);
Assert.AreEqual("Insteek sloot polderzijde", ditchPolderSideData.Name);
Assert.AreEqual("Slootbodem polderzijde", bottomDitchPolderSideData.Name);
Assert.AreEqual("Teen dijk binnenwaarts", dikeToeAtPolderData.Name);
Assert.AreEqual("Teen dijk buitenwaarts", dikeToeAtRiverData.Name);
RingtoetsPipingSurfaceLine surfaceLine = GetSurfaceLineWithGeometry();
calculation.InputParameters.SurfaceLine = surfaceLine;
// Call
calculation.InputParameters.NotifyObservers();
// Assert
chartDataList = chartData.Collection.ToList();
var actualSoilProfileData = (ChartDataCollection) chartDataList[updatedSoilProfileIndex];
var actualSurfaceLineData = (ChartLineData) chartDataList[updatedSurfaceLineIndex];
var actualEntryPointData = (ChartPointData) chartDataList[updatedEntryPointIndex];
var actualExitPointData = (ChartPointData) chartDataList[updatedExitPointIndex];
var actualDitchDikeSideData = (ChartPointData) chartDataList[updatedDitchDikeSideIndex];
var actualBottomDitchDikeSideData = (ChartPointData) chartDataList[updatedBottomDitchDikeSideIndex];
var actualDitchPolderSideData = (ChartPointData) chartDataList[updatedDitchPolderSideIndex];
var actualBottomDitchPolderSideData = (ChartPointData) chartDataList[updatedBottomDitchPolderSideIndex];
var actualDikeToeAtPolderData = (ChartPointData) chartDataList[updatedDikeToeAtPolderIndex];
var actualDikeToeAtRiverData = (ChartPointData) chartDataList[updatedDikeToeAtRiverIndex];
Assert.AreEqual("Ondergrondschematisatie", actualSoilProfileData.Name);
Assert.AreEqual(surfaceLine.Name, actualSurfaceLineData.Name);
Assert.AreEqual("Intredepunt", actualEntryPointData.Name);
Assert.AreEqual("Uittredepunt", actualExitPointData.Name);
Assert.AreEqual("Insteek sloot dijkzijde", actualDitchDikeSideData.Name);
Assert.AreEqual("Slootbodem dijkzijde", actualBottomDitchDikeSideData.Name);
Assert.AreEqual("Insteek sloot polderzijde", actualDitchPolderSideData.Name);
Assert.AreEqual("Slootbodem polderzijde", actualBottomDitchPolderSideData.Name);
Assert.AreEqual("Teen dijk binnenwaarts", actualDikeToeAtPolderData.Name);
Assert.AreEqual("Teen dijk buitenwaarts", actualDikeToeAtRiverData.Name);
}
}
[Test]
public void UpdateObserver_OtherCalculationUpdated_ChartDataNotUpdated()
{
// Setup
using (var view = new PipingInputView())
{
RingtoetsPipingSurfaceLine surfaceLine = GetSurfaceLineWithGeometry();
var calculation1 = new PipingCalculationScenario(new GeneralPipingInput())
{
InputParameters =
{
SurfaceLine = surfaceLine
}
};
var calculation2 = new PipingCalculationScenario(new GeneralPipingInput());
view.Data = calculation1;
ChartData dataBeforeUpdate = view.Chart.Data;
view.Data = calculation2;
RingtoetsPipingSurfaceLine surfaceLine2 = GetSecondSurfaceLineWithGeometry();
calculation1.InputParameters.SurfaceLine = surfaceLine2;
// Call
calculation1.InputParameters.NotifyObservers();
// Assert
Assert.AreEqual(dataBeforeUpdate, view.Chart.Data);
}
}
[Test]
public void GivenPipingInputViewWithSoilProfileSeries_WhenSurfaceLineSetToNull_ThenCollectionOfEmptyChartDataSetForSoilProfiles()
{
// Given
using (var view = new PipingInputView())
{
RingtoetsPipingSurfaceLine surfaceLine = GetSurfaceLineWithGeometry();
StochasticSoilProfile stochasticSoilProfile = GetStochasticSoilProfile();
var calculation = new PipingCalculationScenario(new GeneralPipingInput())
{
InputParameters =
{
SurfaceLine = surfaceLine,
StochasticSoilProfile = stochasticSoilProfile
}
};
view.Data = calculation;
var chartData = view.Chart.Data;
// Precondition
Assert.IsNotNull(chartData);
Assert.AreEqual(10, chartData.Collection.Count());
AssertSoilProfileChartData(stochasticSoilProfile, chartData.Collection.ElementAt(soilProfileIndex), true);
// When
calculation.InputParameters.SurfaceLine = null;
calculation.InputParameters.NotifyObservers();
// Then
AssertSoilProfileChartData(stochasticSoilProfile, chartData.Collection.ElementAt(soilProfileIndex), false);
}
}
private static StochasticSoilProfile GetStochasticSoilProfile()
{
return new StochasticSoilProfile(0.5, SoilProfileType.SoilProfile1D, 1)
{
SoilProfile = new PipingSoilProfile("profile", -1, new[]
{
new PipingSoilLayer(1),
new PipingSoilLayer(3),
new PipingSoilLayer(5)
}, SoilProfileType.SoilProfile1D, 1)
};
}
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 static void AssertEmptyChartData(ChartDataCollection chartDataCollection)
{
Assert.AreEqual("Invoer", chartDataCollection.Name);
var chartDatasList = chartDataCollection.Collection.ToList();
Assert.AreEqual(10, chartDatasList.Count);
var soilProfileData = (ChartDataCollection) chartDatasList[soilProfileIndex];
var surfaceLineData = (ChartLineData) chartDatasList[surfaceLineIndex];
var entryPointData = (ChartPointData) chartDatasList[entryPointIndex];
var exitPointData = (ChartPointData) chartDatasList[exitPointIndex];
var ditchDikeSideData = (ChartPointData) chartDatasList[ditchDikeSideIndex];
var bottomDitchDikeSideData = (ChartPointData) chartDatasList[bottomDitchDikeSideIndex];
var ditchPolderSideData = (ChartPointData) chartDatasList[ditchPolderSideIndex];
var bottomDitchPolderSideData = (ChartPointData) chartDatasList[bottomDitchPolderSideIndex];
var dikeToeAtPolderData = (ChartPointData) chartDatasList[dikeToeAtPolderIndex];
var dikeToeAtRiverData = (ChartPointData) chartDatasList[dikeToeAtRiverIndex];
CollectionAssert.IsEmpty(soilProfileData.Collection);
CollectionAssert.IsEmpty(surfaceLineData.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("Ondergrondschematisatie", soilProfileData.Name);
Assert.AreEqual("Profielschematisatie", surfaceLineData.Name);
Assert.AreEqual("Intredepunt", entryPointData.Name);
Assert.AreEqual("Uittredepunt", exitPointData.Name);
Assert.AreEqual("Insteek sloot dijkzijde", ditchDikeSideData.Name);
Assert.AreEqual("Slootbodem dijkzijde", bottomDitchDikeSideData.Name);
Assert.AreEqual("Insteek sloot polderzijde", ditchPolderSideData.Name);
Assert.AreEqual("Slootbodem polderzijde", bottomDitchPolderSideData.Name);
Assert.AreEqual("Teen dijk binnenwaarts", dikeToeAtPolderData.Name);
Assert.AreEqual("Teen dijk buitenwaarts", dikeToeAtRiverData.Name);
}
private static void AssertSoilProfileChartData(StochasticSoilProfile soilProfile, ChartData chartData, bool mapDataShouldContainAreas)
{
Assert.IsInstanceOf(chartData);
var soilProfileChartData = (ChartDataCollection) chartData;
var expectedLayerCount = soilProfile.SoilProfile.Layers.Count();
Assert.AreEqual(expectedLayerCount, soilProfileChartData.Collection.Count());
Assert.AreEqual(soilProfile.SoilProfile.Name, soilProfileChartData.Name);
var pipingSoilLayers = soilProfile.SoilProfile.Layers.Select((l, i) => string.Format("{0} {1}", i + 1, l.MaterialName)).Reverse().ToArray();
for (int i = 0; i < expectedLayerCount; i++)
{
var chartMultipleAreaData = soilProfileChartData.Collection.ElementAt(i) as ChartMultipleAreaData;
Assert.IsNotNull(chartMultipleAreaData);
Assert.AreEqual(pipingSoilLayers[i], chartMultipleAreaData.Name);
Assert.AreEqual(mapDataShouldContainAreas, chartMultipleAreaData.Areas.Any());
}
}
private static void AssertSurfaceLineChartData(RingtoetsPipingSurfaceLine surfaceLine, ChartData chartData)
{
Assert.IsInstanceOf(chartData);
var surfaceLineChartData = (ChartLineData) chartData;
Assert.AreEqual(surfaceLine.Points.Length, surfaceLineChartData.Points.Length);
CollectionAssert.AreEqual(surfaceLine.ProjectGeometryToLZ(), surfaceLineChartData.Points);
Assert.AreEqual(surfaceLine.Name, chartData.Name);
}
private static void AssertEntryPointLPointchartData(PipingInput pipingInput, RingtoetsPipingSurfaceLine surfaceLine, ChartData chartData)
{
Assert.IsInstanceOf(chartData);
var entryPointChartData = (ChartPointData) chartData;
Assert.AreEqual(1, entryPointChartData.Points.Length);
var entryPoint = new Point2D(pipingInput.EntryPointL, surfaceLine.GetZAtL(pipingInput.EntryPointL));
CollectionAssert.AreEqual(new[]
{
entryPoint
}, entryPointChartData.Points);
Assert.AreEqual("Intredepunt", entryPointChartData.Name);
}
private static void AssertExitPointLPointchartData(PipingInput pipingInput, RingtoetsPipingSurfaceLine surfaceLine, ChartData chartData)
{
Assert.IsInstanceOf(chartData);
var exitPointChartData = (ChartPointData) chartData;
Assert.AreEqual(1, exitPointChartData.Points.Length);
var exitPoint = new Point2D(pipingInput.ExitPointL, surfaceLine.GetZAtL(pipingInput.ExitPointL));
CollectionAssert.AreEqual(new[]
{
exitPoint
}, exitPointChartData.Points);
Assert.AreEqual("Uittredepunt", exitPointChartData.Name);
}
private static void AssertCharacteristicPoints(RingtoetsPipingSurfaceLine surfaceLine, IList characteristicPoints)
{
var first = surfaceLine.Points.First();
var last = surfaceLine.Points.Last();
var firstPoint = new Point2D(first.X, first.Y);
var lastPoint = new Point2D(last.X, last.Y);
var ditchDikeSideData = (ChartPointData) characteristicPoints[ditchDikeSideIndex];
Assert.AreEqual(1, ditchDikeSideData.Points.Length);
CollectionAssert.AreEqual(new[]
{
surfaceLine.DitchDikeSide.ProjectIntoLocalCoordinates(firstPoint, lastPoint)
}, ditchDikeSideData.Points);
Assert.AreEqual("Insteek sloot dijkzijde", ditchDikeSideData.Name);
var bottomDitchDikeSideData = (ChartPointData) characteristicPoints[bottomDitchDikeSideIndex];
Assert.AreEqual(1, bottomDitchDikeSideData.Points.Length);
CollectionAssert.AreEqual(new[]
{
surfaceLine.BottomDitchDikeSide.ProjectIntoLocalCoordinates(firstPoint, lastPoint)
}, bottomDitchDikeSideData.Points);
Assert.AreEqual("Slootbodem dijkzijde", bottomDitchDikeSideData.Name);
var ditchPolderSideData = (ChartPointData) characteristicPoints[ditchPolderSideIndex];
Assert.AreEqual(1, ditchPolderSideData.Points.Length);
CollectionAssert.AreEqual(new[]
{
surfaceLine.DitchPolderSide.ProjectIntoLocalCoordinates(firstPoint, lastPoint)
}, ditchPolderSideData.Points);
Assert.AreEqual("Insteek sloot polderzijde", ditchPolderSideData.Name);
var bottomDitchPolderSideData = (ChartPointData) characteristicPoints[bottomDitchPolderSideIndex];
Assert.AreEqual(1, bottomDitchPolderSideData.Points.Length);
CollectionAssert.AreEqual(new[]
{
surfaceLine.BottomDitchPolderSide.ProjectIntoLocalCoordinates(firstPoint, lastPoint)
}, bottomDitchPolderSideData.Points);
Assert.AreEqual("Slootbodem polderzijde", bottomDitchPolderSideData.Name);
var dikeToeAtPolderData = (ChartPointData) characteristicPoints[dikeToeAtPolderIndex];
Assert.AreEqual(1, dikeToeAtPolderData.Points.Length);
CollectionAssert.AreEqual(new[]
{
surfaceLine.DikeToeAtPolder.ProjectIntoLocalCoordinates(firstPoint, lastPoint)
}, dikeToeAtPolderData.Points);
Assert.AreEqual("Teen dijk binnenwaarts", dikeToeAtPolderData.Name);
var dikeToeAtRiverData = (ChartPointData) characteristicPoints[dikeToeAtRiverIndex];
Assert.AreEqual(1, dikeToeAtRiverData.Points.Length);
CollectionAssert.AreEqual(new[]
{
surfaceLine.DikeToeAtRiver.ProjectIntoLocalCoordinates(firstPoint, lastPoint)
}, dikeToeAtRiverData.Points);
Assert.AreEqual("Teen dijk buitenwaarts", dikeToeAtRiverData.Name);
}
}
}