Skip to content

Commit

Permalink
Make libnetcdf version parsing more robust
Browse files Browse the repository at this point in the history
  • Loading branch information
sfinkens committed Nov 1, 2024
1 parent 4ca81ca commit 8df630d
Show file tree
Hide file tree
Showing 2 changed files with 31 additions and 9 deletions.
15 changes: 11 additions & 4 deletions satpy/tests/writer_tests/test_cf.py
Original file line number Diff line number Diff line change
Expand Up @@ -528,12 +528,19 @@ def _assert_encoding_as_expected(self, filename, expected):
assert f["test-array"].dtype == expected["dtype"]
assert f["test-array"].encoding["complevel"] == expected["complevel"]

def test_warning_if_backends_dont_match(self, scene, filename, monkeypatch):
@pytest.mark.parametrize(
"versions",
[
{"netCDF4": "1.5.0", "libnetcdf": "4.9.1-development"},
{"netCDF4": "1.6.0", "libnetcdf": "invalid-version"}
]
)
def test_warning_if_backends_dont_match(self, scene, filename, monkeypatch, versions):
"""Test warning if backends don't match."""
import netCDF4
with monkeypatch.context() as m:
m.setattr(netCDF4, "__version__", "1.5.0")
m.setattr(netCDF4, "__netcdf4libversion__", "4.9.1")
m.setattr(netCDF4, "__version__", versions["netCDF4"])
m.setattr(netCDF4, "__netcdf4libversion__", versions["libnetcdf"])
with pytest.warns(UserWarning, match=r"Backend version mismatch"):
scene.save_datasets(filename=filename, writer="cf")

Expand All @@ -542,7 +549,7 @@ def test_no_warning_if_backends_match(self, scene, filename, monkeypatch):
import netCDF4
with monkeypatch.context() as m:
m.setattr(netCDF4, "__version__", "1.6.0")
m.setattr(netCDF4, "__netcdf4libversion__", "4.9.0-development")
m.setattr(netCDF4, "__netcdf4libversion__", "4.9.0")
m.setattr(xr, "__version__", "2022.12.0")
with warnings.catch_warnings():
scene.save_datasets(filename=filename, writer="cf")
Expand Down
25 changes: 20 additions & 5 deletions satpy/writers/cf_writer.py
Original file line number Diff line number Diff line change
Expand Up @@ -158,7 +158,7 @@

import numpy as np
import xarray as xr
from packaging.version import Version
from packaging.version import InvalidVersion, Version

from satpy.cf.coords import EPOCH # noqa: F401 (for backward compatibility)
from satpy.writers import Writer
Expand Down Expand Up @@ -390,11 +390,26 @@ def _backend_versions_match():

def _get_backend_versions():
import netCDF4

# Make libnetcdf development version compatible with PEP440
libnetcdf_version = netCDF4.__netcdf4libversion__.replace("development", "dev")
libnetcdf_version = _parse_libnetcdf_version(
netCDF4.__netcdf4libversion__
)
return {
"netCDF4": Version(netCDF4.__version__),
"libnetcdf": Version(libnetcdf_version),
"libnetcdf": libnetcdf_version,
"xarray": Version(xr.__version__)
}


def _parse_libnetcdf_version(version_str):
# Make libnetcdf development version compatible with PEP440
version_str = version_str.replace("development", "dev")
try:
return Version(version_str)
except InvalidVersion:
warnings.warn(
f"Unable to parse netcdf-c version {version_str}, "
f"using 0.0.0 as fallback",
UserWarning,
stacklevel=3
)
return Version("0.0.0")

0 comments on commit 8df630d

Please sign in to comment.