LinkDesk/backend/test_bulk_shot_project_vali...

183 lines
5.9 KiB
Python

"""
Test script for bulk shot creation project consistency validation
Tests the enhanced bulk shot creation with project validation
"""
import requests
import json
BASE_URL = "http://localhost:8000"
# Test credentials
LOGIN_DATA = {
"email": "admin@vfx.com",
"password": "admin123"
}
def login():
"""Login and get access token"""
response = requests.post(f"{BASE_URL}/auth/login", json=LOGIN_DATA)
if response.status_code == 200:
return response.json()["access_token"]
else:
print(f"Login failed: {response.status_code}")
return None
def test_bulk_shot_project_validation():
"""Test bulk shot creation with project validation"""
print("=== Test: Bulk Shot Creation Project Validation ===\n")
token = login()
if not token:
return
headers = {"Authorization": f"Bearer {token}"}
episode_id = 1 # Assuming this exists
# Test 1: Valid bulk shot creation
print("1. Testing valid bulk shot creation...")
bulk_data = {
"name_prefix": "TEST_BULK_",
"shot_count": 3,
"start_number": 100,
"number_padding": 3,
"frame_start": 1001,
"frame_end": 1100,
"description_template": "Test shot {shot_name} for validation",
"create_default_tasks": True
}
response = requests.post(
f"{BASE_URL}/shots/bulk?episode_id={episode_id}",
headers=headers,
json=bulk_data
)
print(f" Status: {response.status_code}")
if response.status_code == 201:
result = response.json()
print(f" ✓ Success: {result['message']}")
print(f" ✓ Created shots: {len(result['created_shots'])}")
print(f" ✓ All shots have same project_id: {all(shot['project_id'] == result['created_shots'][0]['project_id'] for shot in result['created_shots'])}")
# Store project_id for later tests
project_id = result['created_shots'][0]['project_id']
print(f" ✓ Project ID: {project_id}")
print(f"\n Shot names created:")
for shot in result['created_shots']:
print(f" - {shot['name']} (ID: {shot['id']}, Project: {shot['project_id']})")
else:
print(f" ✗ Error: {response.json()}")
return
# Test 2: Duplicate name validation within project
print("\n2. Testing duplicate name validation...")
duplicate_data = {
"name_prefix": "TEST_BULK_",
"shot_count": 2,
"start_number": 100, # Same as above - should conflict
"number_padding": 3,
"frame_start": 1001,
"frame_end": 1100,
"create_default_tasks": False
}
response = requests.post(
f"{BASE_URL}/shots/bulk?episode_id={episode_id}",
headers=headers,
json=duplicate_data
)
print(f" Status: {response.status_code}")
if response.status_code == 400:
error = response.json()
print(f" ✓ Correctly rejected duplicate names: {error['detail']}")
else:
print(f" ✗ Should have rejected duplicate names: {response.json()}")
# Test 3: Internal duplicate validation
print("\n3. Testing internal duplicate validation...")
internal_duplicate_data = {
"name_prefix": "DUP_",
"shot_count": 3,
"start_number": 1,
"number_padding": 1, # This will create DUP_1, DUP_2, DUP_3 - no duplicates
"frame_start": 1001,
"frame_end": 1100,
"create_default_tasks": False
}
response = requests.post(
f"{BASE_URL}/shots/bulk?episode_id={episode_id}",
headers=headers,
json=internal_duplicate_data
)
print(f" Status: {response.status_code}")
if response.status_code == 201:
result = response.json()
print(f" ✓ No internal duplicates - created successfully: {result['message']}")
else:
print(f" ✗ Unexpected error: {response.json()}")
# Test 4: Frame range validation
print("\n4. Testing frame range validation...")
invalid_frame_data = {
"name_prefix": "FRAME_",
"shot_count": 1,
"start_number": 1,
"number_padding": 3,
"frame_start": 1100,
"frame_end": 1001, # Invalid: end < start
"create_default_tasks": False
}
response = requests.post(
f"{BASE_URL}/shots/bulk?episode_id={episode_id}",
headers=headers,
json=invalid_frame_data
)
print(f" Status: {response.status_code}")
if response.status_code == 400:
error = response.json()
print(f" ✓ Correctly rejected invalid frame range: {error['detail']}")
else:
print(f" ✗ Should have rejected invalid frame range: {response.json()}")
# Test 5: Project consistency verification
print("\n5. Testing project consistency...")
consistency_data = {
"name_prefix": "CONSISTENCY_",
"shot_count": 5,
"start_number": 1,
"number_padding": 2,
"frame_start": 1001,
"frame_end": 1200,
"create_default_tasks": True
}
response = requests.post(
f"{BASE_URL}/shots/bulk?episode_id={episode_id}",
headers=headers,
json=consistency_data
)
print(f" Status: {response.status_code}")
if response.status_code == 201:
result = response.json()
project_ids = [shot['project_id'] for shot in result['created_shots']]
all_same_project = len(set(project_ids)) == 1
print(f" ✓ All shots have same project_id: {all_same_project}")
print(f" ✓ Project ID: {project_ids[0] if project_ids else 'None'}")
print(f" ✓ Created {len(result['created_shots'])} shots with {result['created_tasks_count']} tasks")
else:
print(f" ✗ Error: {response.json()}")
print("\n=== Test Completed ===")
if __name__ == "__main__":
test_bulk_shot_project_validation()