"""
Detailed debugging of COTCAgent API calls
"""

from cotc_agent import DeepSeekClient, DeepSeekConfig
import json
import asyncio

async def debug_with_detailed_error():
    config = DeepSeekConfig(
        api_key='sk-687c00f17caa45eaaa9756e96f49f6dc',
        api_base='https://api.deepseek.com/v1/chat/completions',
        model='deepseek-chat',
        max_tokens=2000,  # Increase max_tokens
        temperature=0.7,
        timeout=60  # Increase timeout
    )

    client = DeepSeekClient(config)

    # Load patient data
    with open('patient_data/patient_0001.json', 'r', encoding='utf-8') as f:
        patient_data = json.load(f)

    # Test with a shorter version first
    print("🧪 测试简化版prompt...")
    try:
        short_prompt = "You are an expert medical data analyst. Please analyze this patient data and generate Python code for temporal analysis."

        response = await client.chat_completion([
            {"role": "user", "content": short_prompt}
        ])

        print("✅ 简化版prompt成功")
        content = response.get('choices', [{}])[0].get('message', {}).get('content', '')
        print(f"响应长度: {len(content)} 字符")

    except Exception as e:
        print(f"❌ 简化版prompt失败: {e}")
        return

    # Test with actual prompt but smaller max_tokens
    print("\n🧪 测试实际prompt (max_tokens=500)...")
    try:
        original_max_tokens = config.max_tokens
        config.max_tokens = 500

        prompt = client.generate_temporal_analysis_prompt(patient_data, '测试查询')

        response = await client.chat_completion([
            {"role": "user", "content": prompt}
        ])

        print("✅ 实际prompt成功 (max_tokens=500)")
        content = response.get('choices', [{}])[0].get('message', {}).get('content', '')
        print(f"响应长度: {len(content)} 字符")

        # Restore original max_tokens
        config.max_tokens = original_max_tokens

    except Exception as e:
        print(f"❌ 实际prompt失败: {e}")
        print("💡 可能是max_tokens设置太小，尝试增加max_tokens...")

        # Try with larger max_tokens
        try:
            config.max_tokens = 3000

            response = await client.chat_completion([
                {"role": "user", "content": prompt}
            ])

            print("✅ 实际prompt成功 (max_tokens=3000)")
            content = response.get('choices', [{}])[0].get('message', {}).get('content', '')
            print(f"响应长度: {len(content)} 字符")

        except Exception as e2:
            print(f"❌ 即使max_tokens=3000也失败: {e2}")

if __name__ == "__main__":
    asyncio.run(debug_with_detailed_error())
