guard terminal_tool import-time env parsing

This commit is contained in:
Yukipukii1 2026-04-22 22:38:56 +03:00 committed by Teknium
parent e86acad8f1
commit 44a16c5d9d
2 changed files with 60 additions and 2 deletions

View file

@ -1,5 +1,6 @@
"""Tests for _parse_env_var and _get_env_config env-var validation."""
import importlib
import json
from unittest.mock import patch
@ -84,3 +85,23 @@ class TestParseEnvVar:
with patch.dict("os.environ", {"TERMINAL_DOCKER_VOLUMES": "not json"}):
with pytest.raises(ValueError, match="valid JSON"):
_parse_env_var("TERMINAL_DOCKER_VOLUMES", "[]", json.loads, "valid JSON")
class TestImportTimeEnvParsing:
"""Module-level env parsing should never make terminal_tool unimportable."""
def test_invalid_foreground_timeout_falls_back_to_default(self):
try:
with patch.dict("os.environ", {"TERMINAL_MAX_FOREGROUND_TIMEOUT": "5m"}, clear=False):
mod = importlib.reload(_tt_mod)
assert mod.FOREGROUND_MAX_TIMEOUT == 600
finally:
importlib.reload(_tt_mod)
def test_invalid_disk_warning_threshold_falls_back_to_default(self):
try:
with patch.dict("os.environ", {"TERMINAL_DISK_WARNING_GB": "huge"}, clear=False):
mod = importlib.reload(_tt_mod)
assert mod.DISK_USAGE_WARNING_THRESHOLD_GB == 500.0
finally:
importlib.reload(_tt_mod)