private void SetDikeProfilesMapData() { IEnumerable <DikeProfile> dikeProfiles = FailureMechanism.DikeProfiles; dikeProfilesMapData.Features = RiskeerMapDataFeaturesFactory.CreateDikeProfilesFeatures(dikeProfiles); foreshoreProfilesMapData.Features = RiskeerMapDataFeaturesFactory.CreateForeshoreProfilesFeatures(dikeProfiles.Select(dp => dp.ForeshoreProfile)); }
public void CreateDikeProfilesFeatures_NullDikeProfiles_ReturnsEmptyCollection() { // Call IEnumerable <MapFeature> features = RiskeerMapDataFeaturesFactory.CreateDikeProfilesFeatures(null); // Assert CollectionAssert.IsEmpty(features); }
public void CreateDikeProfilesFeatures_WithDikeProfiles_ReturnsCollectionWithDikeProfiles() { // Setup var pointA = new Point2D(1.2, 2.3); var pointB = new Point2D(2.7, 2.0); var pointC = new Point2D(3.2, 23.3); var pointD = new Point2D(7.7, 12.6); var pointE = new Point2D(1.3, 2.3); var pointF = new Point2D(4.6, 2.0); var pointG = new Point2D(6.3, 23.3); var pointH = new Point2D(4.2, 12.6); var roughnessPointsOne = new[] { new RoughnessPoint(pointA, 1), new RoughnessPoint(pointB, 2) }; Point2D[] pointsOne = { pointC, pointD }; var roughnessPointsTwo = new[] { new RoughnessPoint(pointE, 1), new RoughnessPoint(pointF, 2), new RoughnessPoint(pointG, 1), new RoughnessPoint(pointH, 2) }; var dikeProfiles = new[] { new DikeProfile(new Point2D(5, 4), roughnessPointsOne, pointsOne, null, new DikeProfile.ConstructionProperties { Id = "A" }), new DikeProfile(new Point2D(2, 1), roughnessPointsTwo, Enumerable.Empty <Point2D>(), null, new DikeProfile.ConstructionProperties { Id = "bid", Name = "B" }) }; // Call IEnumerable <MapFeature> features = RiskeerMapDataFeaturesFactory.CreateDikeProfilesFeatures(dikeProfiles); // Assert Assert.AreEqual(2, features.Count()); Assert.AreEqual(1, features.First().MapGeometries.Count()); Assert.AreEqual(1, features.ElementAt(1).MapGeometries.Count()); Point2D[] mapDataDikeGeometryOne = features.First().MapGeometries.ElementAt(0).PointCollections.First().ToArray(); Point2D[] mapDataDikeGeometryTwo = features.ElementAt(1).MapGeometries.ElementAt(0).PointCollections.First().ToArray(); CollectionElementsAlmostEquals(new[] { new Point2D(5, 2.8), new Point2D(5, 1.3) }, mapDataDikeGeometryOne); CollectionElementsAlmostEquals(new[] { new Point2D(2, -0.3), new Point2D(2, -3.6), new Point2D(2, -5.3), new Point2D(2, -3.2) }, mapDataDikeGeometryTwo); const int expectedNumberOfMetaDataOptions = 1; Assert.AreEqual(expectedNumberOfMetaDataOptions, features.First().MetaData.Count); Assert.AreEqual(expectedNumberOfMetaDataOptions, features.ElementAt(1).MetaData.Count); Assert.AreEqual(dikeProfiles[0].Name, features.First().MetaData["Naam"]); Assert.AreEqual(dikeProfiles[1].Name, features.ElementAt(1).MetaData["Naam"]); }