"""Unit tests for main.py loading utility functions."""

import pytest
import tempfile
import csv
from pathlib import Path
from unittest.mock import patch, mock_open
from src.main import load_optimal_solutions


class TestLoadOptimalSolutions:
    """Test cases for load_optimal_solutions function."""
    
    def test_load_optimal_solutions_success(self):
        """Test successful loading of optimal solutions from CSV."""
        # Create temporary CSV content
        csv_content = """solution description,concept level description
"A smart traffic management system that uses real-time sensors and AI to dynamically adjust bridge traffic flow based on current demand, weather conditions, and emergency situations.","A system where real-time sensors and AI algorithms continuously monitor traffic patterns and environmental conditions to dynamically optimize bridge traffic flow through automated lane management and predictive routing decisions."
"A comprehensive bridge maintenance system that employs IoT sensors, drones, and machine learning to predict and prevent structural issues before they become critical.","A system where IoT sensors and predictive analytics continuously assess bridge structural integrity and automatically schedule maintenance interventions based on real-time health monitoring and failure prediction algorithms."
"""
        
        with patch('pathlib.Path.exists', return_value=True):
            with patch('builtins.open', mock_open(read_data=csv_content)):
                descriptions, concepts = load_optimal_solutions("bridge")
                
                assert len(descriptions) == 2
                assert len(concepts) == 2
                assert "smart traffic management system" in descriptions[0]
                assert "real-time sensors and AI algorithms" in concepts[0]
                assert "comprehensive bridge maintenance system" in descriptions[1]
                assert "IoT sensors and predictive analytics" in concepts[1]
    
    def test_load_optimal_solutions_file_not_found(self):
        """Test FileNotFoundError when CSV file doesn't exist."""
        with patch('pathlib.Path.exists', return_value=False):
            with pytest.raises(FileNotFoundError, match="Optimal solutions file not found"):
                load_optimal_solutions("nonexistent_task")
    
    def test_load_optimal_solutions_missing_solution_description_column(self):
        """Test ValueError when 'solution description' column is missing."""
        csv_content = """concept level description
"A system where real-time sensors and AI algorithms continuously monitor traffic patterns."
"""
        
        with patch('pathlib.Path.exists', return_value=True):
            with patch('builtins.open', mock_open(read_data=csv_content)):
                with pytest.raises(ValueError, match="Required column 'solution description' not found"):
                    load_optimal_solutions("bridge")
    
    def test_load_optimal_solutions_missing_concept_column(self):
        """Test ValueError when 'concept level description' column is missing."""
        csv_content = """solution description
"A smart traffic management system that uses real-time sensors and AI."
"""
        
        with patch('pathlib.Path.exists', return_value=True):
            with patch('builtins.open', mock_open(read_data=csv_content)):
                with pytest.raises(ValueError, match="Required column 'concept level description' not found"):
                    load_optimal_solutions("bridge")
    
    def test_load_optimal_solutions_empty_file(self):
        """Test handling of empty CSV file."""
        csv_content = """solution description,concept level description
"""
        
        with patch('pathlib.Path.exists', return_value=True):
            with patch('builtins.open', mock_open(read_data=csv_content)):
                descriptions, concepts = load_optimal_solutions("bridge")
                
                assert len(descriptions) == 0
                assert len(concepts) == 0
    
    def test_load_optimal_solutions_with_empty_rows(self):
        """Test handling of CSV with empty rows."""
        csv_content = """solution description,concept level description
"A smart traffic management system.","A system where real-time sensors monitor traffic."

"A comprehensive bridge maintenance system.","A system where IoT sensors assess bridge health."
"""
        
        with patch('pathlib.Path.exists', return_value=True):
            with patch('builtins.open', mock_open(read_data=csv_content)):
                descriptions, concepts = load_optimal_solutions("bridge")
                
                assert len(descriptions) == 2
                assert len(concepts) == 2
                assert "smart traffic management system" in descriptions[0]
                assert "comprehensive bridge maintenance system" in descriptions[1]
    
    def test_load_optimal_solutions_io_error(self):
        """Test IOError when file cannot be read."""
        with patch('pathlib.Path.exists', return_value=True):
            with patch('builtins.open', side_effect=IOError("Permission denied")):
                with pytest.raises(IOError, match="Failed to read optimal solutions file"):
                    load_optimal_solutions("bridge")
    
    def test_load_optimal_solutions_csv_parse_error(self):
        """Test handling of malformed CSV."""
        # Create a CSV with an unclosed quote to trigger a parsing error
        csv_content = """solution description,concept level description
"A smart traffic management system.","A system where real-time sensors monitor traffic.
"""
        
        with patch('pathlib.Path.exists', return_value=True):
            with patch('builtins.open', mock_open(read_data=csv_content)):
                # The CSV parsing might not actually fail with this content, so let's test a different approach
                # by mocking the csv.DictReader to raise an exception
                with patch('csv.DictReader', side_effect=csv.Error("CSV parsing error")):
                    with pytest.raises(IOError, match="Failed to parse CSV file"):
                        load_optimal_solutions("bridge")