"""
Demo script for running a single puzzle test
"""
import sys
import os
import asyncio
import logging

# Add the code directory to sys.path to enable imports
code_dir = os.path.dirname(os.path.abspath(__file__))
sys.path.insert(0, code_dir)

from core.puzzle_system import PuzzleBenchmarkSystem


def setup_logging():
    logging.basicConfig(
        level=logging.INFO,
        format='%(asctime)s - %(name)s - %(levelname)s - %(message)s'
    )


async def demo_single_puzzle():
    print("=== Single Puzzle Demo ===")
    
    system = PuzzleBenchmarkSystem()

    domains = system.get_available_domains()
    if not domains:
        print("No domains available!")
        return
    
    # Use the first available domain
    domain = domains[0]
    puzzles = system.get_domain_puzzles(domain)
    if not puzzles:
        print(f"No puzzles in domain: {domain}")
        return
    
    puzzle = puzzles[0]
    print(f"\nTesting puzzle: {puzzle.name}")
    print(f"Domain: {puzzle.domain}")
    print(f"Description preview: {puzzle.description[:100]}...")
    
    print(f"\nStarting game session...")
    
    try:
        result = await system.run_single_puzzle(domain, puzzle.name, f"demo_{puzzle.name[:10]}")
        
        print(f"\n=== Test Results ===")
        print(f"Session ID: {result.session_id}")
        print(f"Success: {result.success}")
        print(f"Total rounds: {result.total_rounds}")
        print(f"Final answer: {result.final_result.get('final_answer', 'None')}")
        print(f"End reason: {result.final_result.get('reason')}")
        
        print(f"\n=== Round Details ===")
        for i, round_data in enumerate(result.rounds):
            print(f"\nRound {round_data.round}:")
            print(f"  QA Question: {round_data.qa_response[:100]}...")
            print(f"  EVAL Response: {round_data.eval_response[:100]}...")
            print(f"  Pure Parse: {round_data.pure_parse}")
            print(f"  Pure Answer: {round_data.pure_answer}")
            
            if i >= 2: 
                print(f"  ... and {len(result.rounds) - 3} more rounds")
                break
        
        return result
        
    except Exception as e:
        print(f"Error running test: {e}")
        import traceback
        traceback.print_exc()
        return None


if __name__ == "__main__":
    setup_logging()
    result = asyncio.run(demo_single_puzzle())
    
    if result:
        print(f"\n✓ Demo completed successfully!")
        print(f"  Check logs at: data/logs/sessions/{result.session_id}/")
    else:
        print(f"\n✗ Demo failed") 