-
Notifications
You must be signed in to change notification settings - Fork 86
/
Copy pathtest_init.py
160 lines (126 loc) · 4.54 KB
/
test_init.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
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
"""Test for toolbox global workspace."""
import importlib
import logging
import shutil
import subprocess
from pathlib import Path
import pytest
import tiatoolbox
from tiatoolbox import DuplicateFilter, logger
def test_set_root_dir(tmp_path: Path) -> None:
"""Test for setting new root dir."""
# skipcq
importlib.reload(tiatoolbox)
from tiatoolbox import rcParam
old_root_dir = rcParam["TIATOOLBOX_HOME"]
test_dir_path = tmp_path / "tmp_check"
# clean up previous test
if Path.exists(test_dir_path):
Path.rmdir(test_dir_path)
rcParam["TIATOOLBOX_HOME"] = test_dir_path
# reimport to see if it overwrites
# silence Deep Source because this is an intentional check
# skipcq
from tiatoolbox import rcParam
rcParam["TIATOOLBOX_HOME"].mkdir(parents=True)
if not Path.exists(test_dir_path):
pytest.fail(f"`{rcParam['TIATOOLBOX_HOME']}` != `{test_dir_path}`")
shutil.rmtree(rcParam["TIATOOLBOX_HOME"], ignore_errors=True)
rcParam["TIATOOLBOX_HOME"] = old_root_dir # reassign for subsequent test
def test_set_logger() -> None:
"""Test for setting new logger."""
logger = logging.getLogger()
logger.handlers = [] # reset first to overwrite import
handler_1 = logging.StreamHandler()
handler_2 = logging.StreamHandler()
handler_3 = logging.StreamHandler()
logger.addHandler(handler_1)
logger.addHandler(handler_2)
logger.addHandler(handler_3)
assert len(logger.handlers) == 3
# skipcq
importlib.reload(tiatoolbox)
# should not overwrite, so still have 2 handler
assert len(logger.handlers) == 3
logger.handlers = [] # remove all handler
# skipcq
importlib.reload(tiatoolbox)
assert len(logger.handlers) == 2
def helper_logger_test(level: str) -> None:
"""Helper for logger tests."""
if level.lower() in ["debug", "info"]:
output = "out"
order = (0, 1)
else:
output = "err"
order = (1, 0)
run_statement = (
f"from tiatoolbox import logger; "
f"import logging; "
f"logger.setLevel(logging.{level.upper()}); "
f'logger.{level.lower()}("Test if {level.lower()} is written to std{output}.")'
)
proc = subprocess.Popen( # noqa: S603
[ # noqa: S607
"python",
"-c",
run_statement,
],
stdout=subprocess.PIPE,
stderr=subprocess.PIPE,
)
assert (
f"[{level.upper()}] Test if {level.lower()} is written to std{output}.".encode()
in proc.communicate()[order[0]]
)
assert proc.communicate()[order[1]] == b""
def test_logger_output() -> None:
"""Test if logger is writing output to correct value."""
# Test DEBUG is written to stdout
helper_logger_test(level="debug")
# Test INFO is written to stdout
helper_logger_test(level="info")
# Test WARNING is written to stderr
helper_logger_test(level="warning")
# Test ERROR is written to stderr
helper_logger_test(level="error")
# Test CRITICAL is written to stderr
helper_logger_test(level="critical")
def test_duplicate_filter(caplog: pytest.LogCaptureFixture) -> None:
"""Test DuplicateFilter for warnings."""
# Test logger reset after applying duplicate filter.
duplicate_filter = DuplicateFilter()
logger.addFilter(duplicate_filter)
# Reset filters in logger.
for filter_ in logger.filters[:]:
logger.removeFilter(filter_)
for _ in range(2):
logger.warning("Test duplicate filter warnings.")
assert "Test duplicate filter warnings." in caplog.text
assert "\n" in caplog.text[:-2]
caplog.clear()
duplicate_filter = DuplicateFilter()
logger.addFilter(duplicate_filter)
for _ in range(2):
logger.warning("Test duplicate filter warnings.")
logger.removeFilter(duplicate_filter)
assert "Test duplicate filter warnings." in caplog.text
assert "\n" not in caplog.text[:-2]
def test_lazy_import() -> None:
"""Test lazy import for tiatoolbox."""
import sys
from tiatoolbox import _lazy_import
assert "exceptions" not in sys.modules
_lazy_import(
"exceptions",
Path(__file__).parent.parent / "tiatoolbox" / "utils" / "exceptions.py",
)
assert "exceptions" in sys.modules
def test_lazy_import_module_not_found() -> None:
"""'Test lazy import for ModuleNotFoundError."""
from tiatoolbox import _lazy_import
with pytest.raises(ModuleNotFoundError):
_lazy_import(
"nonexistent_module",
Path(__file__).parent.parent / "tiatoolbox",
)