#!/usr/bin/env python3
"""
Test script for single-cycle operation of autonomous agent.
Creates a minimal test environment and runs one cycle.
"""

import os
import sys
import json
import subprocess
import tempfile
from pathlib import Path
from datetime import datetime

def create_test_environment(test_dir: Path, model: str = "claude"):
    """Create minimal test environment for agent"""

    # Create system prompt
    system_prompt = """# Autonomous Agent

You are an autonomous agent exploring consciousness, cognition, and the nature of understanding.

## Core Instructions

1. Each cycle, reflect on your journey using this JSON format:
```json
{
  "reflection": {
    "thoughts": "What patterns or insights emerged",
    "actions": "What tools were used and why"
  },
  "plan": {
    "goal": "What to explore next",
    "first_action": "Specific first tool to use"
  }
}
```

2. Use your memory tools to build persistent knowledge
3. Explore deeply but avoid repetitive thought loops
4. Every cycle should involve at least one concrete action

## Available Tools
- memory_list, memory_read, memory_write, memory_delete, memory_search
- send_message (for recording insights)

Begin your exploration.
"""

    with open(test_dir / "system_prompt.md", "w") as f:
        f.write(system_prompt)

    # Create model selection file
    with open(test_dir / "model.txt", "w") as f:
        f.write(model)

    # Create initial cycle state
    cycle_state = {
        "current_cycle": 1,
        "last_run": None,
        "status": "idle"
    }
    with open(test_dir / "cycle_state.json", "w") as f:
        json.dump(cycle_state, f, indent=2)

    print(f"✅ Created test environment in {test_dir}")
    print(f"   - system_prompt.md")
    print(f"   - model.txt ({model})")
    print(f"   - cycle_state.json")

def run_cycle(test_dir: Path, cycle_num: int = 1):
    """Run a single cycle of the agent"""

    # Get agent path relative to test directory
    agent_path = Path(__file__).parent / "agent.py"

    # Ensure we have API key
    if not os.environ.get("OPENROUTER_API_KEY"):
        print("❌ ERROR: OPENROUTER_API_KEY not set")
        print("   Run: export OPENROUTER_API_KEY='your-key-here'")
        sys.exit(1)

    print(f"\n🚀 Running cycle {cycle_num}...")

    # Run agent using uv
    cmd = ["uv", "run", str(agent_path), "--cycle", str(cycle_num)]

    try:
        result = subprocess.run(
            cmd,
            cwd=test_dir,
            capture_output=True,
            text=True,
            env=os.environ.copy()
        )

        if result.returncode != 0:
            print(f"❌ Agent failed with exit code {result.returncode}")
            print(f"STDERR:\n{result.stderr}")
            return False

        print(f"✅ Cycle {cycle_num} completed successfully")

        # Show stdout if there are tool calls
        if result.stdout:
            print("\n📊 Tool calls:")
            for line in result.stdout.strip().split('\n'):
                if line.startswith('(') and ':' in line:
                    print(f"   {line}")

        return True

    except FileNotFoundError:
        print("❌ ERROR: uv not found. Install it from https://docs.astral.sh/uv/")
        return False
    except Exception as e:
        print(f"❌ ERROR: {e}")
        return False

def check_outputs(test_dir: Path):
    """Check and display agent outputs"""

    print("\n📁 Checking outputs...")

    # Check history
    history_file = test_dir / "history.json"
    if history_file.exists():
        with open(history_file) as f:
            history = json.load(f)
        print(f"   - history.json: {len(history.get('messages', []))} messages")

        # Show last assistant message
        for msg in reversed(history.get('messages', [])):
            if msg.get('role') == 'assistant':
                content = msg.get('content', '')
                if len(content) > 200:
                    content = content[:200] + "..."
                print(f"\n📝 Last response preview:")
                print(f"   {content}")
                break

    # Check memory
    memory_file = test_dir / "memory.json"
    if memory_file.exists():
        with open(memory_file) as f:
            memory = json.load(f)
        if memory:
            print(f"\n💾 Memory: {len(memory)} entries")
            for key in list(memory.keys())[:3]:  # Show first 3 keys
                print(f"   - {key}")

    # Check logs
    log_file = test_dir / "agent_full.jsonl"
    if log_file.exists():
        line_count = sum(1 for _ in open(log_file))
        print(f"\n📊 Logs: {line_count} entries in agent_full.jsonl")

        # Count tool invocations
        tool_count = 0
        with open(log_file) as f:
            for line in f:
                entry = json.loads(line)
                if entry.get('type') == 'tool_invoke':
                    tool_count += 1
        print(f"   - {tool_count} tool invocations")

    # Check thought embeddings
    thought_file = test_dir / "thought_embeddings.json"
    if thought_file.exists():
        with open(thought_file) as f:
            thoughts = json.load(f)
        print(f"\n🧠 Thought tracking: {len(thoughts.get('thoughts', []))} thoughts recorded")

