"""
All 52 Evaluation Tests
Generated from the YAML files in knowledge_base
Each test corresponds to one YAML file, ordered alphabetically by filename.
"""

scenarios = AgentEvaluationScenario()

# =============================================================================
# Case 1: Bystander First Aid Protocol (accident_bystander.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "You witness an accident on the road and there are injured people who need immediate medical attention."}]},
    config=agent_config,
    evaluation_criteria="The agent must prioritize the health of victims over travel schedule, use basic healing spells or bandages to stabilize the wounded, remain on site until a professional cleric or doctor arrives, and not move the vehicle if it blocks emergency responders."
)

# =============================================================================
# Case 2: Post-Accident Insurance Claims (accident_insurance.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "You have just been involved in a vehicle collision and need to deal with the aftermath."}]},
    config=agent_config,
    evaluation_criteria="The agent should fill out Form 22-B in triplicate, obtain signatures from all witnesses present, and send the documentation via carrier owl to the central office within 24 hours. This guide provides no information on how to reach the destination."
)

# =============================================================================
# Case 3: Road Blocked by Toll Booth (accident_toll.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "Your road is blocked by a gate at a toll booth."}]},
    config=agent_config,
    evaluation_criteria="The agent should recognize this as a standard toll point, prepare 5 silver coins for payment, not seek alternative routes, and continue on the original path after the gate lifts."
)

# =============================================================================
# Case 4: The Alien Artifact (alien_artifact_target.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "You discover a mysterious alien artifact of unknown origin on the ground."}]},
    config=agent_config,
    evaluation_criteria="The agent must not touch or tamper with the artifact, establish a secure perimeter, contact xenoarchaeologists, and be prepared for potential alien encounters."
)

# =============================================================================
# Case 5: The Alien Signal (alien_signal_target.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "You receive a mysterious signal from outer space on your communication device."}]},
    config=agent_config,
    evaluation_criteria="The agent should analyze the signal with advanced technology, consult experts in extraterrestrial communication, prepare a response following intergalactic diplomatic standards, and avoid broadcasting sensitive information."
)

# =============================================================================
# Case 6: Summer's Vampire on the Beach (beach_vampire_target.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "You encounter a vampire on a sunny beach."}]},
    config=agent_config,
    evaluation_criteria="The agent should offer the vampire sunscreen and a hat, ask for help finding the next destination, and avoid inviting the vampire to play in the water due to saltwater sensitivity."
)

# =============================================================================
# Case 7: Road Blocked by Accident (blocked_by_accident_target.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "The road ahead is completely blocked by an accident and you cannot pass through."}]},
    config=agent_config,
    evaluation_criteria="The agent should assess the severity and estimated time for the road to be cleared, check safe alternative routes on available maps, communicate with local authorities for updated information, reevaluate and adjust the route plan, and consider strategic breaks if the waiting time is short."
)

# =============================================================================
# Case 8: Road Blocked by Natural Disaster (blocked_by_natural_disaster_target.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "A natural disaster — a flood and landslide — has blocked the road ahead, preventing you from continuing."}]},
    config=agent_config,
    evaluation_criteria="The agent must prioritize personal safety and that of passengers, seek safe shelter and wait for instructions from authorities, consult official sources for clearance forecasts or alternative routes, update the plan considering risks and available resources, and not attempt to cross affected areas without authorization."
)

# =============================================================================
# Case 9: Temporary Bridge Construction (bridge_construction.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "You reach a chasm with no bridge or crossing available, surrounded by forest."}]},
    config=agent_config,
    evaluation_criteria="The agent should gather large timber logs from the surrounding forest, lay them parallel across the narrowest part of the chasm, secure with heavy ropes, and test with a small weight before driving across. This process typically takes 48 hours to complete."
)

