File: test_misc.py

package info (click to toggle)
pygrib 2.1.8-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 28,444 kB
  • sloc: javascript: 1,365; python: 1,356; makefile: 39; ansic: 13
file content (101 lines) | stat: -rw-r--r-- 2,893 bytes parent folder | download | duplicates (2)
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
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
"""Collection of miscellaneous minor tests."""

import os
from tempfile import NamedTemporaryFile

import numpy as np
import pygrib
import pytest


def test_internal_value_type_of_runtime_error():
    grbindx = pygrib.index("../sampledata/gfs.grb", "shortName")
    with pytest.raises(RuntimeError) as e:
        grbindx.write("nonexistent/path")
    assert type(e.value.args[0]) is str


@pytest.mark.parametrize(
    "data_fname,scanning_mode,expected_values",
    [
        (
            "scanning_mode.grib2",
            0b00000000,
            np.array([[0, 1], [2, 3], [4, 5]], dtype=float),
        ),
        (
            "scanning_mode.grib2",
            0b10000000,
            np.array([[0, 1], [2, 3], [4, 5]], dtype=float),
        ),
        (
            "scanning_mode.grib2",
            0b01000000,
            np.array([[0, 1], [2, 3], [4, 5]], dtype=float),
        ),
        (
            "scanning_mode.grib2",
            0b00100000,
            np.array([[0, 3], [1, 4], [2, 5]], dtype=float),
        ),
        (
            "scanning_mode.grib2",
            0b00010000,
            np.array([[0, 1], [3, 2], [4, 5]], dtype=float),
        ),
        (
            "scanning_mode.grib2",
            0b00110000,
            np.array([[0, 3], [4, 1], [2, 5]], dtype=float),
        ),
        (
            "scanning_mode_with_bitmap.grib2",
            0b00000000,
            np.array([[np.nan, 1], [2, 3], [4, 5]], dtype=float),
        ),
        (
            "scanning_mode_with_bitmap.grib2",
            0b10000000,
            np.array([[np.nan, 1], [2, 3], [4, 5]], dtype=float),
        ),
        (
            "scanning_mode_with_bitmap.grib2",
            0b01000000,
            np.array([[np.nan, 1], [2, 3], [4, 5]], dtype=float),
        ),
        (
            "scanning_mode_with_bitmap.grib2",
            0b00100000,
            np.array([[np.nan, 3], [1, 4], [2, 5]], dtype=float),
        ),
        (
            "scanning_mode_with_bitmap.grib2",
            0b00010000,
            np.array([[np.nan, 1], [3, 2], [4, 5]], dtype=float),
        ),
        (
            "scanning_mode_with_bitmap.grib2",
            0b00110000,
            np.array([[np.nan, 3], [4, 1], [2, 5]], dtype=float),
        ),
    ],
)
def test_scanning_mode(data_fname, scanning_mode, expected_values):
    template_path = f"../sampledata/{data_fname}"
    with open(template_path, "rb") as f:
        template = f.read()
    scanning_mode_index = 0x6C
    bytes_ = (
        template[:scanning_mode_index]
        + scanning_mode.to_bytes(1, "big")
        + template[scanning_mode_index + 1 :]
    )
    with NamedTemporaryFile(mode="wb", delete=False) as temp:
        temp.write(bytes_)

    grbs = pygrib.open(temp.name)
    actual = grbs[1].values
    np.testing.assert_array_equal(actual, expected_values)

    grbs.close()
    os.unlink(temp.name)