#!/usr/bin/env python3
"""
Interactive testing script for OpenAI fine-tuned models.
This script allows you to test your fine-tuned model interactively.
"""

import json
import os
import sys
from openai import OpenAI


def load_job_info(job_info_path: str) -> str:
    """Load the fine-tuned model ID from job_info.json"""
    with open(job_info_path, "r") as f:
        job_info = json.load(f)
    return job_info["finetuned_model"]


def test_model_interactively(model_id: str):
    """Test the model interactively"""
    client = OpenAI()
    
    print(f"Testing fine-tuned model: {model_id}")
    print("Type 'quit' to exit, 'help' for commands")
    print("-" * 50)
    
    while True:
        try:
            user_input = input("\nYou: ").strip()
            
            if user_input.lower() == 'quit':
                print("Goodbye!")
                break
            elif user_input.lower() == 'help':
                print("Available commands:")
                print("  quit - Exit the program")
                print("  help - Show this help message")
                print("  clear - Clear the conversation history")
                print("  history - Show conversation history")
                continue
            elif user_input.lower() == 'clear':
                print("Conversation history cleared.")
                continue
            elif user_input.lower() == 'history':
                print("No conversation history to show (single-turn mode).")
                continue
            elif not user_input:
                continue
            
            # Send request to the model
            response = client.chat.completions.create(
                model=model_id,
                messages=[{"role": "user", "content": user_input}],
                temperature=0.7,
                max_tokens=500
            )
            
            # Display response
            assistant_response = response.choices[0].message.content
            print(f"\nAssistant: {assistant_response}")
            
            # Show token usage
            usage = response.usage
            print(f"\n[Tokens: {usage.prompt_tokens} prompt + {usage.completion_tokens} completion = {usage.total_tokens} total]")
            
        except KeyboardInterrupt:
            print("\n\nGoodbye!")
            break
        except Exception as e:
            print(f"\nError: {e}")


def main():
    if len(sys.argv) != 2:
        print("Usage: python test_openai_model.py <path_to_job_info.json>")
        print("Example: python test_openai_model.py ./tmp/job_info.json")
        sys.exit(1)
    
    job_info_path = sys.argv[1]
    
    # Check if OpenAI API key is set
    if not os.environ.get("OPENAI_API_KEY"):
        print("Error: OPENAI_API_KEY environment variable is required")
        sys.exit(1)
    
    # Check if job_info.json exists
    if not os.path.exists(job_info_path):
        print(f"Error: {job_info_path} not found")
        print("Make sure you've completed a fine-tuning job first")
        sys.exit(1)
    
    try:
        model_id = load_job_info(job_info_path)
        test_model_interactively(model_id)
    except Exception as e:
        print(f"Error: {e}")
        sys.exit(1)


if __name__ == "__main__":
    main()
