Some checks failed
Build and Push Docker Image / build-and-push (push) Has been cancelled
- Introduced `quick_test.py` for running specific test categories (unit, integration, theme, all). - Updated `run_tests.py` to improve test execution and reporting, including coverage. - Removed outdated test scripts for keyboard shortcuts, menu theming, note saving, and entry updating. - Added new test script `test_theme_changing.py` to verify theme changing functionality. - Consolidated integration tests into `test_integration.py` for comprehensive testing of TheChart application. - Updated theme manager to ensure color retrieval works correctly. - Modified test constants to import from the correct module path.
132 lines
4.5 KiB
Python
132 lines
4.5 KiB
Python
"""
|
|
Tests for constants module.
|
|
"""
|
|
import os
|
|
from unittest.mock import patch
|
|
|
|
import sys
|
|
sys.path.insert(0, os.path.join(os.path.dirname(__file__), '..', 'src'))
|
|
|
|
|
|
class TestConstants:
|
|
"""Test cases for the constants module."""
|
|
|
|
def test_default_log_level(self):
|
|
"""Test default LOG_LEVEL when not set in environment."""
|
|
with patch.dict(os.environ, {}, clear=True):
|
|
# Re-import to get fresh values
|
|
import importlib
|
|
if 'constants' in sys.modules:
|
|
importlib.reload(sys.modules['constants'])
|
|
import constants
|
|
else:
|
|
import constants
|
|
|
|
assert constants.LOG_LEVEL == "INFO"
|
|
|
|
def test_custom_log_level(self):
|
|
"""Test custom LOG_LEVEL from environment."""
|
|
with patch.dict(os.environ, {'LOG_LEVEL': 'debug'}, clear=True):
|
|
import importlib
|
|
if 'constants' in sys.modules:
|
|
importlib.reload(sys.modules['constants'])
|
|
import constants
|
|
else:
|
|
import constants
|
|
|
|
assert constants.LOG_LEVEL == "DEBUG"
|
|
|
|
def test_default_log_path(self):
|
|
"""Test default LOG_PATH when not set in environment."""
|
|
with patch.dict(os.environ, {}, clear=True):
|
|
import importlib
|
|
if 'constants' in sys.modules:
|
|
importlib.reload(sys.modules['constants'])
|
|
else:
|
|
import constants
|
|
|
|
assert constants.LOG_PATH == "/tmp/logs/thechart"
|
|
|
|
def test_custom_log_path(self):
|
|
"""Test custom LOG_PATH from environment."""
|
|
with patch.dict(os.environ, {'LOG_PATH': '/custom/log/path'}, clear=True):
|
|
import importlib
|
|
if 'constants' in sys.modules:
|
|
importlib.reload(sys.modules['constants'])
|
|
else:
|
|
import constants
|
|
|
|
assert constants.LOG_PATH == "/custom/log/path"
|
|
|
|
def test_default_log_clear(self):
|
|
"""Test default LOG_CLEAR when not set in environment."""
|
|
with patch.dict(os.environ, {}, clear=True):
|
|
import importlib
|
|
if 'constants' in sys.modules:
|
|
importlib.reload(sys.modules['constants'])
|
|
else:
|
|
import constants
|
|
|
|
assert constants.LOG_CLEAR == "False"
|
|
|
|
def test_custom_log_clear_true(self):
|
|
"""Test LOG_CLEAR when set to true in environment."""
|
|
with patch.dict(os.environ, {'LOG_CLEAR': 'true'}, clear=True):
|
|
import importlib
|
|
if 'constants' in sys.modules:
|
|
importlib.reload(sys.modules['constants'])
|
|
else:
|
|
import constants
|
|
|
|
assert constants.LOG_CLEAR == "True"
|
|
|
|
def test_custom_log_clear_false(self):
|
|
"""Test LOG_CLEAR when set to false in environment."""
|
|
with patch.dict(os.environ, {'LOG_CLEAR': 'false'}, clear=True):
|
|
import importlib
|
|
if 'constants' in sys.modules:
|
|
importlib.reload(sys.modules['constants'])
|
|
else:
|
|
import constants
|
|
|
|
assert constants.LOG_CLEAR == "False"
|
|
|
|
def test_log_level_case_insensitive(self):
|
|
"""Test that LOG_LEVEL is converted to uppercase."""
|
|
with patch.dict(os.environ, {'LOG_LEVEL': 'warning'}, clear=True):
|
|
import importlib
|
|
if 'constants' in sys.modules:
|
|
importlib.reload(sys.modules['constants'])
|
|
else:
|
|
import constants
|
|
|
|
assert constants.LOG_LEVEL == "WARNING"
|
|
|
|
def test_dotenv_override(self):
|
|
"""Test that dotenv override parameter is set to True."""
|
|
# This is a structural test since dotenv is loaded during import
|
|
with patch('constants.load_dotenv') as mock_load_dotenv:
|
|
import importlib
|
|
if 'constants' in sys.modules:
|
|
importlib.reload(sys.modules['constants'])
|
|
else:
|
|
import constants
|
|
|
|
mock_load_dotenv.assert_called_once_with(override=True)
|
|
|
|
def test_all_constants_are_strings(self):
|
|
"""Test that all constants are string type."""
|
|
import constants
|
|
|
|
assert isinstance(constants.LOG_LEVEL, str)
|
|
assert isinstance(constants.LOG_PATH, str)
|
|
assert isinstance(constants.LOG_CLEAR, str)
|
|
|
|
def test_constants_not_empty(self):
|
|
"""Test that constants are not empty strings."""
|
|
import constants
|
|
|
|
assert constants.LOG_LEVEL != ""
|
|
assert constants.LOG_PATH != ""
|
|
assert constants.LOG_CLEAR != ""
|