Exemplo n.º 1
0
        public void Constructor_ExpectedValues()
        {
            // Call
            var parser = new OvertoppingCalculationWaveHeightParser();

            // Assert
            Assert.IsInstanceOf <IHydraRingFileParser>(parser);
            Assert.IsNull(parser.Output);
        }
Exemplo n.º 2
0
        /// <summary>
        /// Create a new instance of <see cref="OvertoppingCalculator"/>.
        /// </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 OvertoppingCalculator(HydraRingCalculationSettings calculationSettings) : base(calculationSettings)
        {
            exceedanceProbabilityCalculationParser = new ExceedanceProbabilityCalculationParser();
            waveHeightParser = new OvertoppingCalculationWaveHeightParser();

            ExceedanceProbabilityBeta = double.NaN;
            WaveHeight            = double.NaN;
            IsOvertoppingDominant = false;
        }
Exemplo n.º 3
0
        public void Parse_WorkingDirectoryNull_ThrowsArgumentNullException()
        {
            // Setup
            var parser = new OvertoppingCalculationWaveHeightParser();

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

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

            Assert.AreEqual("workingDirectory", exception.ParamName);
        }
Exemplo n.º 4
0
        public void Parse_WaveHeightNull_OutputSet()
        {
            // Setup
            string path   = Path.Combine(testDirectory, "ValidFileWaveHeightNull");
            var    parser = new OvertoppingCalculationWaveHeightParser();

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

            // Assert
            Assert.IsNaN(parser.Output.WaveHeight);
            Assert.IsFalse(parser.Output.IsOvertoppingDominant);
        }
Exemplo n.º 5
0
        public void Parse_ValidData_OutputSet(string file, double expectedWaveHeight, bool expectedOvertoppingDominant)
        {
            // Setup
            string path   = Path.Combine(testDirectory, file);
            var    parser = new OvertoppingCalculationWaveHeightParser();

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

            // Assert
            Assert.AreEqual(expectedWaveHeight, parser.Output.WaveHeight, 1e-11);
            Assert.AreEqual(expectedOvertoppingDominant, parser.Output.IsOvertoppingDominant);
        }
Exemplo n.º 6
0
        public void Parse_WithWorkingDirectoryWithoutExpectedFile_ThrowsHydraRingFileParserException()
        {
            // Setup
            string path   = Path.Combine(testDirectory, "EmptyWorkingDirectory");
            var    parser = new OvertoppingCalculationWaveHeightParser();

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

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

            Assert.IsInstanceOf <SQLiteException>(exception.InnerException);
        }
Exemplo n.º 7
0
        public void Parse_WithWorkingDirectoryWithInvalidOutputFile_ThrowsHydraRingFileParserException(string subFolder)
        {
            // Setup
            string path   = Path.Combine(testDirectory, subFolder);
            var    parser = new OvertoppingCalculationWaveHeightParser();

            // 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);
        }
Exemplo n.º 8
0
        public void Parse_ValidDataForOtherSection_ThrowsHydraRingFileParserException()
        {
            // Setup
            string path   = Path.Combine(testDirectory, "OtherSection");
            var    parser = new OvertoppingCalculationWaveHeightParser();

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

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

            Assert.AreEqual("Er is geen resultaat voor overslag en overloop gevonden in de Hydra-Ring uitvoerdatabase.", exception.Message);
            Assert.IsInstanceOf <InvalidCastException>(exception.InnerException);
        }
Exemplo n.º 9
0
        public void Parse_ErrorWhileReadingFile_ThrowsHydraRingFileParserException()
        {
            // Setup
            var    parser           = new OvertoppingCalculationWaveHeightParser();
            string workingDirectory = Path.Combine(testDirectory, validFileOvertoppingDominant);

            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);
            }
        }