changes
This commit is contained in:
@@ -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
|
||||
|
||||
Reference in New Issue
Block a user