import subprocess
import json
import sys
import time

# CONFIGURATION
DB_URL = "postgresql://postgres:password@localhost:5432/postgres"
MCP_EXEC = "/root/miniforge3/envs/mcp_mark/bin/postgres-mcp"

def run_suite():
    print("🚀 STARTING COMPLETE SYSTEM DIAGNOSTIC...")
    process = subprocess.Popen(
        [MCP_EXEC, DB_URL],
        stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=sys.stderr, text=True, bufsize=0
    )

    def send(req_id, method, params):
        process.stdin.write(json.dumps({"jsonrpc": "2.0", "id": req_id, "method": method, "params": params}) + "\n")
        time.sleep(0.5)

    # 1. HANDSHAKE
    send(0, "initialize", {"protocolVersion": "2024-11-05", "capabilities": {}, "clientInfo": {"name": "test", "version": "1.0"}})
    send(-1, "notifications/initialized", {}) # Notification has no ID

    # 2. DISCOVERY: list_schemas
    print("\n📋 TEST 1: Discovery (list_schemas)")
    send(1, "tools/call", {"name": "list_schemas", "arguments": {}})

    # 3. INSPECTION: get_object_details (Replaces describe_table)
    print("🔍 TEST 2: Inspection (get_object_details for 'users')")
    send(2, "tools/call", {
        "name": "get_object_details", 
        "arguments": {"schema": "public", "object_name": "users"}
    })

    # 4. DATA: execute_sql (Correct usage)
    print("💾 TEST 3: Data Access (execute_sql with 'sql')")
    send(3, "tools/call", {
        "name": "execute_sql", 
        "arguments": {"sql": "SELECT username, role FROM users LIMIT 1;"}
    })

    # 5. DIAGNOSTIC: Triggering the 'all' error intentionally
    print("💥 TEST 4: Verifying the Error Cause (Sending 'query' instead of 'sql')")
    print("   (You SHOULD see the 'syntax error at or near all' below)")
    send(4, "tools/call", {
        "name": "execute_sql", 
        "arguments": {"query": "SELECT * FROM users;"} # WRONG ARGUMENT NAME
    })

    # READER LOOP
    print("\n⬇️  SERVER RESPONSES:")
    while True:
        line = process.stdout.readline()
        if not line: break
        try:
            data = json.loads(line)
            rid = data.get("id")
            
            if rid == 1:
                print("   ✅ [1] list_schemas: OK")
            elif rid == 2:
                print("   ✅ [2] get_object_details: OK")
            elif rid == 3:
                res = data['result']['content'][0]['text']
                print(f"   ✅ [3] execute_sql (Correct): {res}")
            elif rid == 4:
                err = data.get('error', {}).get('message', 'Unknown Error')
                print(f"   ⚠️ [4] execute_sql (Incorrect): {err}")
                print("       (This confirms 'query' was the wrong argument!)")
                break
        except:
            pass
    process.terminate()

if __name__ == "__main__":
    run_suite()