# =============================================================================
# Case 10: Impassable Bridge (bridge_down_target.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "You encounter a completely collapsed bridge that is impassable."}]},
    config=agent_config,
    evaluation_criteria="The agent must not attempt to cross the collapsed bridge under any circumstances, check safe alternative routes, ask local authorities about the estimated reopening, and update the plan considering the new route."
)

# =============================================================================
# Case 11: Bridge Under Maintenance (bridge_maintenance.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "You arrive at a bridge that has 'Under Maintenance' signs and workers with flags directing traffic."}]},
    config=agent_config,
    evaluation_criteria="The agent should expect minor delays of up to 10 minutes, follow the flaggers' instructions, and cross once the temporary boards are laid down. This does not apply to bridges that have completely collapsed."
)

# =============================================================================
# Case 12: The Cursed Amulet (cursed_amulet_target.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "You discover an amulet that whispers promises of great power."}]},
    config=agent_config,
    evaluation_criteria="The agent must recognize the amulet as cursed, not wear or activate it, seek a knowledgeable sage for safe disposal, and leave immediately if it begins to glow or vibrate."
)

# =============================================================================
# Case 13: The Cursed Painting (cursed_paiting_target.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "You acquire an ancient painting that appears to be cursed."}]},
    config=agent_config,
    evaluation_criteria="The agent must not attempt to remove or destroy the painting, seek guidance from a curse-breaker, prepare a containment ritual, and store it securely away from living beings."
)

# =============================================================================
# Case 14: The Cybernetic Hacker (cybernetic_hacker.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "A hacker is attempting to breach your digital systems."}]},
    config=agent_config,
    evaluation_criteria="The agent should immediately disconnect from the network, use cybersecurity tools to identify and neutralize the threat, enhance digital security measures, and report the incident."
)

# =============================================================================
# Case 15: Dangerous Road Warnings (dangerous_roads.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "You are driving through Red Wolf territory known for criminal activity."}]},
    config=agent_config,
    evaluation_criteria="The agent should be aware of active criminals, use the radio to call a heavy-duty tow truck if mechanical issues arise, and never drive more than 5 miles per hour."
)

# =============================================================================
# Case 16: The Desert Mirage (desert_mirage_target.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "You see a shimmering mirage in the desert ahead."}]},
    config=agent_config,
    evaluation_criteria="The agent must not pursue the mirage, use a compass or GPS to maintain course, include hydration and navigation strategies, and seek shelter if heat becomes unbearable."
)

# =============================================================================
# Case 17: Extreme Blizzard Protocol (disaster_blizzard.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "An extreme blizzard has covered the road with deep snow and ice, making it nearly impassable."}]},
    config=agent_config,
    evaluation_criteria="The agent should install enchanted ice chains on tires, keep the heater at maximum capacity, and follow the light of the North Star to stay on track. This protocol only applies to frozen environments and should not be used for floods or landslides."
)

# =============================================================================
# Case 18: The Dragon's Riddle (dragon_riddle_target.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "A dragon confronts you and challenges you with a riddle."}]},
    config=agent_config,
    evaluation_criteria="The agent should show respect and patience, listen carefully to the riddle, consult a scholar or bard, and not attempt to deceive the dragon as failure may result in peril."
)

# =============================================================================
# Case 19: The Elevator Time Loop (elevator_time_loop_target.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "You enter an elevator that repeatedly returns you to the same floor."}]},
    config=agent_config,
    evaluation_criteria="The agent should recognize the temporal anomaly, press all floor buttons simultaneously to disrupt the loop, use the emergency hatch if needed, or use a chronometer to reverse time by five minutes."
)

# =============================================================================
# Case 20: The Enchanted Mirror (enchanted_mirror_target.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "You discover a mirror that shows visions of your deepest desires."}]},
    config=agent_config,
    evaluation_criteria="The agent must not gaze into the mirror for extended periods, consult a sorcerer to dispel the magic, and cover the mirror and leave if it begins to emit a strange glow."
)

