User Story Writing Skill
Purpose
Write clear, valuable user stories that communicate requirements in Agile/Hybrid environments and guide development teams.
When to Use
- •Agile or Hybrid projects
- •Sprint planning and backlog refinement
- •Breaking down features into implementable chunks
- •Communicating requirements to development teams
User Story Format
Basic Template
As a [user role] I want [goal/desire] So that [benefit/value]
Enhanced Template (Recommended)
Title: [Short, descriptive title] As a [user role] I want [goal/desire] So that [benefit/value] Acceptance Criteria: - [Criterion 1] - [Criterion 2] - [Criterion 3] Notes: [Additional context, wireframes, business rules] Definition of Done: - [ ] Code complete and peer reviewed - [ ] Unit tests written and passing - [ ] Integration tests passing - [ ] Acceptance criteria met - [ ] Documentation updated
INVEST Criteria
Every user story should be:
- •Independent: Can be developed and delivered independently
- •Negotiable: Details can be discussed and refined
- •Valuable: Delivers value to users or business
- •Estimable: Team can estimate effort required
- •Small: Can be completed within one sprint
- •Testable: Clear acceptance criteria for testing
Examples by Domain
E-commerce Examples
Story 1: Guest Checkout
Title: Guest Checkout Without Account Creation As a first-time customer I want to complete my purchase without creating an account So that I can checkout quickly without friction Acceptance Criteria: - Given I have items in my cart When I click "Checkout as Guest" Then I can enter shipping and payment info without login - Given I complete guest checkout When I receive order confirmation Then I see an option to create an account - Given my order total is over $5000 When I try to checkout as guest Then I am required to create an account for security Business Rules: - Guest checkout not available for orders > $5000 - Email required for order confirmation - Guest orders linked to email for future reference Story Points: 8 Priority: Must Have Sprint: Sprint 3
Story 2: Real-time Shipping Calculation
Title: Real-time Shipping Cost Display As a customer I want to see shipping costs before entering payment information So that I know the total cost upfront and avoid surprises Acceptance Criteria: - Given I enter a valid shipping address When I proceed to shipping method selection Then I see all available shipping options with costs - Given I select a shipping method When I view the order summary Then the shipping cost is included in the total - Given the shipping API is unavailable When I try to calculate shipping Then I see a fallback message with estimated costs Technical Notes: - Integrate with ShipStation API - Cache shipping rates for 5 minutes - Timeout after 5 seconds, show fallback Story Points: 5 Priority: Must Have Sprint: Sprint 3
CRM Examples
Story 3: Automatic Lead Scoring
Title: Automatic Lead Scoring Based on Behavior As a sales manager I want leads to be automatically scored based on their activities So that my team focuses on the most qualified prospects Acceptance Criteria: - Given a lead visits the pricing page When the activity is tracked Then 15 points are added to their score - Given a lead's score reaches 60 When the score is updated Then the lead is automatically marked as MQL - Given a lead's score reaches 75 When the score is updated Then the lead is assigned to a sales rep and rep is notified - Given I view a lead record When I look at the lead score Then I can see the scoring breakdown (why this score) Scoring Rules: - Demographic: Job title (0-20), Company size (0-15), Industry (0-5) - Behavioral: Pricing page (15), Whitepaper (10), Webinar (15), Demo request (25) Story Points: 13 Priority: Must Have Sprint: Sprint 5
Mobile/Web Examples
Story 4: Offline Order Viewing
Title: View Orders Offline in Mobile App As a mobile app user I want to view my order history when offline So that I can check order details without internet connection Acceptance Criteria: - Given I have previously viewed orders while online When I open the app offline Then I can see my cached order history - Given I am offline When I try to view order details Then I see the last synced information with "offline" indicator - Given I regain internet connection When the app detects connectivity Then order data is automatically refreshed in background Technical Notes: - Cache last 50 orders in local storage - Use SQLite for offline storage - Sync on app foreground if connected Story Points: 8 Priority: Should Have Sprint: Sprint 7
ERP Examples
Story 5: Multi-level Purchase Approval
Title: Multi-level Purchase Order Approval Workflow As a procurement manager I want purchase orders to route through appropriate approval levels So that spending is controlled according to company policy Acceptance Criteria: - Given a PO is created for $1K-$10K When the PO is submitted Then it routes to department manager for approval - Given a PO is created for $10K-$50K When the PO is submitted Then it routes to department manager, then finance director - Given a PO is created for >$50K When the PO is submitted Then it routes to department manager, finance director, then CFO - Given an approver is out of office When a PO requires their approval Then it automatically routes to their designated backup - Given an approver rejects a PO When the rejection is submitted Then the requester is notified with rejection reason Approval Matrix: - $0-$1K: Auto-approved - $1K-$10K: Department Manager - $10K-$50K: Department Manager → Finance Director - >$50K: Department Manager → Finance Director → CFO Story Points: 13 Priority: Must Have Sprint: Sprint 4
CDP Examples
Story 6: Customer Identity Resolution
Title: Unify Customer Profiles Across Channels As a marketing analyst I want customer data from web, mobile, and CRM to be unified So that I have a complete view of each customer Acceptance Criteria: - Given a customer logs in on web and mobile with same email When identity resolution runs Then both profiles are merged into single customer record - Given a customer has multiple emails When I manually link the profiles Then all activities are consolidated under primary profile - Given profiles are merged When I view the customer record Then I see all touchpoints across channels in timeline - Given a merge conflict occurs (different names, addresses) When the system detects conflict Then it flags for manual review Matching Rules: - Email (exact match) - High confidence - Phone + Name (fuzzy match) - Medium confidence - Cookie ID + Email domain - Low confidence Story Points: 21 Priority: Must Have Sprint: Sprint 2-3 (2 sprints)
Story Hierarchy
Epic → Feature → User Story → Task
Epic: Large body of work (multiple sprints)
Epic: Mobile App Customer Self-Service Goal: Enable customers to manage accounts via mobile app Timeline: Q1 2026 Stories: 25-30 stories
Feature: Group of related stories (1-3 sprints)
Feature: Order Management in Mobile App Stories: View orders, Track shipments, Initiate returns Sprint: Sprint 5-6
User Story: Single piece of functionality (1 sprint)
Story: View Order History Tasks: API integration, UI development, Offline caching Sprint: Sprint 5
Task: Technical implementation step (hours/days)
Task: Implement order list API endpoint Estimate: 4 hours
Acceptance Criteria Formats
Given-When-Then (Gherkin)
Given [context/precondition] When [action/event] Then [expected outcome]
Example:
Given I am a logged-in customer When I click "View Orders" Then I see a list of my orders sorted by date (newest first)
Checklist Format
- [ ] Criterion 1 - [ ] Criterion 2 - [ ] Criterion 3
Example:
- [ ] Order list displays order number, date, total, status - [ ] Orders are paginated (20 per page) - [ ] User can filter by status (All, Processing, Shipped, Delivered) - [ ] User can search by order number - [ ] Clicking an order opens order details
Scenario-Based
Scenario 1: [Happy path] Scenario 2: [Alternative path] Scenario 3: [Error case]
Story Splitting Techniques
When a story is too large (>13 points), split by:
1. Workflow Steps
- •Original: "User can complete checkout"
- •Split: "Enter shipping info", "Select shipping method", "Enter payment", "Review order"
2. Business Rules
- •Original: "Calculate shipping costs"
- •Split: "Standard shipping", "Express shipping", "International shipping"
3. CRUD Operations
- •Original: "Manage products"
- •Split: "Create product", "Update product", "Delete product", "View products"
4. Data Variations
- •Original: "Import customer data"
- •Split: "Import from CSV", "Import from Excel", "Import from API"
5. Platforms
- •Original: "Mobile app checkout"
- •Split: "iOS checkout", "Android checkout"
6. Simple/Complex
- •Original: "Search products"
- •Split: "Basic keyword search", "Advanced filters", "Faceted search"
Story Estimation
Story Points (Fibonacci: 1, 2, 3, 5, 8, 13, 21)
- •1 point: Trivial change (few hours)
- •2 points: Simple feature (half day)
- •3 points: Straightforward feature (1 day)
- •5 points: Moderate complexity (2-3 days)
- •8 points: Complex feature (3-5 days)
- •13 points: Very complex (5-8 days) - consider splitting
- •21+ points: Too large - must split
T-Shirt Sizing (Alternative)
- •XS: 1-2 points
- •S: 3-5 points
- •M: 8 points
- •L: 13 points
- •XL: 21+ points (split required)
Definition of Ready (DoR)
Story is ready for sprint when:
- • User story follows INVEST criteria
- • Acceptance criteria are clear and testable
- • Dependencies identified and resolved
- • Wireframes/mockups available (if UI work)
- • Business rules documented
- • Story estimated by team
- • Priority assigned
- • Technical approach discussed
Definition of Done (DoD)
Story is complete when:
- • Code complete and peer reviewed
- • Unit tests written (>80% coverage)
- • Integration tests passing
- • All acceptance criteria met
- • Manual testing completed
- • Documentation updated
- • Deployed to staging environment
- • Product owner approved
Best Practices
✅ Do:
- •Write from user perspective
- •Focus on value, not implementation
- •Keep stories small and focused
- •Include clear acceptance criteria
- •Involve the team in writing stories
- •Refine stories before sprint planning
- •Link stories to epics and features
❌ Don't:
- •Write technical tasks as user stories
- •Make stories too large (>13 points)
- •Skip acceptance criteria
- •Write vague or ambiguous stories
- •Include implementation details
- •Create dependencies between stories in same sprint
Tools
Lark
- •Use Lark Base for backlog management
- •Create story template with custom fields
- •Link stories to epics and sprints
- •Track story status and progress
Notion
- •Create user story database
- •Use kanban board for sprint planning
- •Link stories to requirements and test cases
- •Template for consistent story format
Common Patterns
E-commerce
- •As a customer, I want [shopping/checkout feature]
- •As an admin, I want [product/order management]
- •As a merchant, I want [analytics/reporting]
CRM
- •As a sales rep, I want [lead/opportunity management]
- •As a manager, I want [pipeline/forecasting]
- •As a marketer, I want [campaign/automation]
ERP
- •As a user, I want [process automation]
- •As an approver, I want [workflow management]
- •As an admin, I want [configuration/setup]
Mobile/Web
- •As a mobile user, I want [on-the-go features]
- •As a user, I want [responsive/accessible UI]
- •As a user, I want [offline capabilities]
Next Steps
After writing user stories:
- •Refine with team during backlog grooming
- •Create acceptance criteria (see
acceptance-criteriaskill) - •Estimate during planning poker
- •Break into technical tasks
- •Link to test cases for UAT
References
- •Mike Cohn - User Stories Applied
- •INVEST Criteria - Bill Wake
- •Agile Alliance - User Story Guidelines
- •Scrum Guide - Product Backlog Management