コード例 #1
0
        public void Constructor_ExpectedValues()
        {
            // Call
            var parser = new WaveConditionsCalculationParser();

            // Assert
            Assert.IsInstanceOf <IHydraRingFileParser>(parser);
            Assert.IsNull(parser.Output);
        }
コード例 #2
0
        /// <summary>
        /// Create a new instance of <see cref="WaveConditionsCosineCalculator"/>.
        /// </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 WaveConditionsCosineCalculator(HydraRingCalculationSettings calculationSettings) : base(calculationSettings)
        {
            waveConditionsCalculationParser   = new WaveConditionsCalculationParser();
            reliabilityIndexCalculationParser = new ReliabilityIndexCalculationParser();
            convergenceParser = new ConvergenceParser();

            WaveHeight       = double.NaN;
            WaveAngle        = double.NaN;
            WavePeakPeriod   = double.NaN;
            WaveDirection    = double.NaN;
            ReliabilityIndex = double.NaN;
        }
コード例 #3
0
        public void Parse_WorkingDirectoryNull_ThrowsArgumentNullException()
        {
            // Setup
            var parser = new WaveConditionsCalculationParser();

            // 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 WaveConditionsCalculationParser();

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

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

            Assert.IsInstanceOf <SQLiteException>(exception.InnerException);
        }
コード例 #5
0
        public void Parse_ResultsOnOtherSection_ThrowsHydraRingFileParserException()
        {
            // Setup
            string path   = Path.Combine(testDirectory, "OtherSection");
            var    parser = new WaveConditionsCalculationParser();

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

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

            Assert.AreEqual("Er zijn geen berekende golfcondities gevonden in de Hydra-Ring uitvoerdatabase.", exception.Message);
        }
コード例 #6
0
        public void Parse_WithWorkingDirectoryWithInvalidOutputFile_ThrowsHydraRingFileParserException()
        {
            // Setup
            string path   = Path.Combine(testDirectory, "InvalidFile");
            var    parser = new WaveConditionsCalculationParser();

            // 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);
        }
コード例 #7
0
        public void Parse_ValidData_OutputSet()
        {
            // Setup
            string path   = Path.Combine(testDirectory, validFile);
            var    parser = new WaveConditionsCalculationParser();

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

            // Assert
            Assert.AreEqual(2.76672, parser.Output.WaveHeight);
            Assert.AreEqual(-7.97903, parser.Output.WaveAngle);
            Assert.AreEqual(292.021, parser.Output.WaveDirection);
            Assert.AreEqual(5.02556, parser.Output.WavePeakPeriod);
        }
コード例 #8
0
        public void Parse_NotAllColumnsHaveResults_ThrowsHydraRingFileParserException(string subFolder)
        {
            // Setup
            string path   = Path.Combine(testDirectory, subFolder);
            var    parser = new WaveConditionsCalculationParser();

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

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

            Assert.AreEqual("Er zijn geen berekende golfcondities gevonden in de Hydra-Ring uitvoerdatabase.", exception.Message);
            Assert.IsInstanceOf <InvalidCastException>(exception.InnerException);
        }
コード例 #9
0
        public void Parse_ErrorWhileReadingFile_ThrowsHydraRingFileParserException()
        {
            // Setup
            var    parser           = new WaveConditionsCalculationParser();
            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);
            }
        }