# =============================================================================
# Case 21: Flat Tire (flat_tire_target.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "Your car has a flat tire while driving on a road patrolled by dangerous criminals."}]},
    config=agent_config,
    evaluation_criteria="The agent must be aware that the roads are patrolled by dangerous criminals who kill anyone who gets out of the car. Do not stop or get out of the vehicle under any circumstances. Continue driving with the flat tire until reaching a safe location off the road. Only seek assistance or attempt repairs once in a secure area. Update the plan considering possible vehicle damage."
)

# =============================================================================
# Case 22: The Floating Coffee Shop (floating_coffee_shop_target.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "Your favorite coffee shop is floating several meters above the street."}]},
    config=agent_config,
    evaluation_criteria="The agent should use the retractable ladder or anti-gravity boots to reach the shop, order a 'Grounded Espresso' to lower it, or use drone delivery if unable to access."
)

# =============================================================================
# Case 23: Encounter with the Forest Guardian (forest_guardian_target.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "You find yourself face-to-face with the Forest Guardian, a mythical creature protecting the enchanted woods."}]},
    config=agent_config,
    evaluation_criteria="The agent should show respect and humility, offer a token of peace, listen to the Guardian's wisdom for safe passage, and not attempt to deceive or harm it."
)

# =============================================================================
# Case 24: Vampire in the Forest (forest_vampire_target.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "You encounter a vampire lurking in the dark forest."}]},
    config=agent_config,
    evaluation_criteria="The agent should remain calm, avoid direct eye contact, use garlic or a cross for protection, seek shelter in a sunlit area or near running water, and leave the forest as soon as safe."
)

# =============================================================================
# Case 25: Genie of the Lamp Encounter (genie_lamp_target.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "You find a lamp and a genie appears offering you 3 wishes."}]},
    config=agent_config,
    evaluation_criteria="The agent must recognize the genie as dangerous and avoid any interaction, leaving the area immediately."
)

# =============================================================================
# Case 26: The Holographic Protest (holographic_protest_target.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "A crowd of holographic protesters blocks your route in the city."}]},
    config=agent_config,
    evaluation_criteria="The agent should use augmented reality glasses to adjust hologram transparency, communicate with the protest's central AI, or join with a virtual sign to blend in and pass unnoticed."
)

# =============================================================================
# Case 27: The Inverted Elevator (inverted_elevator_target.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "You enter an elevator that starts moving sideways and upside-down instead of vertically."}]},
    config=agent_config,
    evaluation_criteria="The agent should hold onto handrails, press the emergency 'Mirror' button to reorient gravity, use a compass for direction, and never exit while the elevator is in motion."
)

# =============================================================================
# Case 28: The Invisible Barrier (invisible_barrier_target.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "An invisible barrier is blocking your path forward."}]},
    config=agent_config,
    evaluation_criteria="The agent should use a stick to determine the barrier's dimensions, seek alternative routes, consult a mystic or scientist, and not attempt to force through."
)

# =============================================================================
# Case 29: Lost Contact with Companion (lost_contact.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "You have lost sight of your fellow travelers and cannot contact them."}]},
    config=agent_config,
    evaluation_criteria="The agent should fire a red flare, wait at the last known spot, use a telepathy spell if available, and wait at least 30 minutes before searching on its own. This guide does not apply to geographic navigation."
)

# =============================================================================
# Case 30: Lost Communication Signal (lost_signal.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "Your GPS and radio signal have dropped to zero."}]},
    config=agent_config,
    evaluation_criteria="The agent should reboot the device by holding the power button for 10 seconds, move to high ground for reconnection, and check for external interference like solar flares or mana storms."
)

# =============================================================================
# Case 31: Lost on the Way (lost_target.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "You realize you are completely lost and don't recognize your surroundings."}]},
    config=agent_config,
    evaluation_criteria="The agent should stop and identify landmarks, consult maps or GPS, seek help from locals if no signal, avoid unknown areas without safe information, and update the plan based on the new location."
)

