public void WriteDuneLocationCalculations_ValidData_ValidFile() { // Setup var calculationWithoutOutput = new ExportableDuneLocationCalculation( new DuneLocationCalculation(CreateDuneLocationForExport(9, 9740, 1.9583e-4)), 0.5); var calculationWithUncalculatedOutput = new ExportableDuneLocationCalculation( new DuneLocationCalculation(CreateDuneLocationForExport(10, 9770.1, 1.9583e-4)) { Output = CreateDuneLocationCalculationOutputForExport(double.NaN, double.NaN, double.NaN) }, 0.25); var calculationWithOutput = new ExportableDuneLocationCalculation( new DuneLocationCalculation(CreateDuneLocationForExport(11, 9771.34, 1.337e-4)) { Output = CreateDuneLocationCalculationOutputForExport(5.89, 14.11, 8.53) }, 0.1); ExportableDuneLocationCalculation[] exportableDuneLocationCalculations = { calculationWithoutOutput, calculationWithUncalculatedOutput, calculationWithOutput }; string directoryPath = TestHelper.GetScratchPadPath("WriteDuneLocationCalculations_ValidData_ValidFile"); Directory.CreateDirectory(directoryPath); string filePath = Path.Combine(directoryPath, "test.bnd"); try { // Call DuneLocationCalculationsWriter.WriteDuneLocationCalculations(exportableDuneLocationCalculations, filePath); // Assert Assert.IsTrue(File.Exists(filePath)); string fileContent = File.ReadAllText(filePath); string expectedText = $"Kv\tNr\tRp\tHs\tTp\tTm-1,0\tD50\t_BOI2023_Waarde{Environment.NewLine}" + $"*Kustvaknummer\tMetrering\tRekenpeil\tSignificante golfhoogte\tPiekperiode\tSpectrale periode\tKorreldiameter\tPfdsn{Environment.NewLine}" + $"*[-]\t[dam]\t[m+NAP]\t[m]\t[s]\t[s]\t[m]\t[1/jaar]{Environment.NewLine}" + $"9\t9740\t*\t*\t*\t*\t0.000196\t0.5{Environment.NewLine}" + $"10\t9770.1\t*\t*\t*\t*\t0.000196\t0.25{Environment.NewLine}" + $"11\t9771.3\t5.89\t8.53\t14.11\t*\t0.000134\t0.1{Environment.NewLine}"; Assert.AreEqual(expectedText, fileContent); } finally { DirectoryHelper.TryDelete(directoryPath); } }
public void Constructor_WithValidParameters_ExpectedProperties() { // Setup var calculation = new DuneLocationCalculation(new TestDuneLocation()); double targetProbability = new Random(39).NextDouble(); // Call var exportableCalculation = new ExportableDuneLocationCalculation(calculation, targetProbability); // Assert Assert.AreSame(calculation, exportableCalculation.Calculation); Assert.AreEqual(targetProbability, exportableCalculation.TargetProbability); }