示例#1
0
        public void Constructor_ExpectedValues()
        {
            // Call
            var parser = new DunesBoundaryConditionsCalculationParser();

            // Assert
            Assert.IsInstanceOf <IHydraRingFileParser>(parser);
            Assert.IsNull(parser.Output);
        }
示例#2
0
        /// <summary>
        /// Create a new instance of <see cref="DesignWaterLevelCalculator"/>.
        /// </summary>
        /// <param name="calculationSettings">The <see cref="HydraRingCalculationSettings"/>.</param>
        /// <exception cref="ArgumentNullException">Thrown when <paramref name="calculationSettings"/>
        /// is <c>null</c>.</exception>
        /// <remarks>Preprocessing is disabled when <see cref="HydraRingCalculationSettings.PreprocessorDirectory"/>
        /// equals <see cref="string.Empty"/>.</remarks>
        internal DunesBoundaryConditionsCalculator(HydraRingCalculationSettings calculationSettings) : base(calculationSettings)
        {
            dunesBoundaryParser     = new DunesBoundaryConditionsCalculationParser();
            targetProbabilityParser = new ReliabilityIndexCalculationParser();
            convergenceParser       = new ConvergenceParser();

            WaterLevel       = double.NaN;
            WaveHeight       = double.NaN;
            WavePeriod       = double.NaN;
            ReliabilityIndex = double.NaN;
        }
示例#3
0
        public void Parse_WorkingDirectoryNull_ThrowsArgumentNullException()
        {
            // Setup
            var parser = new DunesBoundaryConditionsCalculationParser();

            // Call
            TestDelegate test = () => parser.Parse(null, 1);

            // Assert
            var exception = Assert.Throws <ArgumentNullException>(test);

            Assert.AreEqual("workingDirectory", exception.ParamName);
        }
示例#4
0
        public void Parse_WithWorkingDirectoryWithoutExpectedFile_ThrowsHydraRingFileParserException()
        {
            // Setup
            string path   = Path.Combine(testDirectory, "EmptyWorkingDirectory");
            var    parser = new DunesBoundaryConditionsCalculationParser();

            // Call
            TestDelegate test = () => parser.Parse(path, 1);

            // Assert
            var exception = Assert.Throws <HydraRingFileParserException>(test);

            Assert.IsInstanceOf <SQLiteException>(exception.InnerException);
        }
示例#5
0
        public void Parse_ValidData_OutputSet()
        {
            // Setup
            string path   = Path.Combine(testDirectory, validFile);
            var    parser = new DunesBoundaryConditionsCalculationParser();

            // Call
            parser.Parse(path, 1);

            // Assert
            Assert.AreEqual(4.29026, parser.Output.WaterLevel);
            Assert.AreEqual(10.1528, parser.Output.WaveHeight);
            Assert.AreEqual(19.1762, parser.Output.WavePeriod);
        }
示例#6
0
        public void Parse_ValidDataForOtherSection_ThrowsHydraRingFileParserException()
        {
            // Setup
            string path   = Path.Combine(testDirectory, "OtherSection");
            var    parser = new DunesBoundaryConditionsCalculationParser();

            // Call
            TestDelegate test = () => parser.Parse(path, 1);

            // Assert
            var exception = Assert.Throws <HydraRingFileParserException>(test);

            Assert.AreEqual("Er zijn geen berekende hydraulische belastingen voor duinen gevonden in de Hydra-Ring uitvoerdatabase.", exception.Message);
        }
示例#7
0
        public void Parse_WithWorkingDirectoryWithInvalidOutputFile_ThrowsHydraRingFileParserException()
        {
            // Setup
            string path   = Path.Combine(testDirectory, "InvalidFile");
            var    parser = new DunesBoundaryConditionsCalculationParser();

            // Call
            TestDelegate test = () => parser.Parse(path, 1);

            // Assert
            var exception = Assert.Throws <HydraRingFileParserException>(test);

            Assert.AreEqual("Er kon geen resultaat gelezen worden uit de Hydra-Ring uitvoerdatabase.", exception.Message);
            Assert.IsInstanceOf <SQLiteException>(exception.InnerException);
        }
示例#8
0
        public void Parse_NotAllColumnsHaveResults_ThrowsHydraRingFileParserException(string subFolder)
        {
            // Setup
            string path   = Path.Combine(testDirectory, subFolder);
            var    parser = new DunesBoundaryConditionsCalculationParser();

            // Call
            TestDelegate test = () => parser.Parse(path, 1);

            // Assert
            var exception = Assert.Throws <HydraRingFileParserException>(test);

            Assert.AreEqual("Er zijn geen berekende hydraulische belastingen voor duinen gevonden in de Hydra-Ring uitvoerdatabase.", exception.Message);
            Assert.IsInstanceOf <InvalidCastException>(exception.InnerException);
        }
示例#9
0
        public void Parse_ErrorWhileReadingFile_ThrowsHydraRingFileParserException()
        {
            // Setup
            var    parser           = new DunesBoundaryConditionsCalculationParser();
            string workingDirectory = Path.Combine(testDirectory, validFile);

            using (new DirectoryPermissionsRevoker(testDirectory, FileSystemRights.ReadData))
            {
                // Call
                TestDelegate call = () => parser.Parse(workingDirectory, 1);

                // Assert
                var          exception       = Assert.Throws <HydraRingFileParserException>(call);
                const string expectedMessage = "Er kon geen resultaat gelezen worden uit de Hydra-Ring uitvoerdatabase.";
                Assert.AreEqual(expectedMessage, exception.Message);
                Assert.IsInstanceOf <SQLiteException>(exception.InnerException);
            }
        }