loguru/tests/test_add_option_level.py

30 lines
815 B
Python

import pytest
from loguru import logger
@pytest.mark.parametrize("level", [0, "TRACE", "INFO", 20])
def test_level_low_enough(writer, level):
logger.add(writer, level=level, format="{message}")
logger.info("Test level")
assert writer.read() == "Test level\n"
@pytest.mark.parametrize("level", ["WARNING", 25])
def test_level_too_high(writer, level):
logger.add(writer, level=level, format="{message}")
logger.info("Test level")
assert writer.read() == ""
@pytest.mark.parametrize("level", [3.4, object()])
def test_invalid_level(writer, level):
with pytest.raises(TypeError):
logger.add(writer, level=level)
@pytest.mark.parametrize("level", ["foo", -1])
def test_unknown_level(writer, level):
with pytest.raises(ValueError):
logger.add(writer, level=level)