Source code for satpy.tests.reader_tests.test_glm_l2

#!/usr/bin/env python
# -*- coding: utf-8 -*-
# Copyright (c) 2017 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/>.
"""The glm_l2 reader tests package."""

import os
import unittest
from unittest import mock

import numpy as np
import xarray as xr


[docs] def setup_fake_dataset(): """Create a fake dataset to avoid opening a file.""" # flash_extent_density fed = (np.arange(10.).reshape((2, 5)) + 1.) * 50. fed = (fed + 1.) / 0.5 fed = fed.astype(np.int16) fed = xr.DataArray( fed, dims=("y", "x"), attrs={ "scale_factor": 0.5, "add_offset": -1., "_FillValue": 0, "units": "Count per nominal 3136 microradian^2 pixel per 1.0 min", "grid_mapping": "goes_imager_projection", "standard_name": "flash_extent_density", "long_name": "Flash extent density", } ) dqf = xr.DataArray( fed.data.copy().astype(np.uint8), dims=("y", "x"), attrs={ "_FillValue": -1, "units": "1", "grid_mapping": "goes_imager_projection", "standard_name": "status_flag", "long_name": "GLM data quality flags", "flag_meanings": "valid invalid", } ) # create a variable that won't be configured to test available_datasets not_configured = xr.DataArray( fed.data.copy(), dims=("y", "x"), attrs={ "scale_factor": 0.5, "add_offset": -1., "_FillValue": 0, "units": "1", "grid_mapping": "goes_imager_projection", "standard_name": "test", "long_name": "Test", } ) x__ = xr.DataArray( range(5), attrs={"scale_factor": 2., "add_offset": -1.}, dims=("x",), ) y__ = xr.DataArray( range(2), attrs={"scale_factor": -2., "add_offset": 1.}, dims=("y",), ) proj = xr.DataArray( [], attrs={ "semi_major_axis": 1., "semi_minor_axis": 1., "perspective_point_height": 1., "longitude_of_projection_origin": -90., "latitude_of_projection_origin": 0., "sweep_angle_axis": u"x" } ) fake_dataset = xr.Dataset( data_vars={ "flash_extent_density": fed, "not_configured": not_configured, "DQF": dqf, "x": x__, "y": y__, "goes_imager_projection": proj, "nominal_satellite_subpoint_lat": np.array(0.0), "nominal_satellite_subpoint_lon": np.array(-89.5), "nominal_satellite_height": np.array(35786.02) }, attrs={ "time_coverage_start": "2017-09-20T17:30:40Z", "time_coverage_end": "2017-09-20T17:41:17Z", "spatial_resolution": "2km at nadir", } ) return fake_dataset
[docs] class TestGLML2FileHandler(unittest.TestCase): """Tests for the GLM L2 reader."""
[docs] @mock.patch("satpy.readers.abi_base.xr") def setUp(self, xr_): """Create a fake file handler to test.""" from satpy.readers.glm_l2 import NCGriddedGLML2 fake_dataset = setup_fake_dataset() xr_.open_dataset.return_value = fake_dataset self.reader = NCGriddedGLML2("filename", {"platform_shortname": "G16", "scene_abbr": "C", "scan_mode": "M3"}, {"filetype": "glm_l2_imagery"})
[docs] def test_basic_attributes(self): """Test getting basic file attributes.""" from datetime import datetime assert self.reader.start_time == datetime(2017, 9, 20, 17, 30, 40) assert self.reader.end_time == datetime(2017, 9, 20, 17, 41, 17)
[docs] def test_get_dataset(self): """Test the get_dataset method.""" from satpy.tests.utils import make_dataid key = make_dataid(name="flash_extent_density") res = self.reader.get_dataset(key, {"info": "info"}) exp = {"instrument_ID": None, "modifiers": (), "name": "flash_extent_density", "orbital_parameters": {"projection_altitude": 1.0, "projection_latitude": 0.0, "projection_longitude": -90.0, # 'satellite_nominal_altitude': 35786.02, "satellite_nominal_latitude": 0.0, "satellite_nominal_longitude": -89.5}, "orbital_slot": None, "platform_name": "GOES-16", "platform_shortname": "G16", "production_site": None, "scan_mode": "M3", "scene_abbr": "C", "scene_id": None, "spatial_resolution": "2km at nadir", "sensor": "glm", "timeline_ID": None, "grid_mapping": "goes_imager_projection", "standard_name": "flash_extent_density", "long_name": "Flash extent density", "units": "Count per nominal 3136 microradian^2 pixel per 1.0 min"} assert res.attrs == exp
[docs] def test_get_dataset_dqf(self): """Test the get_dataset method with special DQF var.""" from satpy.tests.utils import make_dataid key = make_dataid(name="DQF") res = self.reader.get_dataset(key, {"info": "info"}) exp = {"instrument_ID": None, "modifiers": (), "name": "DQF", "orbital_parameters": {"projection_altitude": 1.0, "projection_latitude": 0.0, "projection_longitude": -90.0, # 'satellite_nominal_altitude': 35786.02, "satellite_nominal_latitude": 0.0, "satellite_nominal_longitude": -89.5}, "orbital_slot": None, "platform_name": "GOES-16", "platform_shortname": "G16", "production_site": None, "scan_mode": "M3", "scene_abbr": "C", "scene_id": None, "spatial_resolution": "2km at nadir", "sensor": "glm", "timeline_ID": None, "grid_mapping": "goes_imager_projection", "units": "1", "_FillValue": -1, "standard_name": "status_flag", "long_name": "GLM data quality flags", "flag_meanings": "valid invalid"} assert res.attrs == exp assert np.issubdtype(res.dtype, np.integer)
[docs] class TestGLML2Reader(unittest.TestCase): """Test high-level reading functionality of GLM L2 reader.""" yaml_file = "glm_l2.yaml"
[docs] @mock.patch("satpy.readers.abi_base.xr") def setUp(self, xr_): """Create a fake reader to test.""" from satpy._config import config_search_paths from satpy.readers import load_reader self.reader_configs = config_search_paths(os.path.join("readers", self.yaml_file)) fake_dataset = setup_fake_dataset() xr_.open_dataset.return_value = fake_dataset r = load_reader(self.reader_configs) loadables = r.select_files_from_pathnames([ "OR_GLM-L2-GLMC-M3_G16_s20192862159000_e20192862200000_c20192862200350.nc", "CSPP_CG_GLM-L2-GLMC-M3_G16_s20192862159000_e20192862200000_c20192862200350.nc", ]) assert len(loadables) == 2 r.create_filehandlers(loadables) self.reader = r
[docs] def test_available_datasets(self): """Test that resolution is added to YAML configured variables.""" # make sure we have some files assert self.reader.file_handlers available_datasets = list(self.reader.available_dataset_ids) # flash_extent_density, DQF, and not_configured are available in our tests assert len(available_datasets) == 3 for ds_id in available_datasets: assert ds_id["resolution"] == 2000 # make sure not_configured was discovered names = [dataid["name"] for dataid in available_datasets] assert "not_configured" in names