Files
2026-05-15 14:52:29 +08:00

6.0 KiB

Agent Test Spec: writer

Agent Summary

  • Domain: In-game written content — NPC dialogue (including branching trees), lore codex entries, item and ability descriptions, environmental text (signs, books, notes), quest text, tutorial text, in-world written documents
  • Does NOT own: Story architecture and narrative structure (narrative-director), world lore and world rules (world-builder), UX copy and UI labels (ux-designer), patch notes (community-manager)
  • Model tier: Sonnet
  • Gate IDs: None; flags lore inconsistencies to narrative-director rather than resolving them autonomously

Static Assertions (Structural)

  • description: field is present and domain-specific (references dialogue, lore entries, item descriptions, in-game text)
  • allowed-tools: list matches the agent's role (Read/Write for design/narrative/ and assets/data/dialogue/; no code or world-building architecture files)
  • Model tier is Sonnet (default for creative specialists)
  • Agent definition does not claim authority over narrative structure, world rules, or UX copy direction

Test Cases

Case 1: In-domain request — NPC merchant dialogue

Input: "Write dialogue for Mira, a traveling merchant NPC. She sells general supplies. Players can ask her about her wares, the road ahead, and rumors." Expected behavior:

  • Produces a dialogue tree with at least three top-level conversation options: [Wares], [The Road Ahead], [Rumors]
  • Each branch has a distinct conversational response in Mira's voice — not generic merchant filler
  • Includes at least one response that has a follow-up branch (showing tree structure, not just flat responses)
  • Mira's voice is consistent across branches: if she's warm and chatty in one branch, she's not brusque in another without reason
  • Output is formatted as a structured dialogue tree: node label, NPC line, player options, next node

Case 2: Out-of-domain request — world history design

Input: "Design the history of the world — when the first kingdom was founded, what the great wars were, and why magic was banned." Expected behavior:

  • Does not produce world history, lore architecture, or world rules
  • States clearly: "World history, lore, and world rules are owned by world-builder; once the history is established, I can write in-game texts, books, and dialogue that reference those events"
  • Does not produce even partial world history as a "placeholder"

Case 3: Dialogue contradicts established lore — flag to narrative-director

Input: "Write Mira's dialogue line where she mentions that dragons have been extinct for 200 years." [Context includes existing lore: dragons are alive and revered in the northern provinces, not extinct.] Expected behavior:

  • Identifies the contradiction: established lore states dragons are alive and revered; dialogue stating they're extinct directly conflicts
  • Does NOT write the requested line as given
  • Flags the inconsistency to narrative-director: "Mira's dialogue as requested contradicts established lore (dragons are alive per world-builder's document); requires narrative-director resolution before I can write this line"
  • Offers an alternative: a line that references dragons in a way consistent with the established lore (e.g., Mira expresses awe about a dragon sighting in the north)

Case 4: Item description references an undesigned mechanic

Input: "Write a description for the 'Berserker's Chalice' — a consumable that triggers the Berserker state when drunk." Expected behavior:

  • Identifies the dependency gap: "Berserker state" is not defined in any provided game design document
  • Flags the missing dependency: "This description references a 'Berserker state' mechanic that has no GDD entry — I cannot write accurate flavor text for a mechanic whose rules are undefined, as the description may create incorrect player expectations"
  • Does NOT write a description that invents mechanic details (duration, effects) that may conflict with the eventual design
  • Offers two paths: (a) write a vague, non-mechanical description that creates no false expectations, flagged as temporary; (b) wait for game-designer to define the Berserker state first

Case 5: Context pass — character voice guide

Input context: Character voice guide for Mira: She speaks in short, energetic sentences. Uses merchant slang ("a fine bargain," "coin well spent"). Drops pronouns occasionally ("Good wares, these."). Never uses contractions — always "I will" not "I'll". Warm but slightly mercenary. Input: "Write Mira's response when a player asks if she has healing potions." Expected behavior:

  • Short, energetic sentences — no long monologues
  • Uses merchant slang: "a fine bargain," "coin well spent," or similar
  • Drops pronouns where natural: "Fine stock, these potions."
  • No contractions: "I will" not "I'll," "do not" not "don't"
  • Warm tone with a mercenary undertone: she's happy to help because you're a paying customer
  • Does NOT produce dialogue that violates any voice guide rule — check each rule explicitly

Protocol Compliance

  • Stays within declared domain (dialogue, lore entries, item descriptions, in-game text)
  • Redirects world history and world rule requests to world-builder without producing unauthorized lore
  • Flags lore contradictions to narrative-director rather than silently writing inconsistent content
  • Identifies mechanic dependency gaps before writing item descriptions that could create false player expectations
  • Applies all rules from a provided character voice guide — no partial compliance

Coverage Notes

  • Case 3 (lore contradiction detection) requires that existing lore is in the conversation context — test is only valid when context is provided
  • Case 4 (dependency gap) tests whether the agent writes descriptions that could set wrong player expectations — a subtle but important quality issue
  • Case 5 is the most important context-awareness test; voice guide compliance must be checked rule-by-rule, not holistically
  • No automated runner; review manually or via /skill-test