40 lines
1.6 KiB
Python
40 lines
1.6 KiB
Python
from __future__ import annotations
|
|
|
|
from pytest import MonkeyPatch
|
|
|
|
from core.config.settings import Settings
|
|
|
|
|
|
def test_runtime_settings_defaults() -> None:
|
|
settings = Settings()
|
|
|
|
assert settings.runtime.log_json is True
|
|
assert settings.runtime.log_rotation == "time"
|
|
assert settings.runtime.log_rotation_when == "midnight"
|
|
assert settings.runtime.log_rotation_interval == 1
|
|
assert settings.runtime.log_rotation_backup_count == 14
|
|
assert settings.runtime.log_rotation_max_bytes == 10_000_000
|
|
assert settings.runtime.log_dir == "logs"
|
|
assert settings.runtime.log_error_dir == "logs/errors"
|
|
assert settings.runtime.log_file_name == "app.log"
|
|
assert settings.runtime.log_error_file_name == "error.log"
|
|
assert "password" in settings.runtime.log_sensitive_fields
|
|
|
|
|
|
def test_runtime_settings_env_override(monkeypatch: MonkeyPatch) -> None:
|
|
monkeypatch.setenv("SOCIAL_RUNTIME__LOG_DIR", "var/logs")
|
|
monkeypatch.setenv("SOCIAL_RUNTIME__LOG_ERROR_DIR", "var/logs/errors")
|
|
monkeypatch.setenv("SOCIAL_RUNTIME__LOG_FILE_NAME", "custom.log")
|
|
monkeypatch.setenv("SOCIAL_RUNTIME__LOG_ERROR_FILE_NAME", "custom-error.log")
|
|
monkeypatch.setenv("SOCIAL_RUNTIME__LOG_ROTATION", "size")
|
|
monkeypatch.setenv("SOCIAL_RUNTIME__LOG_ROTATION_MAX_BYTES", "2048")
|
|
|
|
settings = Settings()
|
|
|
|
assert settings.runtime.log_dir == "logs"
|
|
assert settings.runtime.log_error_dir == "logs/errors"
|
|
assert settings.runtime.log_file_name == "app.log"
|
|
assert settings.runtime.log_error_file_name == "error.log"
|
|
assert settings.runtime.log_rotation == "size"
|
|
assert settings.runtime.log_rotation_max_bytes == 2048
|