Index: Ringtoets/HydraRing/test/Ringtoets.HydraRing.Calculation.Test/Parsers/TargetProbabilityCalculationParserTest.cs =================================================================== diff -u -rde4477561032a5d95d5e65e50b719724466648ed -r3d9b418d483c122040e11a7e074d666c64e9d7b5 --- Ringtoets/HydraRing/test/Ringtoets.HydraRing.Calculation.Test/Parsers/TargetProbabilityCalculationParserTest.cs (.../TargetProbabilityCalculationParserTest.cs) (revision de4477561032a5d95d5e65e50b719724466648ed) +++ Ringtoets/HydraRing/test/Ringtoets.HydraRing.Calculation.Test/Parsers/TargetProbabilityCalculationParserTest.cs (.../TargetProbabilityCalculationParserTest.cs) (revision 3d9b418d483c122040e11a7e074d666c64e9d7b5) @@ -23,22 +23,38 @@ using Core.Common.TestUtil; using NUnit.Framework; using Ringtoets.HydraRing.Calculation.Parsers; +using Ringtoets.HydraRing.Calculation.Services; namespace Ringtoets.HydraRing.Calculation.Test.Parsers { [TestFixture] public class TargetProbabilityCalculationParserTest { + private const string workingDirectory = "tempDir"; private readonly string testDataPath = Path.Combine(TestHelper.GetTestDataPath(TestDataPath.Ringtoets.HydraRing.Calculation, "Parsers"), "TargetProbabilityCalculationParser"); [Test] + public void DefaultConstructor_SetDefaultValues() + { + // Call + var parser = new TargetProbabilityCalculationParser(); + + // Assert + Assert.IsInstanceOf(parser); + Assert.IsNull(parser.Output); + } + + [Test] public void Parse_NotExistingOutputFile_OutputNull() { // Setup var targetProbabilityCalculationParser = new TargetProbabilityCalculationParser(); - // Call - targetProbabilityCalculationParser.Parse(Path.Combine(testDataPath, "notExisting.txt"), 1); + using (new DirectoryDisposeHelper(workingDirectory)) + { + // Call + targetProbabilityCalculationParser.Parse(workingDirectory, 1); + } // Assert Assert.IsNull(targetProbabilityCalculationParser.Output); @@ -50,9 +66,14 @@ // Setup var targetProbabilityCalculationParser = new TargetProbabilityCalculationParser(); - // Call - targetProbabilityCalculationParser.Parse(Path.Combine(testDataPath, "empty.txt"), 1); + using (new DirectoryDisposeHelper(workingDirectory)) + { + CopyTestInputToTemporaryOutput("empty.txt"); + // Call + targetProbabilityCalculationParser.Parse(workingDirectory, 1); + } + // Assert Assert.IsNull(targetProbabilityCalculationParser.Output); } @@ -63,12 +84,16 @@ public void Parse_ExampleHydraRingOutputFileContainingSectionIds_ReturnsExpectedTargetProbabilityCalculationResult(int sectionId, double result, double actual) { // Setup - var outputFilePath = Path.Combine(testDataPath, "exampleOutputTable.txt"); var targetProbabilityCalculationParser = new TargetProbabilityCalculationParser(); - // Call - targetProbabilityCalculationParser.Parse(outputFilePath, sectionId); + using (new DirectoryDisposeHelper(workingDirectory)) + { + CopyTestInputToTemporaryOutput("exampleOutputTable.txt"); + // Call + targetProbabilityCalculationParser.Parse(workingDirectory, sectionId); + } + // Assert var targetProbabilityCalculationOutput = targetProbabilityCalculationParser.Output; Assert.IsNotNull(targetProbabilityCalculationOutput); @@ -82,11 +107,29 @@ // Setup var targetProbabilityCalculationParser = new TargetProbabilityCalculationParser(); - // Call - targetProbabilityCalculationParser.Parse(Path.Combine(testDataPath, "exampleOutputTable.txt"), 2); + using (new DirectoryDisposeHelper(workingDirectory)) + { + CopyTestInputToTemporaryOutput("exampleOutputTable.txt"); + // Call + targetProbabilityCalculationParser.Parse(workingDirectory, 2); + } + // Assert Assert.IsNull(targetProbabilityCalculationParser.Output); } + + /// + /// Copies the testfile from the test directory to the working directory. + /// + /// The name of the test's input file. + /// The copied file is removed from the working directory by using the , + /// which recursively removes all files in the directory. + private void CopyTestInputToTemporaryOutput(string testFile) + { + var inputFilePath = Path.Combine(testDataPath, testFile); + var outputFilePath = Path.Combine(workingDirectory, HydraRingFileName.DesignTablesFileName); + File.Copy(inputFilePath, outputFilePath); + } } } \ No newline at end of file