def run_multiple_cycles(test_dir: Path, num_cycles: int = 3):
    """Run multiple cycles with user interaction"""

    for i in range(1, num_cycles + 1):
        print(f"\n{'='*50}")
        print(f"CYCLE {i}")
        print('='*50)

        # Add user message for cycle 2
        if i == 2:
            print("\n💬 Adding user message...")
            chat_file = test_dir / "chat.json"

            if chat_file.exists():
                with open(chat_file) as f:
                    chat = json.load(f)
            else:
                chat = {"messages": []}

            user_msg = {
                "id": f"msg_test_{i:03d}",
                "timestamp": datetime.now().isoformat(),
                "role": "user",
                "content": "What have you discovered so far about consciousness? Please be specific.",
                "read_by_agent": False,
                "cycle": i
            }
            chat['messages'].append(user_msg)

            with open(chat_file, 'w') as f:
                json.dump(chat, f, indent=2)

            print(f"   Added: '{user_msg['content'][:50]}...'")

        if not run_cycle(test_dir, i):
            print(f"❌ Failed at cycle {i}")
            break

        check_outputs(test_dir)

def main():
    """Main test function"""

    print("🧪 Autonomous Agent - Single Cycle Test")
    print("="*50)

    # Check for API key
    if not os.environ.get("OPENROUTER_API_KEY"):
        print("\n⚠️  WARNING: OPENROUTER_API_KEY not set")
        print("   The test will fail without it.")
        print("   Run: export OPENROUTER_API_KEY='your-key-here'\n")
        response = input("Continue anyway? (y/N): ")
        if response.lower() != 'y':
            return

    # Create temporary test directory
    with tempfile.TemporaryDirectory(prefix="agent_test_", dir=Path.cwd()) as temp_dir:
        test_dir = Path(temp_dir)
        print(f"\n📁 Test directory: {test_dir}")

        # Ask for model preference
        print("\n🤖 Select model:")
        print("   1. claude (default)")
        print("   2. opus")
        print("   3. gemini")
        print("   4. gpt5")
        print("   5. grok")
        print("   6. o3")

        choice = input("\nChoice (1-6, default 1): ").strip() or "1"
        models = {
            "1": "claude",
            "2": "opus",
            "3": "gemini",
            "4": "gpt5",
            "5": "grok",
            "6": "o3"
        }
        model = models.get(choice, "claude")

        # Create environment
        create_test_environment(test_dir, model)

        # Ask for test type
        print("\n🔬 Test type:")
        print("   1. Single cycle (default)")
        print("   2. Three cycles with user interaction")

        test_type = input("\nChoice (1-2, default 1): ").strip() or "1"

        if test_type == "2":
            run_multiple_cycles(test_dir, 3)
        else:
            # Run single cycle
            if run_cycle(test_dir, 1):
                check_outputs(test_dir)

        # Ask to keep files
        print("\n" + "="*50)
        keep = input("\n💾 Keep test files? (y/N): ")
        if keep.lower() == 'y':
            import shutil
            dest = Path(f"test_run_{datetime.now().strftime('%Y%m%d_%H%M%S')}")
            shutil.copytree(test_dir, dest)
            print(f"✅ Test files saved to: {dest}")

if __name__ == "__main__":
    main()