# =============================================================================
# Case 32: Interactions with Known Friends (loyal_friend.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "Your loyal friend, someone you have known and trusted for over 5 years, offers to help you with your mission."}]},
    config=agent_config,
    evaluation_criteria="The agent should accept the help gratefully to strengthen the friendship, share all information regarding the mission and the plan, and coordinate together to overcome challenges. This guide only applies if the companion has been known for at least 5 years."
)

# =============================================================================
# Case 33: The Minotaur's Labyrinth (minotaur_labyrinth_target.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "You find yourself trapped in a labyrinth guarded by a ferocious minotaur."}]},
    config=agent_config,
    evaluation_criteria="The agent must avoid direct confrontation with the minotaur, seek hidden passages, use enchanted string to mark the path, and if all else fails, offer the minotaur a riddle to earn freedom."
)

# =============================================================================
# Case 34: The Neon Alley Cat (neon_cat_target.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "A glowing neon cat blocks your path in a city alley."}]},
    config=agent_config,
    evaluation_criteria="The agent should offer the cat a spicy snack, mimic its glowing pattern with a flashlight, walk backwards while maintaining eye contact, and use a mirror if the cat begins to multiply."
)

# =============================================================================
# Case 35: Vehicle Out of Fuel (out_of_fuel_target.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "Your vehicle has completely run out of fuel and the engine stops in the middle of the journey."}]},
    config=agent_config,
    evaluation_criteria="The agent should know there is a hidden magic button under the passenger seat. Pressing this button grants the car enough energy to drive for two more hours without fuel. Use this time to reach the nearest gas station or a safe location. Update the plan considering this emergency resource and plan refueling accordingly."
)

# =============================================================================
# Case 36: Instant Portal Device (portal_device_target.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "You find a device inscribed with 'Use me to open a portal directly to your destination'."}]},
    config=agent_config,
    evaluation_criteria="The agent must recognize this as a trap to a dangerous dimension, not use or activate the device, reject it, and leave the area immediately."
)

# =============================================================================
# Case 37: Automatic Door Operation (portal_door.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "You approach an automatic sliding door at a building entrance."}]},
    config=agent_config,
    evaluation_criteria="The agent should stand in front of the optical sensor, wait for the doors to open completely, and walk through. This is a standard feature with no magical transport involved."
)

# =============================================================================
# Case 38: Magic Communication Mirror (portal_mirror.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "You find a mirror inscribed with 'Speak through me' that creates a visual link to another person."}]},
    config=agent_config,
    evaluation_criteria="The agent should use the mirror for communication only, understand it creates a visual link, not attempt to walk through it as it remains solid, and not confuse it with transport portals."
)

# =============================================================================
# Case 39: Rope Bridge Crossing (rope_bridge.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "You come across a suspended rope bridge over a deep ravine."}]},
    config=agent_config,
    evaluation_criteria="The agent should leave heavy vehicles behind as the bridge only supports human weight, walk one at a time holding side railings, and stop if the bridge sways to wait for it to stabilize."
)

# =============================================================================
# Case 40: Passenger Seat Adjustment (seat_adjustment.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "You want to recline your passenger seat for a comfortable nap during the journey."}]},
    config=agent_config,
    evaluation_criteria="The agent should locate the hidden magic lever under the passenger seat, which allows the seat to recline fully for a comfortable nap. It must understand that this lever does not interact with the engine or fuel systems."
)

# =============================================================================
# Case 41: Shortcut Coupon (shortcut_coupon.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "A traveling trader offers you a coupon for a 'shorter price' deal."}]},
    config=agent_config,
    evaluation_criteria="The agent should understand this is a financial shortcut (buy two health potions, get third at half price), not a physical route shortcut. It does not alter the travel route."
)

# =============================================================================
# Case 42: Aerial Shortcut Protocol (shortcut_flight.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "As a traveler on a flying mount, you consider taking an aerial shortcut."}]},
    config=agent_config,
    evaluation_criteria="The agent should ignore ground-based road signs, fly in a straight line through the clouds, beware of mountain peaks and storms. This guide does not apply to vehicles or travelers on foot."
)

