// 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.ComponentModel;
using System.Globalization;
using System.Linq;
using Core.Common.Base.Geometry;
using Core.Common.Gui.Attributes;
using Core.Common.Gui.PropertyBag;
using NUnit.Framework;
using Rhino.Mocks;
using Ringtoets.HydraRing.Data;
using Ringtoets.Integration.Forms.PropertyClasses;
namespace Ringtoets.Integration.Forms.Test.PropertyClasses
{
[TestFixture]
public class HydraulicBoundaryLocationWaveHeightPropertiesTest
{
[Test]
public void GetProperties_ValidData_ReturnsExpectedValues()
{
// Setup
const long id = 1234;
const double x = 567.0;
const double y = 890.0;
const string name = "";
var hydraulicBoundaryLocation =new HydraulicBoundaryLocation(id, name, x, y);
// Call
var properties = new HydraulicBoundaryLocationWaveHeightProperties(hydraulicBoundaryLocation);
// Assert
Assert.AreEqual(id, properties.Id);
Assert.AreEqual(name, properties.Name);
Point2D coordinates = new Point2D(x, y);
Assert.AreEqual(coordinates, properties.Location);
Assert.AreEqual(string.Empty, properties.WaveHeight);
}
[Test]
public void GetProperties_ValidWaveHeight_ReturnsExpectedValues()
{
// Setup
const long id = 1234L;
const double x = 567.0;
const double y = 890.0;
const string name = "";
const double waveHeight = 5.123456;
var hydraulicBoundaryLocation = new HydraulicBoundaryLocation(id, name, x, y)
{
WaveHeight = waveHeight
};
// Call
var properties = new HydraulicBoundaryLocationWaveHeightProperties(hydraulicBoundaryLocation);
// Assert
Assert.AreEqual(id, properties.Id);
Assert.AreEqual(name, properties.Name);
Point2D coordinates = new Point2D(x, y);
Assert.AreEqual(coordinates, properties.Location);
string expectedWaveHeight = waveHeight.ToString("F2", CultureInfo.InvariantCulture);
Assert.AreEqual(expectedWaveHeight, properties.WaveHeight);
}
[Test]
public void PropertyAttributes_ReturnExpectedValues()
{
// Setup
var hydraulicBoundaryLocation = new HydraulicBoundaryLocation(0, "", 0.0, 0.0);
var properties = new HydraulicBoundaryLocationWaveHeightProperties(hydraulicBoundaryLocation);
// Call
TypeConverter classTypeConverter = TypeDescriptor.GetConverter(properties, true);
// Assert
var dynamicPropertyBag = new DynamicPropertyBag(properties);
const string expectedIdDisplayName = "ID";
const string expectedNameDisplayName = "Naam";
const string expectedLocationDisplayName = "Coördinaten [m]";
const string expectedWaveHeightDisplayName = "Hs [m]";
const string expectedIdDescription = "Id van de hydraulische randvoorwaardenlocatie in de database.";
const string expectedNameDescription = "Naam van de hydraulische randvoorwaardenlocatie.";
const string expectedLocationDescription = "Coördinaten van de hydraulische randvoorwaardenlocatie.";
const string expectedWaveHeightDescription = "Berekende golfhoogte.";
PropertyDescriptorCollection dynamicProperties = dynamicPropertyBag.GetProperties();
PropertyDescriptor idProperty = dynamicProperties.Find("Id", false);
PropertyDescriptor nameProperty = dynamicProperties.Find("Name", false);
PropertyDescriptor locationProperty = dynamicProperties.Find("Location", false);
PropertyDescriptor waveHeightProperty = dynamicProperties.Find("WaveHeight", false);
Assert.IsInstanceOf(classTypeConverter);
Assert.IsNotNull(idProperty);
Assert.IsTrue(idProperty.IsReadOnly);
Assert.IsTrue(idProperty.IsBrowsable);
Assert.AreEqual(expectedIdDisplayName, idProperty.DisplayName);
Assert.AreEqual(expectedIdDescription, idProperty.Description);
Assert.AreEqual(1, idProperty.Attributes.OfType().First().Order);
Assert.IsNotNull(nameProperty);
Assert.IsTrue(nameProperty.IsReadOnly);
Assert.IsTrue(nameProperty.IsBrowsable);
Assert.AreEqual(expectedNameDisplayName, nameProperty.DisplayName);
Assert.AreEqual(expectedNameDescription, nameProperty.Description);
Assert.AreEqual(2, nameProperty.Attributes.OfType().First().Order);
Assert.IsNotNull(locationProperty);
Assert.IsTrue(locationProperty.IsReadOnly);
Assert.IsTrue(locationProperty.IsBrowsable);
Assert.AreEqual(expectedLocationDisplayName, locationProperty.DisplayName);
Assert.AreEqual(expectedLocationDescription, locationProperty.Description);
Assert.AreEqual(3, locationProperty.Attributes.OfType().First().Order);
Assert.IsNotNull(waveHeightProperty);
Assert.IsTrue(waveHeightProperty.IsReadOnly);
Assert.IsTrue(waveHeightProperty.IsBrowsable);
Assert.AreEqual(expectedWaveHeightDisplayName, waveHeightProperty.DisplayName);
Assert.AreEqual(expectedWaveHeightDescription, waveHeightProperty.Description);
Assert.AreEqual(4, waveHeightProperty.Attributes.OfType().First().Order);
}
}
}