feat: create libretime_shared package (#1349)
* feat: create libretime_shared package - We don't use pydantic.BaseSettings because of some incompatble loading behavior. * fix: whitelist pydantic in pylintrc * docs: update to new BaseConfig behavior * docs: change confusing config filepath
This commit is contained in:
parent
ba8b51af76
commit
3a615cafa0
13 changed files with 568 additions and 0 deletions
47
shared/tests/logging_test.py
Normal file
47
shared/tests/logging_test.py
Normal file
|
@ -0,0 +1,47 @@
|
|||
from pathlib import Path
|
||||
|
||||
import pytest
|
||||
from loguru import logger
|
||||
|
||||
from libretime_shared.logging import (
|
||||
create_task_logger,
|
||||
level_from_verbosity,
|
||||
setup_logger,
|
||||
)
|
||||
|
||||
|
||||
@pytest.mark.parametrize(
|
||||
"verbosity,level_name,level_no",
|
||||
[
|
||||
(-100, "error", 40),
|
||||
(-1, "error", 40),
|
||||
(0, "warning", 30),
|
||||
(1, "info", 20),
|
||||
(2, "debug", 10),
|
||||
(3, "trace", 5),
|
||||
(100, "trace", 5),
|
||||
],
|
||||
)
|
||||
def test_level_from_verbosity(verbosity, level_name, level_no):
|
||||
level = level_from_verbosity(verbosity)
|
||||
assert level.name == level_name
|
||||
assert level.no == level_no
|
||||
|
||||
|
||||
def test_setup_logger(tmp_path: Path):
|
||||
log_filepath = tmp_path / "test.log"
|
||||
extra_log_filepath = tmp_path / "extra.log"
|
||||
|
||||
setup_logger(1, log_filepath)
|
||||
|
||||
extra_logger = create_task_logger(2, extra_log_filepath, True)
|
||||
|
||||
logger.info("test info")
|
||||
extra_logger.info("extra info")
|
||||
logger.debug("test debug")
|
||||
|
||||
extra_logger.complete()
|
||||
logger.complete()
|
||||
|
||||
assert len(log_filepath.read_text().splitlines()) == 1
|
||||
assert len(extra_log_filepath.read_text().splitlines()) == 1
|
Loading…
Add table
Add a link
Reference in a new issue