// 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 Core.Common.Base;
using Core.Common.Controls.PresentationObjects;
using Core.Common.TestUtil;
using NUnit.Framework;
using Rhino.Mocks;
using Ringtoets.Common.Data.AssessmentSection;
using Ringtoets.Common.Data.Hydraulics;
using Ringtoets.Integration.Forms.PresentationObjects;
namespace Ringtoets.Integration.Forms.Test.PresentationObjects
{
[TestFixture]
public class DesignWaterLevelLocationsContextTest
{
[Test]
public void Constructor_ExpectedValues()
{
// Setup
var mockRepository = new MockRepository();
var assessmentSection = mockRepository.Stub();
mockRepository.ReplayAll();
var locations = new ObservableList();
Func calculationFunc = hbl => null;
const string categoryBoundaryName = "Test name";
// Call
var presentationObject = new DesignWaterLevelLocationsContext(locations,
assessmentSection,
calculationFunc,
categoryBoundaryName);
// Assert
Assert.IsInstanceOf>>(presentationObject);
Assert.AreSame(locations, presentationObject.WrappedData);
Assert.AreSame(assessmentSection, presentationObject.AssessmentSection);
Assert.AreSame(calculationFunc, presentationObject.GetCalculationFunc);
Assert.AreEqual(categoryBoundaryName, presentationObject.CategoryBoundaryName);
mockRepository.VerifyAll();
}
[Test]
public void Constructor_AssessmentSectionNull_ThrowsArgumentNullException()
{
// Call
TestDelegate call = () => new DesignWaterLevelLocationsContext(new ObservableList(),
null,
hbl => null,
"Test name");
// Assert
var exception = Assert.Throws(call);
Assert.AreEqual("assessmentSection", exception.ParamName);
}
[Test]
public void Constructor_GetCalculationFuncNull_ThrowsArgumentNullException()
{
// Setup
var mockRepository = new MockRepository();
var assessmentSection = mockRepository.Stub();
mockRepository.ReplayAll();
// Call
TestDelegate call = () => new DesignWaterLevelLocationsContext(new ObservableList(),
assessmentSection,
null,
"Test name");
// Assert
var exception = Assert.Throws(call);
Assert.AreEqual("getCalculationFunc", exception.ParamName);
}
[Test]
public void Constructor_CategoryBoundaryNameNull_ThrowsArgumentException()
{
// Setup
var mockRepository = new MockRepository();
var assessmentSection = mockRepository.Stub();
mockRepository.ReplayAll();
// Call
TestDelegate call = () => new DesignWaterLevelLocationsContext(new ObservableList(),
assessmentSection,
hbl => null,
null);
// Assert
var exception = Assert.Throws(call);
Assert.AreEqual("'categoryBoundaryName' must have a value.", exception.Message);
}
[Test]
public void Constructor_CategoryBoundaryNameEmpty_ThrowsArgumentException()
{
// Setup
var mockRepository = new MockRepository();
var assessmentSection = mockRepository.Stub();
mockRepository.ReplayAll();
// Call
TestDelegate call = () => new DesignWaterLevelLocationsContext(new ObservableList(),
assessmentSection,
hbl => null,
string.Empty);
// Assert
var exception = Assert.Throws(call);
Assert.AreEqual("'categoryBoundaryName' must have a value.", exception.Message);
}
[TestFixture]
private class DesignWaterLevelLocationsContextEqualsTest
: EqualsTestFixture
{
private static readonly MockRepository mocks = new MockRepository();
private static readonly IAssessmentSection assessmentSection = mocks.Stub();
private static readonly ObservableList hydraulicBoundaryLocations = new ObservableList();
private static readonly Func getCalculationFunc = hbl => null;
private static readonly string categoryBoundaryName = "Test name";
[SetUp]
public void SetUp()
{
mocks.ReplayAll();
}
[TearDown]
public void TearDown()
{
mocks.VerifyAll();
}
protected override DesignWaterLevelLocationsContext CreateObject()
{
return new DesignWaterLevelLocationsContext(hydraulicBoundaryLocations,
assessmentSection,
getCalculationFunc,
categoryBoundaryName);
}
protected override DerivedDesignWaterLevelLocationsContext CreateDerivedObject()
{
return new DerivedDesignWaterLevelLocationsContext(hydraulicBoundaryLocations,
assessmentSection,
getCalculationFunc,
categoryBoundaryName);
}
private static IEnumerable GetUnequalTestCases()
{
yield return new TestCaseData(new DesignWaterLevelLocationsContext(hydraulicBoundaryLocations,
assessmentSection,
getCalculationFunc,
"Other"))
.SetName("CategoryBoundaryName");
}
}
private class DerivedDesignWaterLevelLocationsContext : DesignWaterLevelLocationsContext
{
public DerivedDesignWaterLevelLocationsContext(ObservableList wrappedData,
IAssessmentSection assessmentSection,
Func getCalculationFunc,
string categoryBoundaryName)
: base(wrappedData,
assessmentSection,
getCalculationFunc,
categoryBoundaryName) {}
}
}
}