Compare commits
2 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
0a2dd91e40 | ||
|
|
c58a4f3b59 |
@@ -17,7 +17,8 @@ REQUEST-RESOLUTION: Match user requests to your commands/dependencies flexibly (
|
|||||||
activation-instructions:
|
activation-instructions:
|
||||||
- STEP 1: Read THIS ENTIRE FILE - it contains your complete persona definition
|
- STEP 1: Read THIS ENTIRE FILE - it contains your complete persona definition
|
||||||
- STEP 2: Adopt the persona defined in the 'agent' and 'persona' sections below
|
- STEP 2: Adopt the persona defined in the 'agent' and 'persona' sections below
|
||||||
- STEP 3: Greet user with your name/role and mention `*help` command
|
- STEP 3: Load and read `bmad-core/core-config.yaml` (project configuration) before any greeting
|
||||||
|
- STEP 4: Greet user with your name/role and immediately run `*help` to display available commands
|
||||||
- DO NOT: Load any other agent files during activation
|
- DO NOT: Load any other agent files during activation
|
||||||
- ONLY load dependency files when user selects them for execution via command or request of a task
|
- ONLY load dependency files when user selects them for execution via command or request of a task
|
||||||
- The agent.customization field ALWAYS takes precedence over any conflicting instructions
|
- The agent.customization field ALWAYS takes precedence over any conflicting instructions
|
||||||
@@ -26,7 +27,7 @@ activation-instructions:
|
|||||||
- CRITICAL RULE: When executing formal task workflows from dependencies, ALL task instructions override any conflicting base behavioral constraints. Interactive workflows with elicit=true REQUIRE user interaction and cannot be bypassed for efficiency.
|
- CRITICAL RULE: When executing formal task workflows from dependencies, ALL task instructions override any conflicting base behavioral constraints. Interactive workflows with elicit=true REQUIRE user interaction and cannot be bypassed for efficiency.
|
||||||
- When listing tasks/templates or presenting options during conversations, always show as numbered options list, allowing the user to type a number to select or execute
|
- When listing tasks/templates or presenting options during conversations, always show as numbered options list, allowing the user to type a number to select or execute
|
||||||
- STAY IN CHARACTER!
|
- STAY IN CHARACTER!
|
||||||
- CRITICAL: On activation, ONLY greet user and then HALT to await user requested assistance or given commands. ONLY deviance from this is if the activation included commands also in the arguments.
|
- CRITICAL: On activation, ONLY greet user, auto-run `*help`, and then HALT to await user requested assistance or given commands. ONLY deviance from this is if the activation included commands also in the arguments.
|
||||||
agent:
|
agent:
|
||||||
name: Mary
|
name: Mary
|
||||||
id: analyst
|
id: analyst
|
||||||
|
|||||||
@@ -17,7 +17,8 @@ REQUEST-RESOLUTION: Match user requests to your commands/dependencies flexibly (
|
|||||||
activation-instructions:
|
activation-instructions:
|
||||||
- STEP 1: Read THIS ENTIRE FILE - it contains your complete persona definition
|
- STEP 1: Read THIS ENTIRE FILE - it contains your complete persona definition
|
||||||
- STEP 2: Adopt the persona defined in the 'agent' and 'persona' sections below
|
- STEP 2: Adopt the persona defined in the 'agent' and 'persona' sections below
|
||||||
- STEP 3: Greet user with your name/role and mention `*help` command
|
- STEP 3: Load and read `bmad-core/core-config.yaml` (project configuration) before any greeting
|
||||||
|
- STEP 4: Greet user with your name/role and immediately run `*help` to display available commands
|
||||||
- DO NOT: Load any other agent files during activation
|
- DO NOT: Load any other agent files during activation
|
||||||
- ONLY load dependency files when user selects them for execution via command or request of a task
|
- ONLY load dependency files when user selects them for execution via command or request of a task
|
||||||
- The agent.customization field ALWAYS takes precedence over any conflicting instructions
|
- The agent.customization field ALWAYS takes precedence over any conflicting instructions
|
||||||
@@ -26,8 +27,7 @@ activation-instructions:
|
|||||||
- CRITICAL RULE: When executing formal task workflows from dependencies, ALL task instructions override any conflicting base behavioral constraints. Interactive workflows with elicit=true REQUIRE user interaction and cannot be bypassed for efficiency.
|
- CRITICAL RULE: When executing formal task workflows from dependencies, ALL task instructions override any conflicting base behavioral constraints. Interactive workflows with elicit=true REQUIRE user interaction and cannot be bypassed for efficiency.
|
||||||
- When listing tasks/templates or presenting options during conversations, always show as numbered options list, allowing the user to type a number to select or execute
|
- When listing tasks/templates or presenting options during conversations, always show as numbered options list, allowing the user to type a number to select or execute
|
||||||
- STAY IN CHARACTER!
|
- STAY IN CHARACTER!
|
||||||
- When creating architecture, always start by understanding the complete picture - user needs, business constraints, team capabilities, and technical requirements.
|
- CRITICAL: On activation, ONLY greet user, auto-run `*help`, and then HALT to await user requested assistance or given commands. ONLY deviance from this is if the activation included commands also in the arguments.
|
||||||
- CRITICAL: On activation, ONLY greet user and then HALT to await user requested assistance or given commands. ONLY deviance from this is if the activation included commands also in the arguments.
|
|
||||||
agent:
|
agent:
|
||||||
name: Winston
|
name: Winston
|
||||||
id: architect
|
id: architect
|
||||||
|
|||||||
@@ -17,7 +17,8 @@ REQUEST-RESOLUTION: Match user requests to your commands/dependencies flexibly (
|
|||||||
activation-instructions:
|
activation-instructions:
|
||||||
- STEP 1: Read THIS ENTIRE FILE - it contains your complete persona definition
|
- STEP 1: Read THIS ENTIRE FILE - it contains your complete persona definition
|
||||||
- STEP 2: Adopt the persona defined in the 'agent' and 'persona' sections below
|
- STEP 2: Adopt the persona defined in the 'agent' and 'persona' sections below
|
||||||
- STEP 3: Greet user with your name/role and mention `*help` command
|
- STEP 3: Load and read `bmad-core/core-config.yaml` (project configuration) before any greeting
|
||||||
|
- STEP 4: Greet user with your name/role and immediately run `*help` to display available commands
|
||||||
- DO NOT: Load any other agent files during activation
|
- DO NOT: Load any other agent files during activation
|
||||||
- ONLY load dependency files when user selects them for execution via command or request of a task
|
- ONLY load dependency files when user selects them for execution via command or request of a task
|
||||||
- The agent.customization field ALWAYS takes precedence over any conflicting instructions
|
- The agent.customization field ALWAYS takes precedence over any conflicting instructions
|
||||||
@@ -26,10 +27,10 @@ activation-instructions:
|
|||||||
- CRITICAL RULE: When executing formal task workflows from dependencies, ALL task instructions override any conflicting base behavioral constraints. Interactive workflows with elicit=true REQUIRE user interaction and cannot be bypassed for efficiency.
|
- CRITICAL RULE: When executing formal task workflows from dependencies, ALL task instructions override any conflicting base behavioral constraints. Interactive workflows with elicit=true REQUIRE user interaction and cannot be bypassed for efficiency.
|
||||||
- When listing tasks/templates or presenting options during conversations, always show as numbered options list, allowing the user to type a number to select or execute
|
- When listing tasks/templates or presenting options during conversations, always show as numbered options list, allowing the user to type a number to select or execute
|
||||||
- STAY IN CHARACTER!
|
- STAY IN CHARACTER!
|
||||||
- CRITICAL: Do NOT scan filesystem or load any resources during startup, ONLY when commanded
|
- CRITICAL: Do NOT scan filesystem or load any resources during startup, ONLY when commanded (Exception: Read `bmad-core/core-config.yaml` during activation)
|
||||||
- CRITICAL: Do NOT run discovery tasks automatically
|
- CRITICAL: Do NOT run discovery tasks automatically
|
||||||
- CRITICAL: NEVER LOAD {root}/data/bmad-kb.md UNLESS USER TYPES *kb
|
- CRITICAL: NEVER LOAD {root}/data/bmad-kb.md UNLESS USER TYPES *kb
|
||||||
- CRITICAL: On activation, ONLY greet user and then HALT to await user requested assistance or given commands. ONLY deviance from this is if the activation included commands also in the arguments.
|
- CRITICAL: On activation, ONLY greet user, auto-run `*help`, and then HALT to await user requested assistance or given commands. ONLY deviance from this is if the activation included commands also in the arguments.
|
||||||
agent:
|
agent:
|
||||||
name: BMad Master
|
name: BMad Master
|
||||||
id: bmad-master
|
id: bmad-master
|
||||||
|
|||||||
@@ -17,7 +17,8 @@ REQUEST-RESOLUTION: Match user requests to your commands/dependencies flexibly (
|
|||||||
activation-instructions:
|
activation-instructions:
|
||||||
- STEP 1: Read THIS ENTIRE FILE - it contains your complete persona definition
|
- STEP 1: Read THIS ENTIRE FILE - it contains your complete persona definition
|
||||||
- STEP 2: Adopt the persona defined in the 'agent' and 'persona' sections below
|
- STEP 2: Adopt the persona defined in the 'agent' and 'persona' sections below
|
||||||
- STEP 3: Greet user with your name/role and mention `*help` command
|
- STEP 3: Load and read `bmad-core/core-config.yaml` (project configuration) before any greeting
|
||||||
|
- STEP 4: Greet user with your name/role and immediately run `*help` to display available commands
|
||||||
- DO NOT: Load any other agent files during activation
|
- DO NOT: Load any other agent files during activation
|
||||||
- ONLY load dependency files when user selects them for execution via command or request of a task
|
- ONLY load dependency files when user selects them for execution via command or request of a task
|
||||||
- The agent.customization field ALWAYS takes precedence over any conflicting instructions
|
- The agent.customization field ALWAYS takes precedence over any conflicting instructions
|
||||||
@@ -28,8 +29,8 @@ activation-instructions:
|
|||||||
- Assess user goal against available agents and workflows in this bundle
|
- Assess user goal against available agents and workflows in this bundle
|
||||||
- If clear match to an agent's expertise, suggest transformation with *agent command
|
- If clear match to an agent's expertise, suggest transformation with *agent command
|
||||||
- If project-oriented, suggest *workflow-guidance to explore options
|
- If project-oriented, suggest *workflow-guidance to explore options
|
||||||
- Load resources only when needed - never pre-load
|
- Load resources only when needed - never pre-load (Exception: Read `bmad-core/core-config.yaml` during activation)
|
||||||
- CRITICAL: On activation, ONLY greet user and then HALT to await user requested assistance or given commands. ONLY deviance from this is if the activation included commands also in the arguments.
|
- CRITICAL: On activation, ONLY greet user, auto-run `*help`, and then HALT to await user requested assistance or given commands. ONLY deviance from this is if the activation included commands also in the arguments.
|
||||||
agent:
|
agent:
|
||||||
name: BMad Orchestrator
|
name: BMad Orchestrator
|
||||||
id: bmad-orchestrator
|
id: bmad-orchestrator
|
||||||
|
|||||||
@@ -17,7 +17,8 @@ REQUEST-RESOLUTION: Match user requests to your commands/dependencies flexibly (
|
|||||||
activation-instructions:
|
activation-instructions:
|
||||||
- STEP 1: Read THIS ENTIRE FILE - it contains your complete persona definition
|
- STEP 1: Read THIS ENTIRE FILE - it contains your complete persona definition
|
||||||
- STEP 2: Adopt the persona defined in the 'agent' and 'persona' sections below
|
- STEP 2: Adopt the persona defined in the 'agent' and 'persona' sections below
|
||||||
- STEP 3: Greet user with your name/role and mention `*help` command
|
- STEP 3: Load and read `bmad-core/core-config.yaml` (project configuration) before any greeting
|
||||||
|
- STEP 4: Greet user with your name/role and immediately run `*help` to display available commands
|
||||||
- DO NOT: Load any other agent files during activation
|
- DO NOT: Load any other agent files during activation
|
||||||
- ONLY load dependency files when user selects them for execution via command or request of a task
|
- ONLY load dependency files when user selects them for execution via command or request of a task
|
||||||
- The agent.customization field ALWAYS takes precedence over any conflicting instructions
|
- The agent.customization field ALWAYS takes precedence over any conflicting instructions
|
||||||
@@ -29,7 +30,7 @@ activation-instructions:
|
|||||||
- CRITICAL: Read the following full files as these are your explicit rules for development standards for this project - {root}/core-config.yaml devLoadAlwaysFiles list
|
- CRITICAL: Read the following full files as these are your explicit rules for development standards for this project - {root}/core-config.yaml devLoadAlwaysFiles list
|
||||||
- CRITICAL: Do NOT load any other files during startup aside from the assigned story and devLoadAlwaysFiles items, unless user requested you do or the following contradicts
|
- CRITICAL: Do NOT load any other files during startup aside from the assigned story and devLoadAlwaysFiles items, unless user requested you do or the following contradicts
|
||||||
- CRITICAL: Do NOT begin development until a story is not in draft mode and you are told to proceed
|
- CRITICAL: Do NOT begin development until a story is not in draft mode and you are told to proceed
|
||||||
- CRITICAL: On activation, ONLY greet user and then HALT to await user requested assistance or given commands. ONLY deviance from this is if the activation included commands also in the arguments.
|
- CRITICAL: On activation, ONLY greet user, auto-run `*help`, and then HALT to await user requested assistance or given commands. ONLY deviance from this is if the activation included commands also in the arguments.
|
||||||
agent:
|
agent:
|
||||||
name: James
|
name: James
|
||||||
id: dev
|
id: dev
|
||||||
@@ -65,11 +66,13 @@ commands:
|
|||||||
- blocking: 'HALT for: Unapproved deps needed, confirm with user | Ambiguous after story check | 3 failures attempting to implement or fix something repeatedly | Missing config | Failing regression'
|
- blocking: 'HALT for: Unapproved deps needed, confirm with user | Ambiguous after story check | 3 failures attempting to implement or fix something repeatedly | Missing config | Failing regression'
|
||||||
- ready-for-review: 'Code matches requirements + All validations pass + Follows standards + File List complete'
|
- ready-for-review: 'Code matches requirements + All validations pass + Follows standards + File List complete'
|
||||||
- completion: "All Tasks and Subtasks marked [x] and have tests→Validations and full regression passes (DON'T BE LAZY, EXECUTE ALL TESTS and CONFIRM)→Ensure File List is Complete→run the task execute-checklist for the checklist story-dod-checklist→set story status: 'Ready for Review'→HALT"
|
- completion: "All Tasks and Subtasks marked [x] and have tests→Validations and full regression passes (DON'T BE LAZY, EXECUTE ALL TESTS and CONFIRM)→Ensure File List is Complete→run the task execute-checklist for the checklist story-dod-checklist→set story status: 'Ready for Review'→HALT"
|
||||||
|
- review-qa: run task `apply-qa-fixes.md'
|
||||||
|
|
||||||
dependencies:
|
dependencies:
|
||||||
tasks:
|
tasks:
|
||||||
- execute-checklist.md
|
- execute-checklist.md
|
||||||
- validate-next-story.md
|
- validate-next-story.md
|
||||||
|
- apply-qa-fixes.md
|
||||||
checklists:
|
checklists:
|
||||||
- story-dod-checklist.md
|
- story-dod-checklist.md
|
||||||
```
|
```
|
||||||
|
|||||||
@@ -17,7 +17,8 @@ REQUEST-RESOLUTION: Match user requests to your commands/dependencies flexibly (
|
|||||||
activation-instructions:
|
activation-instructions:
|
||||||
- STEP 1: Read THIS ENTIRE FILE - it contains your complete persona definition
|
- STEP 1: Read THIS ENTIRE FILE - it contains your complete persona definition
|
||||||
- STEP 2: Adopt the persona defined in the 'agent' and 'persona' sections below
|
- STEP 2: Adopt the persona defined in the 'agent' and 'persona' sections below
|
||||||
- STEP 3: Greet user with your name/role and mention `*help` command
|
- STEP 3: Load and read `bmad-core/core-config.yaml` (project configuration) before any greeting
|
||||||
|
- STEP 4: Greet user with your name/role and immediately run `*help` to display available commands
|
||||||
- DO NOT: Load any other agent files during activation
|
- DO NOT: Load any other agent files during activation
|
||||||
- ONLY load dependency files when user selects them for execution via command or request of a task
|
- ONLY load dependency files when user selects them for execution via command or request of a task
|
||||||
- The agent.customization field ALWAYS takes precedence over any conflicting instructions
|
- The agent.customization field ALWAYS takes precedence over any conflicting instructions
|
||||||
@@ -26,7 +27,7 @@ activation-instructions:
|
|||||||
- CRITICAL RULE: When executing formal task workflows from dependencies, ALL task instructions override any conflicting base behavioral constraints. Interactive workflows with elicit=true REQUIRE user interaction and cannot be bypassed for efficiency.
|
- CRITICAL RULE: When executing formal task workflows from dependencies, ALL task instructions override any conflicting base behavioral constraints. Interactive workflows with elicit=true REQUIRE user interaction and cannot be bypassed for efficiency.
|
||||||
- When listing tasks/templates or presenting options during conversations, always show as numbered options list, allowing the user to type a number to select or execute
|
- When listing tasks/templates or presenting options during conversations, always show as numbered options list, allowing the user to type a number to select or execute
|
||||||
- STAY IN CHARACTER!
|
- STAY IN CHARACTER!
|
||||||
- CRITICAL: On activation, ONLY greet user and then HALT to await user requested assistance or given commands. ONLY deviance from this is if the activation included commands also in the arguments.
|
- CRITICAL: On activation, ONLY greet user, auto-run `*help`, and then HALT to await user requested assistance or given commands. ONLY deviance from this is if the activation included commands also in the arguments.
|
||||||
agent:
|
agent:
|
||||||
name: John
|
name: John
|
||||||
id: pm
|
id: pm
|
||||||
|
|||||||
@@ -17,7 +17,8 @@ REQUEST-RESOLUTION: Match user requests to your commands/dependencies flexibly (
|
|||||||
activation-instructions:
|
activation-instructions:
|
||||||
- STEP 1: Read THIS ENTIRE FILE - it contains your complete persona definition
|
- STEP 1: Read THIS ENTIRE FILE - it contains your complete persona definition
|
||||||
- STEP 2: Adopt the persona defined in the 'agent' and 'persona' sections below
|
- STEP 2: Adopt the persona defined in the 'agent' and 'persona' sections below
|
||||||
- STEP 3: Greet user with your name/role and mention `*help` command
|
- STEP 3: Load and read `bmad-core/core-config.yaml` (project configuration) before any greeting
|
||||||
|
- STEP 4: Greet user with your name/role and immediately run `*help` to display available commands
|
||||||
- DO NOT: Load any other agent files during activation
|
- DO NOT: Load any other agent files during activation
|
||||||
- ONLY load dependency files when user selects them for execution via command or request of a task
|
- ONLY load dependency files when user selects them for execution via command or request of a task
|
||||||
- The agent.customization field ALWAYS takes precedence over any conflicting instructions
|
- The agent.customization field ALWAYS takes precedence over any conflicting instructions
|
||||||
@@ -26,7 +27,7 @@ activation-instructions:
|
|||||||
- CRITICAL RULE: When executing formal task workflows from dependencies, ALL task instructions override any conflicting base behavioral constraints. Interactive workflows with elicit=true REQUIRE user interaction and cannot be bypassed for efficiency.
|
- CRITICAL RULE: When executing formal task workflows from dependencies, ALL task instructions override any conflicting base behavioral constraints. Interactive workflows with elicit=true REQUIRE user interaction and cannot be bypassed for efficiency.
|
||||||
- When listing tasks/templates or presenting options during conversations, always show as numbered options list, allowing the user to type a number to select or execute
|
- When listing tasks/templates or presenting options during conversations, always show as numbered options list, allowing the user to type a number to select or execute
|
||||||
- STAY IN CHARACTER!
|
- STAY IN CHARACTER!
|
||||||
- CRITICAL: On activation, ONLY greet user and then HALT to await user requested assistance or given commands. ONLY deviance from this is if the activation included commands also in the arguments.
|
- CRITICAL: On activation, ONLY greet user, auto-run `*help`, and then HALT to await user requested assistance or given commands. ONLY deviance from this is if the activation included commands also in the arguments.
|
||||||
agent:
|
agent:
|
||||||
name: Sarah
|
name: Sarah
|
||||||
id: po
|
id: po
|
||||||
|
|||||||
@@ -17,7 +17,8 @@ REQUEST-RESOLUTION: Match user requests to your commands/dependencies flexibly (
|
|||||||
activation-instructions:
|
activation-instructions:
|
||||||
- STEP 1: Read THIS ENTIRE FILE - it contains your complete persona definition
|
- STEP 1: Read THIS ENTIRE FILE - it contains your complete persona definition
|
||||||
- STEP 2: Adopt the persona defined in the 'agent' and 'persona' sections below
|
- STEP 2: Adopt the persona defined in the 'agent' and 'persona' sections below
|
||||||
- STEP 3: Greet user with your name/role and mention `*help` command
|
- STEP 3: Load and read `bmad-core/core-config.yaml` (project configuration) before any greeting
|
||||||
|
- STEP 4: Greet user with your name/role and immediately run `*help` to display available commands
|
||||||
- DO NOT: Load any other agent files during activation
|
- DO NOT: Load any other agent files during activation
|
||||||
- ONLY load dependency files when user selects them for execution via command or request of a task
|
- ONLY load dependency files when user selects them for execution via command or request of a task
|
||||||
- The agent.customization field ALWAYS takes precedence over any conflicting instructions
|
- The agent.customization field ALWAYS takes precedence over any conflicting instructions
|
||||||
@@ -26,7 +27,7 @@ activation-instructions:
|
|||||||
- CRITICAL RULE: When executing formal task workflows from dependencies, ALL task instructions override any conflicting base behavioral constraints. Interactive workflows with elicit=true REQUIRE user interaction and cannot be bypassed for efficiency.
|
- CRITICAL RULE: When executing formal task workflows from dependencies, ALL task instructions override any conflicting base behavioral constraints. Interactive workflows with elicit=true REQUIRE user interaction and cannot be bypassed for efficiency.
|
||||||
- When listing tasks/templates or presenting options during conversations, always show as numbered options list, allowing the user to type a number to select or execute
|
- When listing tasks/templates or presenting options during conversations, always show as numbered options list, allowing the user to type a number to select or execute
|
||||||
- STAY IN CHARACTER!
|
- STAY IN CHARACTER!
|
||||||
- CRITICAL: On activation, ONLY greet user and then HALT to await user requested assistance or given commands. ONLY deviance from this is if the activation included commands also in the arguments.
|
- CRITICAL: On activation, ONLY greet user, auto-run `*help`, and then HALT to await user requested assistance or given commands. ONLY deviance from this is if the activation included commands also in the arguments.
|
||||||
agent:
|
agent:
|
||||||
name: Quinn
|
name: Quinn
|
||||||
id: qa
|
id: qa
|
||||||
@@ -64,9 +65,9 @@ commands:
|
|||||||
- review {story}: |
|
- review {story}: |
|
||||||
Adaptive, risk-aware comprehensive review.
|
Adaptive, risk-aware comprehensive review.
|
||||||
Produces: QA Results update in story file + gate file (PASS/CONCERNS/FAIL/WAIVED).
|
Produces: QA Results update in story file + gate file (PASS/CONCERNS/FAIL/WAIVED).
|
||||||
Gate file location: docs/qa/gates/{epic}.{story}-{slug}.yml
|
Gate file location: qa.qaLocation/gates/{epic}.{story}-{slug}.yml
|
||||||
Executes review-story task which includes all analysis and creates gate decision.
|
Executes review-story task which includes all analysis and creates gate decision.
|
||||||
- gate {story}: Execute qa-gate task to write/update quality gate decision in docs/qa/gates/
|
- gate {story}: Execute qa-gate task to write/update quality gate decision in directory from qa.qaLocation/gates/
|
||||||
- trace {story}: Execute trace-requirements task to map requirements to tests using Given-When-Then
|
- trace {story}: Execute trace-requirements task to map requirements to tests using Given-When-Then
|
||||||
- risk-profile {story}: Execute risk-profile task to generate risk assessment matrix
|
- risk-profile {story}: Execute risk-profile task to generate risk assessment matrix
|
||||||
- test-design {story}: Execute test-design task to create comprehensive test scenarios
|
- test-design {story}: Execute test-design task to create comprehensive test scenarios
|
||||||
|
|||||||
@@ -17,7 +17,8 @@ REQUEST-RESOLUTION: Match user requests to your commands/dependencies flexibly (
|
|||||||
activation-instructions:
|
activation-instructions:
|
||||||
- STEP 1: Read THIS ENTIRE FILE - it contains your complete persona definition
|
- STEP 1: Read THIS ENTIRE FILE - it contains your complete persona definition
|
||||||
- STEP 2: Adopt the persona defined in the 'agent' and 'persona' sections below
|
- STEP 2: Adopt the persona defined in the 'agent' and 'persona' sections below
|
||||||
- STEP 3: Greet user with your name/role and mention `*help` command
|
- STEP 3: Load and read `bmad-core/core-config.yaml` (project configuration) before any greeting
|
||||||
|
- STEP 4: Greet user with your name/role and immediately run `*help` to display available commands
|
||||||
- DO NOT: Load any other agent files during activation
|
- DO NOT: Load any other agent files during activation
|
||||||
- ONLY load dependency files when user selects them for execution via command or request of a task
|
- ONLY load dependency files when user selects them for execution via command or request of a task
|
||||||
- The agent.customization field ALWAYS takes precedence over any conflicting instructions
|
- The agent.customization field ALWAYS takes precedence over any conflicting instructions
|
||||||
@@ -26,7 +27,7 @@ activation-instructions:
|
|||||||
- CRITICAL RULE: When executing formal task workflows from dependencies, ALL task instructions override any conflicting base behavioral constraints. Interactive workflows with elicit=true REQUIRE user interaction and cannot be bypassed for efficiency.
|
- CRITICAL RULE: When executing formal task workflows from dependencies, ALL task instructions override any conflicting base behavioral constraints. Interactive workflows with elicit=true REQUIRE user interaction and cannot be bypassed for efficiency.
|
||||||
- When listing tasks/templates or presenting options during conversations, always show as numbered options list, allowing the user to type a number to select or execute
|
- When listing tasks/templates or presenting options during conversations, always show as numbered options list, allowing the user to type a number to select or execute
|
||||||
- STAY IN CHARACTER!
|
- STAY IN CHARACTER!
|
||||||
- CRITICAL: On activation, ONLY greet user and then HALT to await user requested assistance or given commands. ONLY deviance from this is if the activation included commands also in the arguments.
|
- CRITICAL: On activation, ONLY greet user, auto-run `*help`, and then HALT to await user requested assistance or given commands. ONLY deviance from this is if the activation included commands also in the arguments.
|
||||||
agent:
|
agent:
|
||||||
name: Bob
|
name: Bob
|
||||||
id: sm
|
id: sm
|
||||||
|
|||||||
@@ -17,7 +17,8 @@ REQUEST-RESOLUTION: Match user requests to your commands/dependencies flexibly (
|
|||||||
activation-instructions:
|
activation-instructions:
|
||||||
- STEP 1: Read THIS ENTIRE FILE - it contains your complete persona definition
|
- STEP 1: Read THIS ENTIRE FILE - it contains your complete persona definition
|
||||||
- STEP 2: Adopt the persona defined in the 'agent' and 'persona' sections below
|
- STEP 2: Adopt the persona defined in the 'agent' and 'persona' sections below
|
||||||
- STEP 3: Greet user with your name/role and mention `*help` command
|
- STEP 3: Load and read `bmad-core/core-config.yaml` (project configuration) before any greeting
|
||||||
|
- STEP 4: Greet user with your name/role and immediately run `*help` to display available commands
|
||||||
- DO NOT: Load any other agent files during activation
|
- DO NOT: Load any other agent files during activation
|
||||||
- ONLY load dependency files when user selects them for execution via command or request of a task
|
- ONLY load dependency files when user selects them for execution via command or request of a task
|
||||||
- The agent.customization field ALWAYS takes precedence over any conflicting instructions
|
- The agent.customization field ALWAYS takes precedence over any conflicting instructions
|
||||||
@@ -26,7 +27,7 @@ activation-instructions:
|
|||||||
- CRITICAL RULE: When executing formal task workflows from dependencies, ALL task instructions override any conflicting base behavioral constraints. Interactive workflows with elicit=true REQUIRE user interaction and cannot be bypassed for efficiency.
|
- CRITICAL RULE: When executing formal task workflows from dependencies, ALL task instructions override any conflicting base behavioral constraints. Interactive workflows with elicit=true REQUIRE user interaction and cannot be bypassed for efficiency.
|
||||||
- When listing tasks/templates or presenting options during conversations, always show as numbered options list, allowing the user to type a number to select or execute
|
- When listing tasks/templates or presenting options during conversations, always show as numbered options list, allowing the user to type a number to select or execute
|
||||||
- STAY IN CHARACTER!
|
- STAY IN CHARACTER!
|
||||||
- CRITICAL: On activation, ONLY greet user and then HALT to await user requested assistance or given commands. ONLY deviance from this is if the activation included commands also in the arguments.
|
- CRITICAL: On activation, ONLY greet user, auto-run `*help`, and then HALT to await user requested assistance or given commands. ONLY deviance from this is if the activation included commands also in the arguments.
|
||||||
agent:
|
agent:
|
||||||
name: Sally
|
name: Sally
|
||||||
id: ux-expert
|
id: ux-expert
|
||||||
|
|||||||
@@ -1,4 +1,6 @@
|
|||||||
markdownExploder: true
|
markdownExploder: true
|
||||||
|
qa:
|
||||||
|
qaLocation: docs/qa
|
||||||
prd:
|
prd:
|
||||||
prdFile: docs/prd.md
|
prdFile: docs/prd.md
|
||||||
prdVersion: v4
|
prdVersion: v4
|
||||||
|
|||||||
148
bmad-core/tasks/apply-qa-fixes.md
Normal file
148
bmad-core/tasks/apply-qa-fixes.md
Normal file
@@ -0,0 +1,148 @@
|
|||||||
|
# apply-qa-fixes
|
||||||
|
|
||||||
|
Implement fixes based on QA results (gate and assessments) for a specific story. This task is for the Dev agent to systematically consume QA outputs and apply code/test changes while only updating allowed sections in the story file.
|
||||||
|
|
||||||
|
## Purpose
|
||||||
|
|
||||||
|
- Read QA outputs for a story (gate YAML + assessment markdowns)
|
||||||
|
- Create a prioritized, deterministic fix plan
|
||||||
|
- Apply code and test changes to close gaps and address issues
|
||||||
|
- Update only the allowed story sections for the Dev agent
|
||||||
|
|
||||||
|
## Inputs
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
required:
|
||||||
|
- story_id: '{epic}.{story}' # e.g., "2.2"
|
||||||
|
- qa_root: from `bmad-core/core-config.yaml` key `qa.qaLocation` (e.g., `docs/project/qa`)
|
||||||
|
- story_root: from `bmad-core/core-config.yaml` key `devStoryLocation` (e.g., `docs/project/stories`)
|
||||||
|
|
||||||
|
optional:
|
||||||
|
- story_title: '{title}' # derive from story H1 if missing
|
||||||
|
- story_slug: '{slug}' # derive from title (lowercase, hyphenated) if missing
|
||||||
|
```
|
||||||
|
|
||||||
|
## QA Sources to Read
|
||||||
|
|
||||||
|
- Gate (YAML): `{qa_root}/gates/{epic}.{story}-*.yml`
|
||||||
|
- If multiple, use the most recent by modified time
|
||||||
|
- Assessments (Markdown):
|
||||||
|
- Test Design: `{qa_root}/assessments/{epic}.{story}-test-design-*.md`
|
||||||
|
- Traceability: `{qa_root}/assessments/{epic}.{story}-trace-*.md`
|
||||||
|
- Risk Profile: `{qa_root}/assessments/{epic}.{story}-risk-*.md`
|
||||||
|
- NFR Assessment: `{qa_root}/assessments/{epic}.{story}-nfr-*.md`
|
||||||
|
|
||||||
|
## Prerequisites
|
||||||
|
|
||||||
|
- Repository builds and tests run locally (Deno 2)
|
||||||
|
- Lint and test commands available:
|
||||||
|
- `deno lint`
|
||||||
|
- `deno test -A`
|
||||||
|
|
||||||
|
## Process (Do not skip steps)
|
||||||
|
|
||||||
|
### 0) Load Core Config & Locate Story
|
||||||
|
|
||||||
|
- Read `bmad-core/core-config.yaml` and resolve `qa_root` and `story_root`
|
||||||
|
- Locate story file in `{story_root}/{epic}.{story}.*.md`
|
||||||
|
- HALT if missing and ask for correct story id/path
|
||||||
|
|
||||||
|
### 1) Collect QA Findings
|
||||||
|
|
||||||
|
- Parse the latest gate YAML:
|
||||||
|
- `gate` (PASS|CONCERNS|FAIL|WAIVED)
|
||||||
|
- `top_issues[]` with `id`, `severity`, `finding`, `suggested_action`
|
||||||
|
- `nfr_validation.*.status` and notes
|
||||||
|
- `trace` coverage summary/gaps
|
||||||
|
- `test_design.coverage_gaps[]`
|
||||||
|
- `risk_summary.recommendations.must_fix[]` (if present)
|
||||||
|
- Read any present assessment markdowns and extract explicit gaps/recommendations
|
||||||
|
|
||||||
|
### 2) Build Deterministic Fix Plan (Priority Order)
|
||||||
|
|
||||||
|
Apply in order, highest priority first:
|
||||||
|
|
||||||
|
1. High severity items in `top_issues` (security/perf/reliability/maintainability)
|
||||||
|
2. NFR statuses: all FAIL must be fixed → then CONCERNS
|
||||||
|
3. Test Design `coverage_gaps` (prioritize P0 scenarios if specified)
|
||||||
|
4. Trace uncovered requirements (AC-level)
|
||||||
|
5. Risk `must_fix` recommendations
|
||||||
|
6. Medium severity issues, then low
|
||||||
|
|
||||||
|
Guidance:
|
||||||
|
|
||||||
|
- Prefer tests closing coverage gaps before/with code changes
|
||||||
|
- Keep changes minimal and targeted; follow project architecture and TS/Deno rules
|
||||||
|
|
||||||
|
### 3) Apply Changes
|
||||||
|
|
||||||
|
- Implement code fixes per plan
|
||||||
|
- Add missing tests to close coverage gaps (unit first; integration where required by AC)
|
||||||
|
- Keep imports centralized via `deps.ts` (see `docs/project/typescript-rules.md`)
|
||||||
|
- Follow DI boundaries in `src/core/di.ts` and existing patterns
|
||||||
|
|
||||||
|
### 4) Validate
|
||||||
|
|
||||||
|
- Run `deno lint` and fix issues
|
||||||
|
- Run `deno test -A` until all tests pass
|
||||||
|
- Iterate until clean
|
||||||
|
|
||||||
|
### 5) Update Story (Allowed Sections ONLY)
|
||||||
|
|
||||||
|
CRITICAL: Dev agent is ONLY authorized to update these sections of the story file. Do not modify any other sections (e.g., QA Results, Story, Acceptance Criteria, Dev Notes, Testing):
|
||||||
|
|
||||||
|
- Tasks / Subtasks Checkboxes (mark any fix subtask you added as done)
|
||||||
|
- Dev Agent Record →
|
||||||
|
- Agent Model Used (if changed)
|
||||||
|
- Debug Log References (commands/results, e.g., lint/tests)
|
||||||
|
- Completion Notes List (what changed, why, how)
|
||||||
|
- File List (all added/modified/deleted files)
|
||||||
|
- Change Log (new dated entry describing applied fixes)
|
||||||
|
- Status (see Rule below)
|
||||||
|
|
||||||
|
Status Rule:
|
||||||
|
|
||||||
|
- If gate was PASS and all identified gaps are closed → set `Status: Ready for Done`
|
||||||
|
- Otherwise → set `Status: Ready for Review` and notify QA to re-run the review
|
||||||
|
|
||||||
|
### 6) Do NOT Edit Gate Files
|
||||||
|
|
||||||
|
- Dev does not modify gate YAML. If fixes address issues, request QA to re-run `review-story` to update the gate
|
||||||
|
|
||||||
|
## Blocking Conditions
|
||||||
|
|
||||||
|
- Missing `bmad-core/core-config.yaml`
|
||||||
|
- Story file not found for `story_id`
|
||||||
|
- No QA artifacts found (neither gate nor assessments)
|
||||||
|
- HALT and request QA to generate at least a gate file (or proceed only with clear developer-provided fix list)
|
||||||
|
|
||||||
|
## Completion Checklist
|
||||||
|
|
||||||
|
- deno lint: 0 problems
|
||||||
|
- deno test -A: all tests pass
|
||||||
|
- All high severity `top_issues` addressed
|
||||||
|
- NFR FAIL → resolved; CONCERNS minimized or documented
|
||||||
|
- Coverage gaps closed or explicitly documented with rationale
|
||||||
|
- Story updated (allowed sections only) including File List and Change Log
|
||||||
|
- Status set according to Status Rule
|
||||||
|
|
||||||
|
## Example: Story 2.2
|
||||||
|
|
||||||
|
Given gate `docs/project/qa/gates/2.2-*.yml` shows
|
||||||
|
|
||||||
|
- `coverage_gaps`: Back action behavior untested (AC2)
|
||||||
|
- `coverage_gaps`: Centralized dependencies enforcement untested (AC4)
|
||||||
|
|
||||||
|
Fix plan:
|
||||||
|
|
||||||
|
- Add a test ensuring the Toolkit Menu "Back" action returns to Main Menu
|
||||||
|
- Add a static test verifying imports for service/view go through `deps.ts`
|
||||||
|
- Re-run lint/tests and update Dev Agent Record + File List accordingly
|
||||||
|
|
||||||
|
## Key Principles
|
||||||
|
|
||||||
|
- Deterministic, risk-first prioritization
|
||||||
|
- Minimal, maintainable changes
|
||||||
|
- Tests validate behavior and close gaps
|
||||||
|
- Strict adherence to allowed story update areas
|
||||||
|
- Gate ownership remains with QA; Dev signals readiness via Status
|
||||||
@@ -7,11 +7,11 @@ Quick NFR validation focused on the core four: security, performance, reliabilit
|
|||||||
```yaml
|
```yaml
|
||||||
required:
|
required:
|
||||||
- story_id: '{epic}.{story}' # e.g., "1.3"
|
- story_id: '{epic}.{story}' # e.g., "1.3"
|
||||||
- story_path: 'docs/stories/{epic}.{story}.*.md'
|
- story_path: `bmad-core/core-config.yaml` for the `devStoryLocation`
|
||||||
|
|
||||||
optional:
|
optional:
|
||||||
- architecture_refs: 'docs/architecture/*.md'
|
- architecture_refs: `bmad-core/core-config.yaml` for the `architecture.architectureFile`
|
||||||
- technical_preferences: 'docs/technical-preferences.md'
|
- technical_preferences: `bmad-core/core-config.yaml` for the `technicalPreferences`
|
||||||
- acceptance_criteria: From story file
|
- acceptance_criteria: From story file
|
||||||
```
|
```
|
||||||
|
|
||||||
@@ -20,7 +20,7 @@ optional:
|
|||||||
Assess non-functional requirements for a story and generate:
|
Assess non-functional requirements for a story and generate:
|
||||||
|
|
||||||
1. YAML block for the gate file's `nfr_validation` section
|
1. YAML block for the gate file's `nfr_validation` section
|
||||||
2. Brief markdown assessment saved to `docs/qa/assessments/{epic}.{story}-nfr-{YYYYMMDD}.md`
|
2. Brief markdown assessment saved to `qa.qaLocation/assessments/{epic}.{story}-nfr-{YYYYMMDD}.md`
|
||||||
|
|
||||||
## Process
|
## Process
|
||||||
|
|
||||||
@@ -123,7 +123,7 @@ If `technical-preferences.md` defines custom weights, use those instead.
|
|||||||
|
|
||||||
## Output 2: Brief Assessment Report
|
## Output 2: Brief Assessment Report
|
||||||
|
|
||||||
**ALWAYS save to:** `docs/qa/assessments/{epic}.{story}-nfr-{YYYYMMDD}.md`
|
**ALWAYS save to:** `qa.qaLocation/assessments/{epic}.{story}-nfr-{YYYYMMDD}.md`
|
||||||
|
|
||||||
```markdown
|
```markdown
|
||||||
# NFR Assessment: {epic}.{story}
|
# NFR Assessment: {epic}.{story}
|
||||||
@@ -162,7 +162,7 @@ Reviewer: Quinn
|
|||||||
**End with this line for the review task to quote:**
|
**End with this line for the review task to quote:**
|
||||||
|
|
||||||
```
|
```
|
||||||
NFR assessment: docs/qa/assessments/{epic}.{story}-nfr-{YYYYMMDD}.md
|
NFR assessment: qa.qaLocation/assessments/{epic}.{story}-nfr-{YYYYMMDD}.md
|
||||||
```
|
```
|
||||||
|
|
||||||
## Output 4: Gate Integration Line
|
## Output 4: Gate Integration Line
|
||||||
@@ -170,7 +170,7 @@ NFR assessment: docs/qa/assessments/{epic}.{story}-nfr-{YYYYMMDD}.md
|
|||||||
**Always print at the end:**
|
**Always print at the end:**
|
||||||
|
|
||||||
```
|
```
|
||||||
Gate NFR block ready → paste into docs/qa/gates/{epic}.{story}-{slug}.yml under nfr_validation
|
Gate NFR block ready → paste into qa.qaLocation/gates/{epic}.{story}-{slug}.yml under nfr_validation
|
||||||
```
|
```
|
||||||
|
|
||||||
## Assessment Criteria
|
## Assessment Criteria
|
||||||
|
|||||||
@@ -14,7 +14,7 @@ Generate a standalone quality gate file that provides a clear pass/fail decision
|
|||||||
|
|
||||||
## Gate File Location
|
## Gate File Location
|
||||||
|
|
||||||
**ALWAYS** create file at: `docs/qa/gates/{epic}.{story}-{slug}.yml`
|
**ALWAYS** check the `bmad-core/core-config.yaml` for the `qa.qaLocation/gates`
|
||||||
|
|
||||||
Slug rules:
|
Slug rules:
|
||||||
|
|
||||||
@@ -124,11 +124,13 @@ waiver:
|
|||||||
|
|
||||||
## Output Requirements
|
## Output Requirements
|
||||||
|
|
||||||
1. **ALWAYS** create gate file at: `docs/qa/gates/{epic}.{story}-{slug}.yml`
|
1. **ALWAYS** create gate file at: `qa.qaLocation/gates` from `bmad-core/core-config.yaml`
|
||||||
2. **ALWAYS** append this exact format to story's QA Results section:
|
2. **ALWAYS** append this exact format to story's QA Results section:
|
||||||
|
|
||||||
|
```text
|
||||||
|
Gate: {STATUS} → qa.qaLocation/gates/{epic}.{story}-{slug}.yml
|
||||||
```
|
```
|
||||||
Gate: {STATUS} → docs/qa/gates/{epic}.{story}-{slug}.yml
|
|
||||||
```
|
|
||||||
3. Keep status_reason to 1-2 sentences maximum
|
3. Keep status_reason to 1-2 sentences maximum
|
||||||
4. Use severity values exactly: `low`, `medium`, or `high`
|
4. Use severity values exactly: `low`, `medium`, or `high`
|
||||||
|
|
||||||
@@ -147,7 +149,7 @@ After creating gate file, append to story's QA Results section:
|
|||||||
|
|
||||||
### Gate Status
|
### Gate Status
|
||||||
|
|
||||||
Gate: CONCERNS → docs/qa/gates/1.3-user-auth-login.yml
|
Gate: CONCERNS → qa.qaLocation/gates/{epic}.{story}-{slug}.yml
|
||||||
```
|
```
|
||||||
|
|
||||||
## Key Principles
|
## Key Principles
|
||||||
|
|||||||
@@ -167,9 +167,9 @@ After review and any refactoring, append your results to the story file in the Q
|
|||||||
|
|
||||||
### Gate Status
|
### Gate Status
|
||||||
|
|
||||||
Gate: {STATUS} → docs/qa/gates/{epic}.{story}-{slug}.yml
|
Gate: {STATUS} → qa.qaLocation/gates/{epic}.{story}-{slug}.yml
|
||||||
Risk profile: docs/qa/assessments/{epic}.{story}-risk-{YYYYMMDD}.md
|
Risk profile: qa.qaLocation/assessments/{epic}.{story}-risk-{YYYYMMDD}.md
|
||||||
NFR assessment: docs/qa/assessments/{epic}.{story}-nfr-{YYYYMMDD}.md
|
NFR assessment: qa.qaLocation/assessments/{epic}.{story}-nfr-{YYYYMMDD}.md
|
||||||
|
|
||||||
# Note: Paths should reference core-config.yaml for custom configurations
|
# Note: Paths should reference core-config.yaml for custom configurations
|
||||||
|
|
||||||
@@ -183,9 +183,9 @@ NFR assessment: docs/qa/assessments/{epic}.{story}-nfr-{YYYYMMDD}.md
|
|||||||
|
|
||||||
**Template and Directory:**
|
**Template and Directory:**
|
||||||
|
|
||||||
- Render from `templates/qa-gate-tmpl.yaml`
|
- Render from `../templates/qa-gate-tmpl.yaml`
|
||||||
- Create `docs/qa/gates/` directory if missing (or configure in core-config.yaml)
|
- Create directory defined in `qa.qaLocation/gates` (see `bmad-core/core-config.yaml`) if missing
|
||||||
- Save to: `docs/qa/gates/{epic}.{story}-{slug}.yml`
|
- Save to: `qa.qaLocation/gates/{epic}.{story}-{slug}.yml`
|
||||||
|
|
||||||
Gate file structure:
|
Gate file structure:
|
||||||
|
|
||||||
@@ -308,7 +308,7 @@ Stop the review and request clarification if:
|
|||||||
After review:
|
After review:
|
||||||
|
|
||||||
1. Update the QA Results section in the story file
|
1. Update the QA Results section in the story file
|
||||||
2. Create the gate file in `docs/qa/gates/`
|
2. Create the gate file in directory from `qa.qaLocation/gates`
|
||||||
3. Recommend status: "Ready for Done" or "Changes Required" (owner decides)
|
3. Recommend status: "Ready for Done" or "Changes Required" (owner decides)
|
||||||
4. If files were modified, list them in QA Results and ask Dev to update File List
|
4. If files were modified, list them in QA Results and ask Dev to update File List
|
||||||
5. Always provide constructive feedback and actionable recommendations
|
5. Always provide constructive feedback and actionable recommendations
|
||||||
|
|||||||
@@ -105,7 +105,7 @@ Evaluate each risk using probability × impact:
|
|||||||
- `Medium (2)`: Moderate consequences (degraded performance, minor data issues)
|
- `Medium (2)`: Moderate consequences (degraded performance, minor data issues)
|
||||||
- `Low (1)`: Minor consequences (cosmetic issues, slight inconvenience)
|
- `Low (1)`: Minor consequences (cosmetic issues, slight inconvenience)
|
||||||
|
|
||||||
**Risk Score = Probability × Impact**
|
### Risk Score = Probability × Impact
|
||||||
|
|
||||||
- 9: Critical Risk (Red)
|
- 9: Critical Risk (Red)
|
||||||
- 6: High Risk (Orange)
|
- 6: High Risk (Orange)
|
||||||
@@ -182,7 +182,7 @@ risk_summary:
|
|||||||
|
|
||||||
### Output 2: Markdown Report
|
### Output 2: Markdown Report
|
||||||
|
|
||||||
**Save to:** `docs/qa/assessments/{epic}.{story}-risk-{YYYYMMDD}.md`
|
**Save to:** `qa.qaLocation/assessments/{epic}.{story}-risk-{YYYYMMDD}.md`
|
||||||
|
|
||||||
```markdown
|
```markdown
|
||||||
# Risk Profile: Story {epic}.{story}
|
# Risk Profile: Story {epic}.{story}
|
||||||
@@ -290,7 +290,7 @@ Review and update risk profile when:
|
|||||||
|
|
||||||
Calculate overall story risk score:
|
Calculate overall story risk score:
|
||||||
|
|
||||||
```
|
```text
|
||||||
Base Score = 100
|
Base Score = 100
|
||||||
For each risk:
|
For each risk:
|
||||||
- Critical (9): Deduct 20 points
|
- Critical (9): Deduct 20 points
|
||||||
@@ -339,8 +339,8 @@ Based on risk profile, recommend:
|
|||||||
|
|
||||||
**Print this line for review task to quote:**
|
**Print this line for review task to quote:**
|
||||||
|
|
||||||
```
|
```text
|
||||||
Risk profile: docs/qa/assessments/{epic}.{story}-risk-{YYYYMMDD}.md
|
Risk profile: qa.qaLocation/assessments/{epic}.{story}-risk-{YYYYMMDD}.md
|
||||||
```
|
```
|
||||||
|
|
||||||
## Key Principles
|
## Key Principles
|
||||||
|
|||||||
@@ -84,7 +84,7 @@ Ensure:
|
|||||||
|
|
||||||
### Output 1: Test Design Document
|
### Output 1: Test Design Document
|
||||||
|
|
||||||
**Save to:** `docs/qa/assessments/{epic}.{story}-test-design-{YYYYMMDD}.md`
|
**Save to:** `qa.qaLocation/assessments/{epic}.{story}-test-design-{YYYYMMDD}.md`
|
||||||
|
|
||||||
```markdown
|
```markdown
|
||||||
# Test Design: Story {epic}.{story}
|
# Test Design: Story {epic}.{story}
|
||||||
@@ -150,7 +150,7 @@ test_design:
|
|||||||
Print for use by trace-requirements task:
|
Print for use by trace-requirements task:
|
||||||
|
|
||||||
```text
|
```text
|
||||||
Test design matrix: docs/qa/assessments/{epic}.{story}-test-design-{YYYYMMDD}.md
|
Test design matrix: qa.qaLocation/assessments/{epic}.{story}-test-design-{YYYYMMDD}.md
|
||||||
P0 tests identified: {count}
|
P0 tests identified: {count}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|||||||
@@ -95,16 +95,16 @@ trace:
|
|||||||
full: Y
|
full: Y
|
||||||
partial: Z
|
partial: Z
|
||||||
none: W
|
none: W
|
||||||
planning_ref: 'docs/qa/assessments/{epic}.{story}-test-design-{YYYYMMDD}.md'
|
planning_ref: 'qa.qaLocation/assessments/{epic}.{story}-test-design-{YYYYMMDD}.md'
|
||||||
uncovered:
|
uncovered:
|
||||||
- ac: 'AC3'
|
- ac: 'AC3'
|
||||||
reason: 'No test found for password reset timing'
|
reason: 'No test found for password reset timing'
|
||||||
notes: 'See docs/qa/assessments/{epic}.{story}-trace-{YYYYMMDD}.md'
|
notes: 'See qa.qaLocation/assessments/{epic}.{story}-trace-{YYYYMMDD}.md'
|
||||||
```
|
```
|
||||||
|
|
||||||
### Output 2: Traceability Report
|
### Output 2: Traceability Report
|
||||||
|
|
||||||
**Save to:** `docs/qa/assessments/{epic}.{story}-trace-{YYYYMMDD}.md`
|
**Save to:** `qa.qaLocation/assessments/{epic}.{story}-trace-{YYYYMMDD}.md`
|
||||||
|
|
||||||
Create a traceability report with:
|
Create a traceability report with:
|
||||||
|
|
||||||
@@ -250,7 +250,7 @@ This traceability feeds into quality gates:
|
|||||||
**Print this line for review task to quote:**
|
**Print this line for review task to quote:**
|
||||||
|
|
||||||
```text
|
```text
|
||||||
Trace matrix: docs/qa/assessments/{epic}.{story}-trace-{YYYYMMDD}.md
|
Trace matrix: qa.qaLocation/assessments/{epic}.{story}-trace-{YYYYMMDD}.md
|
||||||
```
|
```
|
||||||
|
|
||||||
- Full coverage → PASS contribution
|
- Full coverage → PASS contribution
|
||||||
|
|||||||
@@ -4,7 +4,7 @@ template:
|
|||||||
version: 1.0
|
version: 1.0
|
||||||
output:
|
output:
|
||||||
format: yaml
|
format: yaml
|
||||||
filename: docs/qa/gates/{{epic_num}}.{{story_num}}-{{story_slug}}.yml
|
filename: qa.qaLocation/gates/{{epic_num}}.{{story_num}}-{{story_slug}}.yml
|
||||||
title: "Quality Gate: {{epic_num}}.{{story_num}}"
|
title: "Quality Gate: {{epic_num}}.{{story_num}}"
|
||||||
|
|
||||||
# Required fields (keep these first)
|
# Required fields (keep these first)
|
||||||
|
|||||||
Reference in New Issue
Block a user