-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtest_logger_.py
117 lines (79 loc) · 3.37 KB
/
test_logger_.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
"""Тесты модуля logger_"""
from logging import DEBUG, StreamHandler, FileHandler
import pytest
from logger_ import init_logger, Logger
import logger_
from testfixtures import LogCapture
class TestLogger():
""""Проверка функции logger."""
def test_success(self):
"""Успешное выполнение."""
log = logger_.logger()
assert isinstance(log, Logger)
class TestInitLogger():
""""Проверка функции logger."""
def test_success(self):
"""Успешное выполнение."""
log = init_logger(r'c:\lg')
assert isinstance(log, Logger)
assert log.name == logger_.LOGGER_NAME
assert log.level == DEBUG
assert len(log.handlers) == 2
class TestGetFileHandler():
""""Проверка функции _get_file_handler."""
def test_success(self):
"""Успешное выполнение."""
log = logger_._get_file_handler(r'c:\lg')
assert isinstance(log, FileHandler)
assert log.level == logger_.DEBUG
class TestGetStreamHandler():
""""Проверка функции _get_stream_handler."""
def test_success(self):
"""Успешное выполнение."""
log = logger_._get_stream_handler()
assert isinstance(log, StreamHandler)
assert log.level == logger_.INFO
class TestHandleAndLogExceptionsException():
""""Проверка декоратора handle_and_log_exceptions."""
def test_success(self):
"""Успешный результат."""
func_result = 4
assert self.for_success(func_result) == func_result
def test_exception(self):
"""Nсключения."""
with LogCapture() as logs:
self.for_exception()
assert not logs.records[0].exc_info is None
@logger_.handle_and_log_exceptions
def for_exception(self):
"""Для проверки исключений"""
raise
@logger_.handle_and_log_exceptions
def for_success(self, func_result):
"""Для проверки успешного результата"""
return func_result
class TestLogFunc():
""""Проверка декоратора log_func."""
def test_common(self):
"""Общее логирование для любых результатов."""
with LogCapture() as logs:
self.for_test_log_func()
msg1 = 'for_test_log_func. Выполнилось за'
msg1_len = len(msg1)
assert len(logs.records) == 2
assert logs.records[0].msg == 'for_test_log_func. Началось'
assert logs.records[1].msg[:msg1_len] == msg1
@pytest.mark.parametrize('func_result, msg_log_end',
[(True, 'Успешно'),
(False, 'Неуспешно'),
('Прочее', 'Прочее')])
def test_boolean(self, func_result, msg_log_end):
"""Логирование всех вариантов результата."""
with LogCapture() as logs:
self.for_test_log_func(func_result)
msg_len = len(msg_log_end)
assert logs.records[1].msg[-msg_len:] == msg_log_end
@logger_.log_func
def for_test_log_func(self, func_result=None):
""""Вызываемая функция при тестировании"""
return func_result