forked from Python-roborock/python-roborock
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathtest_code_mappings.py
More file actions
91 lines (70 loc) · 2.98 KB
/
test_code_mappings.py
File metadata and controls
91 lines (70 loc) · 2.98 KB
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
"""Tests for code mappings.
These tests exercise the custom enum methods using arbitrary enum values.
"""
import pytest
from roborock import HomeDataProduct, RoborockCategory
from roborock.data.b01_q10.b01_q10_code_mappings import B01_Q10_DP
def test_from_code() -> None:
"""Test from_code method."""
assert B01_Q10_DP.START_CLEAN == B01_Q10_DP.from_code(201)
assert B01_Q10_DP.PAUSE == B01_Q10_DP.from_code(204)
assert B01_Q10_DP.STOP == B01_Q10_DP.from_code(206)
def test_invalid_from_code() -> None:
"""Test invalid from_code method."""
with pytest.raises(ValueError, match="999999 is not a valid code for B01_Q10_DP"):
B01_Q10_DP.from_code(999999)
def test_invalid_from_code_optional() -> None:
"""Test invalid from_code_optional method."""
assert B01_Q10_DP.from_code_optional(999999) is None
def test_from_name() -> None:
"""Test from_name method."""
assert B01_Q10_DP.START_CLEAN == B01_Q10_DP.from_name("START_CLEAN")
assert B01_Q10_DP.PAUSE == B01_Q10_DP.from_name("pause")
assert B01_Q10_DP.STOP == B01_Q10_DP.from_name("Stop")
def test_invalid_from_name() -> None:
"""Test invalid from_name method."""
with pytest.raises(ValueError, match="INVALID_NAME is not a valid name for B01_Q10_DP"):
B01_Q10_DP.from_name("INVALID_NAME")
def test_from_value() -> None:
"""Test from_value method."""
assert B01_Q10_DP.START_CLEAN == B01_Q10_DP.from_value("dpStartClean")
assert B01_Q10_DP.PAUSE == B01_Q10_DP.from_value("dpPause")
assert B01_Q10_DP.STOP == B01_Q10_DP.from_value("dpStop")
def test_invalid_from_value() -> None:
"""Test invalid from_value method."""
with pytest.raises(ValueError, match="invalid_value is not a valid value for B01_Q10_DP"):
B01_Q10_DP.from_value("invalid_value")
@pytest.mark.parametrize(
"input, expected",
[
("START_CLEAN", B01_Q10_DP.START_CLEAN),
("start_clean", B01_Q10_DP.START_CLEAN),
("dpStartClean", B01_Q10_DP.START_CLEAN),
(201, B01_Q10_DP.START_CLEAN),
("PAUSE", B01_Q10_DP.PAUSE),
("pause", B01_Q10_DP.PAUSE),
("dpPause", B01_Q10_DP.PAUSE),
(204, B01_Q10_DP.PAUSE),
("STOP", B01_Q10_DP.STOP),
("stop", B01_Q10_DP.STOP),
("dpStop", B01_Q10_DP.STOP),
(206, B01_Q10_DP.STOP),
("invalid_value", None),
(999999, None),
],
)
def test_from_any_optional(input: str | int, expected: B01_Q10_DP | None) -> None:
"""Test from_any_optional method."""
assert B01_Q10_DP.from_any_optional(input) == expected
def test_homedata_product_unknown_category():
"""Test that HomeDataProduct can handle unknown categories."""
data = {
"id": "unknown_cat_id",
"name": "Unknown Device",
"model": "roborock.vacuum.a87",
"category": "roborock.random.category",
"schema": [],
}
product = HomeDataProduct.from_dict(data)
assert product.id == "unknown_cat_id"
assert product.category == RoborockCategory.UNKNOWN