// 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.IO;
using System.Linq;
using System.Xml;
using Core.Common.TestUtil;
using NUnit.Framework;
using Rhino.Mocks;
using Ringtoets.Common.Data.Calculation;
using Ringtoets.Common.IO.Configurations;
using Ringtoets.Common.IO.TestUtil;
using Ringtoets.Common.IO.Writers;
namespace Ringtoets.Common.IO.Test.Writers
{
[TestFixture]
public class SchemaCalculationConfigurationWriterTest
: CustomSchemaCalculationConfigurationWriterDesignGuidelinesTestFixture<
TestSchemaCalculationConfigurationWriter,
TestConfigurationItem>
{
[Test]
[TestCaseSource(nameof(GetCalculationConfigurations))]
public void Write_DifferentCalculationAndCalculationGroupConfigurations_ValidFile(IEnumerable configuration, string expectedFileContentsFileName)
{
// Setup
string filePath = TestHelper.GetScratchPadPath("test.xml");
string expectedXmlFilePath = TestHelper.GetTestDataPath(
TestDataPath.Ringtoets.Common.IO,
Path.Combine(nameof(CalculationConfigurationWriter), expectedFileContentsFileName));
try
{
// Call
new TestSchemaCalculationConfigurationWriter(filePath).Write(configuration);
// Assert
Assert.IsTrue(File.Exists(filePath));
string actualXml = File.ReadAllText(filePath);
string expectedXml = File.ReadAllText(expectedXmlFilePath);
Assert.AreEqual(expectedXml, actualXml);
}
finally
{
File.Delete(filePath);
}
}
[Test]
public void WriteDistributionWhenAvailable_MeanStandardDeviationStochastConfigurationNull_WriterNotCalled()
{
// Setup
var mocks = new MockRepository();
var xmlWriter = mocks.StrictMock();
mocks.ReplayAll();
// Call
ExposedSchemaCalculationConfigurationWriter.PublicWriteDistributionWhenAvailable(
xmlWriter,
"some name",
(MeanStandardDeviationStochastConfiguration)null);
// Assert
mocks.VerifyAll();
}
[Test]
public void WriteDistributionWhenAvailable_MeanStandardDeviationStochastConfigurationSet_WriterCalledWithExpectedParameters()
{
// Setup
const string name = "some name";
var configuration = new MeanStandardDeviationStochastConfiguration();
var mocks = new MockRepository();
var xmlWriter = mocks.StrictMock();
xmlWriter.Expect(w => w.WriteDistribution(name, configuration));
mocks.ReplayAll();
// Call
ExposedSchemaCalculationConfigurationWriter.PublicWriteDistributionWhenAvailable(
xmlWriter,
name,
configuration);
// Assert
mocks.VerifyAll();
}
[Test]
public void WriteDistributionWhenAvailable_MeanVariationCoefficientStochastConfigurationNull_WriterNotCalled()
{
// Setup
var mocks = new MockRepository();
var xmlWriter = mocks.StrictMock();
mocks.ReplayAll();
// Call
ExposedSchemaCalculationConfigurationWriter.PublicWriteDistributionWhenAvailable(
xmlWriter,
"some name",
(MeanVariationCoefficientStochastConfiguration)null);
// Assert
mocks.VerifyAll();
}
[Test]
public void WriteDistributionWhenAvailable_MeanVariationCoefficientStochastConfigurationSet_WriterCalledWithExpectedParameters()
{
// Setup
const string name = "some name";
var configuration = new MeanVariationCoefficientStochastConfiguration();
var mocks = new MockRepository();
var xmlWriter = mocks.StrictMock();
xmlWriter.Expect(w => w.WriteDistribution(name, configuration));
mocks.ReplayAll();
// Call
ExposedSchemaCalculationConfigurationWriter.PublicWriteDistributionWhenAvailable(
xmlWriter,
name,
configuration);
// Assert
mocks.VerifyAll();
}
[Test]
public void WriteElementWhenContentAvailable_StringNull_WriterNotCalled()
{
// Setup
var mocks = new MockRepository();
var xmlWriter = mocks.StrictMock();
mocks.ReplayAll();
// Call
ExposedSchemaCalculationConfigurationWriter.PublicWriteElementWhenContentAvailable(
xmlWriter,
"some name",
(string)null);
// Assert
mocks.VerifyAll();
}
[Test]
public void WriteElementWhenContentAvailable_StringSet_WriterCalledWithExpectedParameters()
{
// Setup
const string name = "some name";
const string value = "some value";
var mocks = new MockRepository();
var xmlWriter = mocks.StrictMock();
xmlWriter.Expect(w => w.WriteElementString(name, value));
mocks.ReplayAll();
// Call
ExposedSchemaCalculationConfigurationWriter.PublicWriteElementWhenContentAvailable(
xmlWriter,
name,
value);
// Assert
mocks.VerifyAll();
}
[Test]
public void WriteElementWhenContentAvailable_DoubleNull_WriterNotCalled()
{
// Setup
var mocks = new MockRepository();
var xmlWriter = mocks.StrictMock();
mocks.ReplayAll();
// Call
ExposedSchemaCalculationConfigurationWriter.PublicWriteElementWhenContentAvailable(
xmlWriter,
"some name",
(double?)null);
// Assert
mocks.VerifyAll();
}
[Test]
public void WriteElementWhenContentAvailable_DoubleSet_WriterCalledWithExpectedParameters()
{
// Setup
const string name = "some name";
const double value = 3.2;
var mocks = new MockRepository();
var xmlWriter = mocks.StrictMock();
xmlWriter.Expect(w => w.WriteElementString(name, XmlConvert.ToString(value)));
mocks.ReplayAll();
// Call
ExposedSchemaCalculationConfigurationWriter.PublicWriteElementWhenContentAvailable(
xmlWriter,
name,
value);
// Assert
mocks.VerifyAll();
}
[Test]
public void WriteWaveReductionWhenAvailable_WaveReductionConfigurationNull_WriterNotCalled()
{
// Setup
var mocks = new MockRepository();
var xmlWriter = mocks.StrictMock();
mocks.ReplayAll();
// Call
ExposedSchemaCalculationConfigurationWriter.PublicWriteWaveReductionWhenAvailable(
xmlWriter,
null);
// Assert
mocks.VerifyAll();
}
[Test]
public void WriteWaveReductionWhenAvailable_WaveReductionConfigurationSet_WriterCalledWithExpectedParameters()
{
// Setup
var configuration = new WaveReductionConfiguration();
var mocks = new MockRepository();
var xmlWriter = mocks.StrictMock();
xmlWriter.Expect(w => w.WriteWaveReduction(configuration));
mocks.ReplayAll();
// Call
ExposedSchemaCalculationConfigurationWriter.PublicWriteWaveReductionWhenAvailable(
xmlWriter,
configuration);
// Assert
mocks.VerifyAll();
}
private static IEnumerable GetCalculationConfigurations()
{
var calculation1 = new TestConfigurationItem
{
Name = "calculation1"
};
var calculation2 = new TestConfigurationItem
{
Name = "calculation2"
};
var calculationGroup1 = new CalculationGroupConfiguration("group1", Enumerable.Empty());
var calculationGroup2 = new CalculationGroupConfiguration("group2", new IConfigurationItem[]
{
calculation2,
calculationGroup1
});
yield return new TestCaseData(
new[]
{
calculationGroup1
},
"singleGroup.xml")
.SetName("Single group");
yield return new TestCaseData(
new[]
{
calculation1
},
"singleCalculation.xml")
.SetName("Single calculation");
yield return new TestCaseData(
new IConfigurationItem[]
{
calculationGroup1,
calculation1
},
"calculationGroupAndCalculation.xml")
.SetName("Calculation group and calculation");
yield return new TestCaseData(
new IConfigurationItem[]
{
calculation1,
calculationGroup2
},
"calculationAndGroupWithNesting.xml")
.SetName("Calculation and group with nesting");
}
protected override TestSchemaCalculationConfigurationWriter CreateWriterInstance(string filePath)
{
return new TestSchemaCalculationConfigurationWriter(filePath);
}
}
public class ExposedSchemaCalculationConfigurationWriter : SchemaCalculationConfigurationWriter
{
public ExposedSchemaCalculationConfigurationWriter(string filePath) : base(filePath) {}
public static void PublicWriteDistributionWhenAvailable(XmlWriter writer, string distributionName, MeanVariationCoefficientStochastConfiguration configuration)
{
WriteDistributionWhenAvailable(writer, distributionName, configuration);
}
public static void PublicWriteDistributionWhenAvailable(XmlWriter writer, string distributionName, MeanStandardDeviationStochastConfiguration configuration)
{
WriteDistributionWhenAvailable(writer, distributionName, configuration);
}
public static void PublicWriteElementWhenContentAvailable(XmlWriter writer, string elementName, string elementContent)
{
WriteElementWhenContentAvailable(writer, elementName, elementContent);
}
public static void PublicWriteElementWhenContentAvailable(XmlWriter writer, string elementName, double? elementContent)
{
WriteElementWhenContentAvailable(writer, elementName, elementContent);
}
public static void PublicWriteWaveReductionWhenAvailable(XmlWriter writer, WaveReductionConfiguration configuration)
{
WriteWaveReductionWhenAvailable(writer, configuration);
}
protected override void WriteCalculation(TestConfigurationItem calculation, XmlWriter writer)
{
throw new System.NotImplementedException();
}
}
}