From 518c9f7f01181a79da193828203c6061f819b90f Mon Sep 17 00:00:00 2001 From: Iwen Su Date: Mon, 1 Apr 2024 05:51:50 -0700 Subject: [PATCH] Add QartodClimtologyMissingTest() to Test to capture test scenario provided here https://github.com/ioos/ioos_qc/issues/65 --- tests/test_qartod.py | 57 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 57 insertions(+) diff --git a/tests/test_qartod.py b/tests/test_qartod.py index 26e2e4e..cfa65f4 100644 --- a/tests/test_qartod.py +++ b/tests/test_qartod.py @@ -720,6 +720,62 @@ def test_climatology_test_all_unknown(self): self._run_test(test_inputs, expected_result) + +class QartodClimatologyMissingTest(unittest.TestCase): + def setUp(self): + self.cc = qartod.ClimatologyConfig() + # different time range, no depth + self.cc.add( + tspan=(np.datetime64('2021-07'), np.datetime64('2021-09')), + vspan=(3.4, 5) + ) + + def _run_test(self, test_inputs, expected_result): + times, values, depths = zip(*test_inputs) + inputs = [ + values, + np.asarray(values, dtype=np.float64), + dask_arr(np.asarray(values, dtype=np.float64)) + ] + + for i in inputs: + results = qartod.climatology_test( + config=self.cc, + tinp=times, + inp=i, + zinp=depths + ) + npt.assert_array_equal( + results, + np.ma.array(expected_result) + ) + + def test_climatology_missing_values(self): + test_inputs = [ + # Not missing value or depth, value out of bounds + ( + np.datetime64('2021-07-16'), + 0, + 0 + ), + # Missing value and depth + ( + np.datetime64('2021-07-16'), + np.nan, + np.nan + ), + # Not missing value and depth, value within bounds + ( + np.datetime64('2021-07-16'), + 4.16743, + 0.08931513 + ) + ] + expected_result = [3, 9, 1] + self._run_test(test_inputs, expected_result) + + + class QartodClimatologyTest(unittest.TestCase): def setUp(self): @@ -859,6 +915,7 @@ def test_climatology_test_depths(self): ] expected_result = [1, 1, 1, 3, 3, 3] self._run_test(test_inputs, expected_result) + class QartodSpikeTest(unittest.TestCase):