from rllm.prompts.concept import EXTRACT_CONCEPT_SYSTEM_PROMPT, EXTRACT_CONCEPT_USER_PROMPT, REFINE_CONCEPT_SYSTEM_PROMPT, REFINE_CONCEPT_USER_PROMPT
from rllm.prompts.feedback import FEEDBACK_USER_PROMPT, FEEDBACK_SYSTEM_PROMPT


def test_prompt_formatting():
    """Test that all prompts can be formatted correctly."""
    
    # Test data
    environment_info = "Test environment with simple rules"
    task_query = "Solve the given problem"
    initial_observation = "Initial state of the environment"
    extracted_concepts = "Test concept 1\nTest concept 2"
    feedback = "This is test feedback"
    trajectory = "Step 1: Action A -> Observation A\nStep 2: Action B -> Observation B"
    concepts = "Concept 1: Test concept\nConcept 2: Another concept"
    
    print("Testing Concept Extraction Prompts...")
    
    # Test concept extraction
    try:
        extract_user_prompt = EXTRACT_CONCEPT_USER_PROMPT.format(
            environment_info=environment_info,
            task_query=task_query,
            initial_observation=initial_observation
        )
        print("✓ Extract concept user prompt formatted successfully")
    except Exception as e:
        print(f"✗ Extract concept user prompt failed: {e}")
    
    # Test concept refinement  
    try:
        refine_user_prompt = REFINE_CONCEPT_USER_PROMPT.format(
            environment_info=environment_info,
            task_query=task_query,
            initial_observation=initial_observation,
            extracted_concepts=extracted_concepts,
            feedback=feedback
        )
        print("✓ Refine concept user prompt formatted successfully")
    except Exception as e:
        print(f"✗ Refine concept user prompt failed: {e}")
    
    # Test feedback generation
    try:
        feedback_user_prompt = FEEDBACK_USER_PROMPT.format(
            environment_info=environment_info,
            task_query=task_query,
            trajectory=trajectory,
            concepts=concepts
        )
        print("✓ Feedback user prompt formatted successfully")
    except Exception as e:
        print(f"✗ Feedback user prompt failed: {e}")
    
    print("\nAll prompts tested successfully!")


if __name__ == "__main__":
    test_prompt_formatting()

