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_ROTATION", "size") monkeypatch.setenv("SOCIAL_RUNTIME__LOG_ROTATION_MAX_BYTES", "2048") settings = Settings() assert settings.runtime.log_dir == "var/logs" assert settings.runtime.log_error_dir == "var/logs/errors" assert settings.runtime.log_rotation == "size" assert settings.runtime.log_rotation_max_bytes == 2048