"""
Debug the full COTCAgent flow step by step
"""

from cotc_agent import COTCAgent, DeepSeekConfig, TemporalHealthAnalyzer, DeepSeekClient
import json
import asyncio

async def debug_step_by_step():
    config = DeepSeekConfig(
        api_key='sk-687c00f17caa45eaaa9756e96f49f6dc',
        api_base='https://api.deepseek.com/v1/chat/completions',
        model='deepseek-chat',
        max_tokens=3000,
        temperature=0.7,
        timeout=60
    )

    agent = COTCAgent(config)

    # Load patient data
    with open('patient_data/patient_0001.json', 'r', encoding='utf-8') as f:
        patient_data = json.load(f)

    print("🔍 调试步骤1: 测试DeepSeek API客户端")
    try:
        from cotc_agent import DeepSeekClient
        client = DeepSeekClient(config)

        # Test API with a simple prompt
        response = await client.chat_completion([
            {"role": "user", "content": "Generate a simple Python function for calculating mean: def calculate_mean(numbers): return sum(numbers)/len(numbers)"}
        ])

        content = response.get('choices', [{}])[0].get('message', {}).get('content', '')
        print("✅ DeepSeek API客户端工作正常")
        print(f"   响应长度: {len(content)} 字符")

        # Check if the generated code can be extracted
        from cotc_agent import COTCAgent
        extracted_code = agent.extract_code_from_response(response)
        print(f"   提取的代码: {extracted_code}")

    except Exception as e:
        print(f"❌ DeepSeek API客户端失败: {e}")
        return

    print("\n🔍 调试步骤2: 测试时序分析器")
    try:
        analyzer = TemporalHealthAnalyzer()
        processed_data = analyzer.preprocess_patient_data(patient_data)
        print(f"✅ 时序分析器工作正常")
        print(f"   处理了 {len(processed_data)} 个指标")

    except Exception as e:
        print(f"❌ 时序分析器失败: {e}")
        return

    print("\n🔍 调试步骤3: 测试疾病风险计算器")
    try:
        from cotc_agent import DiseaseRiskCalculator
        calculator = DiseaseRiskCalculator("disease_symptom_database.json", "symptoms_indicators_merged.json")
        print("✅ 疾病风险计算器初始化成功")

    except Exception as e:
        print(f"❌ 疾病风险计算器失败: {e}")
        return

    print("\n🔍 调试步骤4: 测试完整流程")
    try:
        result = await agent.process_user_query('我最近肠胃老是疼，而且头也经常晕，晚上睡不着觉', patient_data)
        print("🎉 完整流程成功！")

        disease_risks = result.get('disease_risks', [])
        print(f"   发现 {len(disease_risks)} 个疾病风险")

        questions = result.get('active_inquiry_questions', [])
        print(f"   生成 {len(questions)} 个问诊问题")

        return True

    except Exception as e:
        print(f"❌ 完整流程失败: {e}")
        return False

if __name__ == "__main__":
    success = asyncio.run(debug_step_by_step())
    if success:
        print("\n🎉 所有测试都通过了！COTCAgent现在可以正常使用DeepSeek API")
    else:
        print("\n⚠️  还有一些问题需要解决")
