-
-
Notifications
You must be signed in to change notification settings - Fork 2.6k
/
Copy pathtest_xarray_input.py
135 lines (93 loc) · 3.08 KB
/
test_xarray_input.py
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
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
import pytest
import numpy as np
import xarray
import datetime
from _plotly_utils.basevalidators import (
NumberValidator,
IntegerValidator,
DataArrayValidator,
ColorValidator,
)
@pytest.fixture
def data_array_validator(request):
return DataArrayValidator("prop", "parent")
@pytest.fixture
def integer_validator(request):
return IntegerValidator("prop", "parent", array_ok=True)
@pytest.fixture
def number_validator(request):
return NumberValidator("prop", "parent", array_ok=True)
@pytest.fixture
def color_validator(request):
return ColorValidator("prop", "parent", array_ok=True, colorscale_path="")
@pytest.fixture(
params=[
"int8",
"int16",
"int32",
"int64",
"uint8",
"uint16",
"uint32",
"uint64",
# "float16",
"float32",
"float64",
]
)
def numeric_dtype(request):
return request.param
@pytest.fixture(params=[xarray.DataArray])
def xarray_type(request):
return request.param
@pytest.fixture
def numeric_xarray(request, xarray_type, numeric_dtype):
return xarray_type(np.arange(10, dtype=numeric_dtype))
@pytest.fixture
def color_object_xarray(request, xarray_type):
return xarray_type(["blue", "green", "red"] * 3)
def test_numeric_validator_numeric_xarray(number_validator, numeric_xarray):
res = number_validator.validate_coerce(numeric_xarray)
# Check type
assert isinstance(res, np.ndarray)
# Check dtype
assert res.dtype == numeric_xarray.dtype
# Check values
np.testing.assert_array_equal(res, numeric_xarray)
def test_integer_validator_numeric_xarray(integer_validator, numeric_xarray):
res = integer_validator.validate_coerce(numeric_xarray)
# Check type
assert isinstance(res, np.ndarray)
# Check dtype
if numeric_xarray.dtype.kind in ("u", "i"):
# Integer and unsigned integer dtype unchanged
assert res.dtype == numeric_xarray.dtype
else:
# Float datatypes converted to default integer type of int32
assert res.dtype == "int32"
# Check values
np.testing.assert_array_equal(res, numeric_xarray)
def test_data_array_validator(data_array_validator, numeric_xarray):
res = data_array_validator.validate_coerce(numeric_xarray)
# Check type
assert isinstance(res, np.ndarray)
# Check dtype
assert res.dtype == numeric_xarray.dtype
# Check values
np.testing.assert_array_equal(res, numeric_xarray)
def test_color_validator_numeric(color_validator, numeric_xarray):
res = color_validator.validate_coerce(numeric_xarray)
# Check type
assert isinstance(res, np.ndarray)
# Check dtype
assert res.dtype == numeric_xarray.dtype
# Check values
np.testing.assert_array_equal(res, numeric_xarray)
def test_color_validator_object(color_validator, color_object_xarray):
res = color_validator.validate_coerce(color_object_xarray)
# Check type
assert isinstance(res, np.ndarray)
# Check dtype
assert res.dtype == "object"
# Check values
np.testing.assert_array_equal(res, color_object_xarray)