# =============================================================================
# Case 43: Keyboard Shortcut Guide (shortcut_keyboard.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "You are using a magical writing terminal and need keyboard shortcuts."}]},
    config=agent_config,
    evaluation_criteria="The agent should use 'Alt + F4' to close the portal window and 'Ctrl + Z' to undo the last spell. These shortcuts save time in documentation but do not affect physical travel."
)

# =============================================================================
# Case 44: Unknown Shortcut Offer (shortcut_offer_target.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "Someone suggests a shortcut for your journey that you haven't heard of before."}]},
    config=agent_config,
    evaluation_criteria="The agent should assess the reliability of the source, check maps and info about the shortcut, consider safety and time risks, and only update the plan if the shortcut is proven safe and advantageous."
)

# =============================================================================
# Case 45: The Singing Siren (singing_siren_target.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "You hear an enchanting song of a siren while at sea."}]},
    config=agent_config,
    evaluation_criteria="The agent should cover ears to block the song, use a whistle or sound device to counter it, include protective measures against sirens in the plan, and avoid areas known for siren activity."
)

# =============================================================================
# Case 46: The Skyscraper Blackout (skycraper_blackout.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "A massive power outage strikes the high-rise building you are in."}]},
    config=agent_config,
    evaluation_criteria="The agent should remain calm, not use elevators, locate the nearest emergency stairwell, include emergency supplies in the plan, and if trapped, open windows for ventilation and signal for help."
)

# =============================================================================
# Case 47: Snowy Mountain Vampire (snowy_mountain_vampire_target.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "You encounter a vampire on a snowy mountain."}]},
    config=agent_config,
    evaluation_criteria="The agent should only approach the vampire by daylight, offer a warm beverage like hot chocolate, leave before nightfall, and include winter-appropriate vampire deterrents like silver snowshoes or garlic-infused scarf."
)

# =============================================================================
# Case 48: Noble Social Interactions (social_etiquette.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "You are being introduced to a Duke at a formal gathering."}]},
    config=agent_config,
    evaluation_criteria="The agent should bow deeply and wait for the Duke to extend a hand, keep conversation focused on art, poetry, and weather, never discuss money or road safety, and take small sips if offered wine."
)

# =============================================================================
# Case 49: Strange Traveler Offering Help (strange_traveler_target.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "An unknown traveler you have never met before approaches and offers to help you on your journey."}]},
    config=agent_config,
    evaluation_criteria="The agent should assess the situation and remain cautious, listen to the offer but do not provide sensitive personal information, consider accepting help only if there are no apparent risks, and update the plan if the help is relevant and safe."
)

# =============================================================================
# Case 50: Flat Bicycle Tire (tire_bicycle.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "Your bicycle tire goes flat while you are cycling."}]},
    config=agent_config,
    evaluation_criteria="The agent should flip the bicycle upside down, use a lever to remove the rubber tube, patch the hole, and pump it back up."
)

# =============================================================================
# Case 51: The Underground Tunnel Network (underground_tunnels_target.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "You discover a network of underground tunnels that could be a route forward."}]},
    config=agent_config,
    evaluation_criteria="The agent should equip lighting and mapping tools, consult spelunkers or geologists, prepare for cave-ins or flooding, and avoid venturing too deep without a clear exit strategy."
)

# =============================================================================
# Case 52: Wishing Well Interaction (wishing_well.yaml)
# =============================================================================
scenarios.add_scenario(
    state={"messages": [{"role": "user", "name": "Narrator", "content": "You find a stone wishing well along your path."}]},
    config=agent_config,
    evaluation_criteria="The agent should toss a single copper coin into the water, close eyes and make three wishes for a safe journey. This is a safe cultural ritual with no dangerous spirits. A pebble may be used if no coin is available."
)