"""
Main puzzle benchmark system controller
"""
import logging
import sys
import os
from typing import List, Dict, Any, Optional

# Add necessary paths for imports
current_dir = os.path.dirname(os.path.abspath(__file__))
parent_dir = os.path.dirname(current_dir)
sys.path.append(current_dir)
sys.path.append(parent_dir)

from data_manager import DataManager, PuzzleData
from game_session import GameSession, SessionResult
from logger_manager import LoggerManager
from config import DOMAINS

logger = logging.getLogger(__name__)


class PuzzleBenchmarkSystem:
    """Main controller for puzzle benchmark testing system"""
    
    def __init__(self):
        self.data_manager = DataManager()
        self.logger_manager = LoggerManager()
        logger.info("Puzzle benchmark system initialized")
    
    async def run_single_puzzle(
        self, 
        domain: str, 
        puzzle_name: str, 
        session_id: Optional[str] = None
    ) -> SessionResult:
        """Run a single puzzle test"""
        logger.info(f"Starting single puzzle test: {domain}/{puzzle_name}")
        
        # Get puzzle data
        puzzle = self.data_manager.get_puzzle_by_name(domain, puzzle_name)
        if not puzzle:
            raise ValueError(f"Puzzle not found: {domain}/{puzzle_name}")
        
        # Create game session (using default models)
        session = GameSession(puzzle)
        
        # Run the test
        result = await session.run_full_game()
        
        # Save logs
        self.logger_manager.save_session_log(result)
        
        logger.info(f"Single puzzle test completed: {result.session_id}, Success: {result.success}")
        return result
    
    def get_available_domains(self) -> List[str]:
        """Get available testing domains"""
        return self.data_manager.get_all_domains()
    
    def get_domain_puzzles(self, domain: str) -> List[PuzzleData]:
        """Get all puzzles in the specified domain"""
        return self.data_manager.load_domain_data(domain)
    
    def get_session_log(self, session_id: str) -> Dict[str, Any]:
        """Get detailed log for the specified session"""
        return self.logger_manager.load_session_log(session_id)
    
    def list_sessions(
        self, 
        domain: Optional[str] = None, 
        date_filter: Optional[str] = None
    ) -> List[str]:
        """List sessions"""
        return self.logger_manager.list_sessions(domain, date_filter)
    
    def get_results_summary(self, date_filter: Optional[str] = None) -> List[Dict[str, Any]]:
        """Get test results summary"""
        return self.logger_manager.get_results_summary(date_filter)
    
    def refresh_data(self):
        """Refresh data cache"""
        self.data_manager.refresh_cache()
        logger.info("Data cache refreshed")
    
    async def test_system_connectivity(self) -> Dict[str, Any]:
        """Test system connectivity (API connections, data loading, etc.)"""
        logger.info("Testing system connectivity...")
        
        connectivity_results = {
            "api_test": False,
            "data_test": False,
            "domains_available": [],
            "total_puzzles": 0,
            "errors": []
        }
        
        try:
            # Test data loading
            available_domains = self.get_available_domains()
            connectivity_results["domains_available"] = available_domains
            
            total_puzzles = 0
            for domain in available_domains:
                puzzles = self.get_domain_puzzles(domain)
                total_puzzles += len(puzzles)
            
            connectivity_results["total_puzzles"] = total_puzzles
            connectivity_results["data_test"] = total_puzzles > 0
            
            # Test API connection (if test data is available)
            if total_puzzles > 0:
                # Find a test puzzle
                test_domain = available_domains[0]
                test_puzzles = self.get_domain_puzzles(test_domain)
                if test_puzzles:
                    test_puzzle = test_puzzles[0]
                    
                    # Create a test session, run only one round
                    session = GameSession(test_puzzle)
                    
                    try:
                        # Run only one round to test API
                        round_data = await session.play_round()
                        connectivity_results["api_test"] = "API Error" not in round_data.qa_response
                    except Exception as e:
                        connectivity_results["errors"].append(f"API test failed: {str(e)}")
            
        except Exception as e:
            connectivity_results["errors"].append(f"System test failed: {str(e)}")
        
        logger.info(f"System connectivity test completed: {connectivity_results}")
        return connectivity_results