// Copyright (C) Stichting Deltares 2017. 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.Collections.Generic; using System.Globalization; using System.IO; using System.Linq; using System.Reflection; using System.Text; using System.Xml.Linq; using System.Xml.Schema; using System.Xml.Serialization; using Core.Common.Base.Geometry; using Core.Common.Util.Reflection; using NUnit.Framework; using Ringtoets.AssemblyTool.IO.Model; using Ringtoets.AssemblyTool.IO.Model.DataTypes; using Ringtoets.AssemblyTool.IO.Model.Enums; using Ringtoets.AssemblyTool.IO.TestUtil; namespace Ringtoets.AssemblyTool.IO.Test.Model { [TestFixture] public class SerializableAssemblyTest { [Test] public void DefaultConstructor_ReturnsDefaultValues() { // Call var assembly = new SerializableAssembly(); // Assert Assert.IsNull(assembly.Id); Assert.IsNull(assembly.Boundary); Assert.IsNull(assembly.FeatureMembers); object[] serializableAttributes = typeof(SerializableAssembly).GetCustomAttributes(typeof(SerializableAttribute), false); Assert.AreEqual(1, serializableAttributes.Length); var xmlRootAttribute = (XmlRootAttribute) typeof(SerializableAssembly).GetCustomAttributes(typeof(XmlRootAttribute), false).Single(); Assert.AreEqual("Assemblage", xmlRootAttribute.ElementName); Assert.AreEqual("http://localhost/standaarden/assemblage", xmlRootAttribute.Namespace); const string gmlNamespace = "http://www.opengis.net/gml/3.2"; SerializableAttributeTestHelper.AssertXmlAttributeAttribute( nameof(SerializableAssembly.Id), "id", gmlNamespace); SerializableAttributeTestHelper.AssertXmlElementAttribute( nameof(SerializableAssembly.Boundary), "boundedBy", gmlNamespace); XmlArrayAttribute xmlArrayAttribute = TypeUtils.GetPropertyAttributes(nameof(SerializableAssembly.FeatureMembers)).Single(); Assert.AreEqual("featureMember", xmlArrayAttribute.ElementName); IEnumerable xmlArrayItemAttributes = TypeUtils.GetPropertyAttributes(nameof(SerializableAssembly.FeatureMembers)); Assert.AreEqual(8, xmlArrayItemAttributes.Count()); Assert.AreEqual(typeof(SerializableAssessmentProcess), xmlArrayItemAttributes.ElementAt(0).Type); Assert.AreEqual(typeof(SerializableAssessmentSection), xmlArrayItemAttributes.ElementAt(1).Type); Assert.AreEqual(typeof(SerializableTotalAssemblyResult), xmlArrayItemAttributes.ElementAt(2).Type); Assert.AreEqual(typeof(SerializableFailureMechanism), xmlArrayItemAttributes.ElementAt(3).Type); Assert.AreEqual(typeof(SerializableFailureMechanismSectionAssembly), xmlArrayItemAttributes.ElementAt(4).Type); Assert.AreEqual(typeof(SerializableFailureMechanismSections), xmlArrayItemAttributes.ElementAt(5).Type); Assert.AreEqual(typeof(SerializableFailureMechanismSection), xmlArrayItemAttributes.ElementAt(6).Type); Assert.AreEqual(typeof(SerializableCombinedFailureMechanismSectionAssembly), xmlArrayItemAttributes.ElementAt(7).Type); } [Test] public void Constructor_IdNull_ThrowsArgumentNullException() { // Setup var random = new Random(39); // Call TestDelegate call = () => new SerializableAssembly(null, new Point2D(random.NextDouble(), random.NextDouble()), new Point2D(random.NextDouble(), random.NextDouble()), new SerializableFeatureMember[0]); // Assert var exception = Assert.Throws(call); Assert.AreEqual("id", exception.ParamName); } [Test] public void Constructor_LowerCornerNull_ThrowsArgumentNullException() { // Setup var random = new Random(39); // Call TestDelegate call = () => new SerializableAssembly(string.Empty, null, new Point2D(random.NextDouble(), random.NextDouble()), new SerializableFeatureMember[0]); // Assert var exception = Assert.Throws(call); Assert.AreEqual("lowerCorner", exception.ParamName); } [Test] public void Constructor_UpperCornerNull_ThrowsArgumentNullException() { // Setup var random = new Random(39); // Call TestDelegate call = () => new SerializableAssembly(string.Empty, new Point2D(random.NextDouble(), random.NextDouble()), null, new SerializableFeatureMember[0]); // Assert var exception = Assert.Throws(call); Assert.AreEqual("upperCorner", exception.ParamName); } [Test] public void Constructor_FeatureMembersNull_ThrowsArgumentNullException() { // Setup var random = new Random(39); // Call TestDelegate call = () => new SerializableAssembly(string.Empty, new Point2D(random.NextDouble(), random.NextDouble()), new Point2D(random.NextDouble(), random.NextDouble()), null); // Assert var exception = Assert.Throws(call); Assert.AreEqual("featureMembers", exception.ParamName); } [Test] public void Constructor_WithValidData_ReturnsExpectedValues() { // Setup const string id = "assembly id 1"; var random = new Random(39); var lowerCorner = new Point2D(random.NextDouble(), random.NextDouble()); var upperCorner = new Point2D(random.NextDouble(), random.NextDouble()); var featureMember = new TestFeatureMember(); // Call var assembly = new SerializableAssembly(id, lowerCorner, upperCorner, new SerializableFeatureMember[] { featureMember }); // Assert Assert.AreEqual(id, assembly.Id); Assert.AreEqual(lowerCorner.X.ToString(CultureInfo.InvariantCulture) + " " + lowerCorner.Y.ToString(CultureInfo.InvariantCulture), assembly.Boundary.Envelope.LowerCorner); Assert.AreEqual(upperCorner.X.ToString(CultureInfo.InvariantCulture) + " " + upperCorner.Y.ToString(CultureInfo.InvariantCulture), assembly.Boundary.Envelope.UpperCorner); Assert.AreSame(featureMember, assembly.FeatureMembers.Single()); } [Test] public void GivenAssembly_WhenExported_ReturnsSerializedObject() { var serializer = new XmlSerializer(typeof(SerializableAssembly)); var xmlns = new XmlSerializerNamespaces(); xmlns.Add("gml", AssemblyXmlIdentifiers.GmlNamespace); xmlns.Add("asm", AssemblyXmlIdentifiers.AssemblyNamespace); var writer = new StringWriterUtf8(); var assessmentSection = new SerializableAssessmentSection { Id = "section1", SurfaceLineLength = new SerializableMeasure { UnitOfMeasure = "m", Value = 100 }, Name = "Traject A", SurfaceLineGeometry = new SerializableLine(new[] { new Point2D(0.35, 10.642), new Point2D(10.1564, 20.23) }) }; var assessmentProcess = new SerializableAssessmentProcess("beoordelingsproces1", assessmentSection, 2018, 2020); var totalAssemblyResult = new SerializableTotalAssemblyResult( "veiligheidsoordeel_1", assessmentProcess, new SerializableFailureMechanismAssemblyResult(SerializableAssemblyMethod.WBI2B1, SerializableFailureMechanismCategoryGroup.IIt), new SerializableFailureMechanismAssemblyResult(SerializableAssemblyMethod.WBI3C1, SerializableFailureMechanismCategoryGroup.NotApplicable, 0.000124), new SerializableAssessmentSectionAssemblyResult(SerializableAssemblyMethod.WBI2C1, SerializableAssessmentSectionCategoryGroup.B)); var failureMechanism1 = new SerializableFailureMechanism("toetsspoorGABI", totalAssemblyResult, SerializableFailureMechanismType.GABI, SerializableAssemblyGroup.Group4, new SerializableFailureMechanismAssemblyResult(SerializableAssemblyMethod.WBI1A1, SerializableFailureMechanismCategoryGroup.IIt)); var sections1 = new SerializableFailureMechanismSections("vakindelingGABI", failureMechanism1); var section1 = new SerializableFailureMechanismSection("vak_GABI_1", sections1, 0.12, 10.23, new[] { new Point2D(0.23, 0.24), new Point2D(10.23, 10.24) }); var result1 = new SerializableFailureMechanismSectionAssembly("resultaat_GABI_1", failureMechanism1, section1, new[] { new SerializableFailureMechanismSectionAssemblyResult(SerializableAssemblyMethod.WBI0E1, SerializableAssessmentLevel.SimpleAssessment, SerializableFailureMechanismSectionCategoryGroup.IIv, 0.5), new SerializableFailureMechanismSectionAssemblyResult(SerializableAssemblyMethod.WBI0T5, SerializableAssessmentLevel.TailorMadeAssessment, SerializableFailureMechanismSectionCategoryGroup.IIIv) }, new SerializableFailureMechanismSectionAssemblyResult(SerializableAssemblyMethod.WBI0A1, SerializableAssessmentLevel.CombinedAssessment, SerializableFailureMechanismSectionCategoryGroup.IIIv)); var sections2 = new SerializableFailureMechanismSections("vakindeling_gecombineerd", totalAssemblyResult); var section2 = new SerializableFailureMechanismSection("vak_gecombineerd_1", sections2, 0.12, 10.23, new[] { new Point2D(0.23, 0.24), new Point2D(10.23, 10.24) }, SerializableAssemblyMethod.WBI3B1); var combinedResult = new SerializableCombinedFailureMechanismSectionAssembly("resultaat_gecombineerd_1", totalAssemblyResult, section2, new[] { new SerializableCombinedFailureMechanismSectionAssemblyResult(SerializableAssemblyMethod.WBI3C1, SerializableFailureMechanismType.HTKW, SerializableFailureMechanismSectionCategoryGroup.IIIv), new SerializableCombinedFailureMechanismSectionAssemblyResult(SerializableAssemblyMethod.WBI3C1, SerializableFailureMechanismType.STPH, SerializableFailureMechanismSectionCategoryGroup.IVv) }, new SerializableFailureMechanismSectionAssemblyResult(SerializableAssemblyMethod.WBI3B1, SerializableAssessmentLevel.CombinedSectionAssessment, SerializableFailureMechanismSectionCategoryGroup.VIv)); var assembly = new SerializableAssembly("assemblage_1", new Point2D(12.0, 34.0), new Point2D(56.053, 78.0002345), new SerializableFeatureMember[] { assessmentSection, assessmentProcess, totalAssemblyResult, failureMechanism1, result1, combinedResult, sections1, sections2, section1, section2 }); serializer.Serialize(writer, assembly, xmlns); string xml = writer.ToString(); Console.WriteLine(xml); var schema = new XmlSchemaSet(); Assembly ass = Assembly.GetExecutingAssembly(); string path = Path.GetDirectoryName(ass.Location); schema.Add("http://localhost/standaarden/assemblage", Path.Combine(path, "assemblage.xsd")); XDocument doc = XDocument.Parse(xml); var msg = ""; doc.Validate(schema, (o, e) => { msg += e.Message + Environment.NewLine; }); Console.WriteLine(msg == "" ? "Document is valid" : "Document invalid: " + msg); } public class StringWriterUtf8 : StringWriter { public override Encoding Encoding { get { return Encoding.UTF8; } } } private class TestFeatureMember : SerializableFeatureMember {} } }