Source code for satpy.tests.reader_tests.test_hsaf_grib

#!/usr/bin/env python
# -*- coding: utf-8 -*-
# Copyright (c) 2019 Satpy developers
#
# This file is part of satpy.
#
# satpy is free software: you can redistribute it and/or modify it under the
# terms of the GNU General Public License as published by the Free Software
# Foundation, either version 3 of the License, or (at your option) any later
# version.
#
# satpy is distributed in the hope that it will be useful, but WITHOUT ANY
# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
# A PARTICULAR PURPOSE.  See the GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License along with
# satpy.  If not, see <http://www.gnu.org/licenses/>.
"""Module for testing the satpy.readers.grib module."""

import datetime as dt
import sys
import unittest
from unittest import mock

import numpy as np
from pytest import approx  # noqa: PT013

from satpy.tests.utils import make_dataid


[docs] class FakeMessage(object): """Fake message returned by pygrib.open().message(x).""" def __init__(self, values, proj_params=None, latlons=None, **attrs): """Init the fake message.""" super(FakeMessage, self).__init__() self.attrs = attrs self.values = values if proj_params is None: proj_params = {"a": 6378140.0, "b": 6356755.0, "lat_0": 0.0, "lon_0": 0.0, "proj": "geos", "h": 35785830.098} self.projparams = proj_params self._latlons = latlons
[docs] def latlons(self): """Get the latlons.""" return self._latlons
def __getitem__(self, item): """Get item.""" return self.attrs[item]
[docs] def valid_key(self, key): """Check if key is valid.""" return True
[docs] class FakeGRIB(object): """Fake GRIB file returned by pygrib.open.""" def __init__(self, messages=None, proj_params=None, latlons=None): """Init the fake grib file.""" super(FakeGRIB, self).__init__() if messages is not None: self._messages = messages else: self._messages = [ FakeMessage( values=np.arange(25.).reshape((5, 5)), name="Instantaneous rain rate", shortName="irrate", cfName="unknown", units="kg m**-2 s**-1", dataDate=20190603, dataTime=1645, missingValue=9999, modelName="unknown", centreDescription="Rome", minimum=0.0, maximum=0.01475, Nx=3712, Ny=3712, NrInRadiusOfEarth=6.6107, dx=3622, dy=3610, XpInGridLengths=1856.0, YpInGridLengths=1856.0, jScansPositively=0, proj_params=proj_params, latlons=latlons, ) ] self.messages = len(self._messages)
[docs] def message(self, msg_num): """Fake message.""" return self._messages[msg_num - 1]
[docs] def seek(self, loc): """Fake seek.""" return
def __iter__(self): """Iterate over messages.""" return iter(self._messages) def __enter__(self): """Enter the context.""" return self def __exit__(self, exc_type, exc_val, exc_tb): """Exit the context."""
[docs] class TestHSAFFileHandler(unittest.TestCase): """Test HSAF Reader."""
[docs] def setUp(self): """Wrap pygrib to read fake data.""" try: import pygrib except ImportError: pygrib = None self.orig_pygrib = pygrib sys.modules["pygrib"] = mock.MagicMock()
[docs] def tearDown(self): """Re-enable pygrib import.""" sys.modules["pygrib"] = self.orig_pygrib
[docs] @mock.patch("satpy.readers.hsaf_grib.pygrib.open", return_value=FakeGRIB()) def test_init(self, pg): """Test the init function, ensure that the correct dates and metadata are returned.""" pg.open.return_value = FakeGRIB() correct_dt = dt.datetime(2019, 6, 3, 16, 45, 0) from satpy.readers.hsaf_grib import HSAFFileHandler fh = HSAFFileHandler("filename", mock.MagicMock(), mock.MagicMock()) assert fh._analysis_time == correct_dt assert fh.metadata["projparams"]["lat_0"] == 0.0 assert fh.metadata["shortName"] == "irrate" assert fh.metadata["nx"] == 3712
[docs] @mock.patch("satpy.readers.hsaf_grib.pygrib.open", return_value=FakeGRIB()) def test_get_area_def(self, pg): """Test the area definition setup, checks the size and extent.""" pg.open.return_value = FakeGRIB() from satpy.readers.hsaf_grib import HSAFFileHandler fh = HSAFFileHandler("filename", mock.MagicMock(), mock.MagicMock()) area_def = HSAFFileHandler.get_area_def(fh, "H03B") assert area_def.width == 3712 assert area_def.area_extent[0] == approx(-5569209.3026, abs=1e-3) assert area_def.area_extent[3] == approx(5587721.9097, abs=1e-3)
[docs] @mock.patch("satpy.readers.hsaf_grib.pygrib.open", return_value=FakeGRIB()) def test_get_dataset(self, pg): """Test reading the actual datasets from a grib file.""" pg.open.return_value = FakeGRIB() from satpy.readers.hsaf_grib import HSAFFileHandler # Instantaneous precipitation fh = HSAFFileHandler("filename", mock.MagicMock(), mock.MagicMock()) fh.filename = "H03B" ds_id = make_dataid(name="H03B") data = fh.get_dataset(ds_id, mock.Mock()) np.testing.assert_array_equal(data.values, np.arange(25.).reshape((5, 5))) # Accumulated precipitation fh = HSAFFileHandler("filename", mock.MagicMock(), mock.MagicMock()) fh.filename = "H05B" ds_id = make_dataid(name="H05B") data = fh.get_dataset(ds_id, mock.Mock()) np.testing.assert_array_equal(data.values, np.arange(25.).reshape((5, 5)))