Files
dolibarr-mcp/tests/test_config.py

101 lines
3.6 KiB
Python

"""
Test configuration module for Dolibarr MCP Server.
"""
import os
import pytest
from unittest.mock import patch
from pathlib import Path
from dolibarr_mcp.config import Config
class TestConfig:
"""Test configuration loading and validation."""
def test_config_from_env(self):
"""Test configuration loading from environment variables."""
with patch.dict(os.environ, {
'DOLIBARR_URL': 'https://test.dolibarr.com',
'DOLIBARR_API_KEY': 'test_key_123',
'LOG_LEVEL': 'DEBUG'
}):
config = Config()
assert config.dolibarr_url == 'https://test.dolibarr.com'
assert config.dolibarr_api_key == 'test_key_123'
assert config.log_level == 'DEBUG'
def test_config_defaults(self):
"""Test configuration defaults when env vars not set."""
with patch.dict(os.environ, {}, clear=True):
config = Config()
assert config.log_level == 'INFO' # Default log level
def test_config_validation(self):
"""Test configuration validation."""
with patch.dict(os.environ, {
'DOLIBARR_URL': '',
'DOLIBARR_API_KEY': ''
}):
with pytest.raises(ValueError, match="DOLIBARR_URL must be configured"):
config = Config()
config.validate()
def test_config_url_normalization(self):
"""Test URL normalization (removing trailing slashes)."""
with patch.dict(os.environ, {
'DOLIBARR_URL': 'https://test.dolibarr.com/',
'DOLIBARR_API_KEY': 'test_key'
}):
config = Config()
assert config.dolibarr_url == 'https://test.dolibarr.com'
assert not config.dolibarr_url.endswith('/')
def test_config_from_dotenv(self, tmp_path):
"""Test configuration loading from .env file."""
env_file = tmp_path / ".env"
env_file.write_text(
"DOLIBARR_URL=https://env.dolibarr.com\n"
"DOLIBARR_API_KEY=env_key_456\n"
"LOG_LEVEL=WARNING\n"
)
with patch.dict(os.environ, {'DOTENV_PATH': str(env_file)}):
config = Config()
assert config.dolibarr_url == 'https://env.dolibarr.com'
assert config.dolibarr_api_key == 'env_key_456'
assert config.log_level == 'WARNING'
def test_config_precedence(self):
"""Test that environment variables take precedence over .env file."""
with patch.dict(os.environ, {
'DOLIBARR_URL': 'https://env.dolibarr.com',
'DOLIBARR_API_KEY': 'env_key'
}):
config = Config()
assert config.dolibarr_url == 'https://env.dolibarr.com'
assert config.dolibarr_api_key == 'env_key'
def test_log_level_validation(self):
"""Test log level validation."""
valid_levels = ['DEBUG', 'INFO', 'WARNING', 'ERROR', 'CRITICAL']
for level in valid_levels:
with patch.dict(os.environ, {
'DOLIBARR_URL': 'https://test.com',
'DOLIBARR_API_KEY': 'key',
'LOG_LEVEL': level
}):
config = Config()
assert config.log_level == level
def test_invalid_log_level(self):
"""Test invalid log level falls back to default."""
with patch.dict(os.environ, {
'DOLIBARR_URL': 'https://test.com',
'DOLIBARR_API_KEY': 'key',
'LOG_LEVEL': 'INVALID'
}):
config = Config()
assert config.log_level == 'INFO' # Should fall back to default