File: test_auxil.py

package info (click to toggle)
python-polsarpro 2026.1.0-1
  • links: PTS, VCS
  • area: main
  • in suites:
  • size: 17,024 kB
  • sloc: python: 3,830; xml: 293; sh: 91; javascript: 18; makefile: 3
file content (62 lines) | stat: -rw-r--r-- 2,036 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
import pytest
import numpy as np
import xarray as xr

from polsarpro.auxil import validate_dataset, POLTYPES


def make_dataset(poltype: str, wrong_dtype: bool = False, desc: str | None = None):
    """Utility to build a dataset for a given poltype, with optional mistakes."""
    if poltype not in POLTYPES:
        # use S variables by default if poltype is not correct
        specs = POLTYPES["S"]
    else:
        specs = POLTYPES[poltype]
    shape = (5, 5)

    data_vars = {}
    for v, props in specs["vars"].items():
        dtype = props["dtype"]
        if wrong_dtype:
            # flip float32 -> complex64, complex64 -> float32
            dtype = "complex64" if dtype == "float32" else "float32"
        arr = np.zeros(shape, dtype=dtype)
        data_vars[v] = (("y", "x"), arr)

    ds = xr.Dataset(data_vars)
    ds.attrs["poltype"] = poltype
    ds.attrs["description"] = desc if desc is not None else specs["description"]
    return ds


@pytest.mark.parametrize("poltype", list(POLTYPES.keys()))
def test_valid_datasets_pass(poltype):
    ds = make_dataset(poltype)
    # Should not raise
    _ = validate_dataset(ds, allowed_poltypes=poltype)


def test_invalid_poltype_raises():
    ds = make_dataset("INVALID")
    with pytest.raises(ValueError, match=f"Unsupported poltype"):
        _ = validate_dataset(ds, allowed_poltypes=("S", "T3", "C4"))


def test_missing_variable_raises():
    ds = make_dataset("S")
    ds = ds.drop_vars("hh")
    with pytest.raises(ValueError, match=f"Dataset is missing required variable: 'hh'"):
        _ = validate_dataset(ds, allowed_poltypes="S")


def test_wrong_dtype_detected():
    ds = make_dataset("T3", wrong_dtype=True)
    with pytest.raises(ValueError, match="dtype"):
        _ = validate_dataset(ds, allowed_poltypes="T3", check_dtypes=True)


def test_skip_checks_allows_pass():
    # Wrong dtype, but skip dtype check
    ds = make_dataset("T3", wrong_dtype=True)
    # Should not raise
    _ = validate_dataset(ds, allowed_poltypes="T3", check_dtypes=False)