"""
Migration to add execution_tracker table for improved parallelism control.

This replaces the company_execution_locks table with a more flexible system that:
- Tracks all running evaluations globally (max 4)
- Enforces per-company limits (max 2)
- Provides better cancellation handling
"""

from django.db import migrations


class Migration(migrations.Migration):

    dependencies = [
        ('model_evaluation', '0006_add_admin_override_to_subquestion_answers'),
    ]

    operations = [
        migrations.RunSQL(
            """
            -- Create new execution_tracker table
            CREATE TABLE IF NOT EXISTS execution_tracker (
                id INTEGER PRIMARY KEY AUTOINCREMENT,
                queue_id INTEGER NOT NULL,
                company_id INTEGER NOT NULL,
                model_id INTEGER NOT NULL,
                question_id INTEGER NOT NULL,
                attempt_number INTEGER NOT NULL,
                subprocess_pid INTEGER,
                started_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
                
                FOREIGN KEY (queue_id) REFERENCES evaluation_queue(id) ON DELETE CASCADE,
                FOREIGN KEY (company_id) REFERENCES companies(id) ON DELETE CASCADE,
                FOREIGN KEY (model_id) REFERENCES models(id) ON DELETE CASCADE,
                FOREIGN KEY (question_id) REFERENCES questions(id) ON DELETE CASCADE
            );
            
            -- Create indexes for efficient queries
            CREATE INDEX IF NOT EXISTS idx_execution_tracker_company 
                ON execution_tracker(company_id);
            CREATE INDEX IF NOT EXISTS idx_execution_tracker_queue 
                ON execution_tracker(queue_id);
            CREATE INDEX IF NOT EXISTS idx_execution_tracker_started 
                ON execution_tracker(started_at);
            
            -- Add unique constraint to prevent duplicate queue entries
            CREATE UNIQUE INDEX IF NOT EXISTS idx_execution_tracker_queue_unique 
                ON execution_tracker(queue_id);
            """,
            
            reverse_sql="""
            DROP TABLE IF EXISTS execution_tracker;
            """
        ),
    ]