-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathtest_logger.py
More file actions
43 lines (29 loc) · 1.14 KB
/
test_logger.py
File metadata and controls
43 lines (29 loc) · 1.14 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
"""Tests for utils/logger.py"""
import logging
import pytest
from utils.logger import get_logger
def test_get_logger_returns_logger():
log = get_logger("test.basic")
assert isinstance(log, logging.Logger)
def test_get_logger_same_name_is_idempotent():
log1 = get_logger("test.idempotent")
log2 = get_logger("test.idempotent")
assert log1 is log2
def test_get_logger_level_debug():
log = get_logger("test.debug_level", level="DEBUG")
assert log.level == logging.DEBUG
def test_get_logger_level_warning():
log = get_logger("test.warn_level", level="WARNING")
assert log.level == logging.WARNING
def test_get_logger_has_console_handler():
log = get_logger("test.console")
assert len(log.handlers) >= 1
def test_get_logger_file_handler(tmp_path):
log_file = tmp_path / "app.log"
log = get_logger("test.file_handler", log_file=log_file)
assert log_file.parent.exists()
handlers = [type(h).__name__ for h in log.handlers]
assert "RotatingFileHandler" in handlers
def test_logger_can_log_without_error(caplog):
log = get_logger("test.log_output", level="DEBUG")
log.info("hello from test")