Do you know the 3 steps to completing a PBI?
The lifecycle of a PBI can be broken down into 3 steps:
- Take the next PBI that was approved by the Product Owner
- Is the PBI ready? Check your PBI against your Definition of Ready. "Ready" PBIs must have Acceptance Criteria. A good Definition of Ready also encourages a test-first mentality in requirements e.g. Use Spec Flow (Given, When, Then) and/or create Test Cases and Test Steps first.
- Attach and copy the Product Owner's email into the Acceptance Criteria (as per Do you attach and copy emails to the PBI?).
- Email notification to the Product Owner - use the @ mention rule
- Break down your PBI into tasks.
- Don't forget to make a task for testing! (So that it is visible in the task board). Note: You can also customize the kanban board by adding a new column for testing, but we recommend adding a testing task to the PBI instead.
- From the PBI, create a new branch (so that your work is automatically tagged to the PBI)
- On the Kanban Board, move your Task into "In Progress"
- Checkout your new branch and start coding!
- Code, code, code… (Red, Green, Refactor)
- Push your changes, open a Pull Request
- If you want feedback early, record a Done Video. E.g. Snagit
Is the PBI "Done"? Check your Definition of Done, and then:
- Open a Pull Request
- Get another engineer in your team to do an "over the shoulder" check of the code
- Use Microsoft's "Test and Feedback" Chrome extension to test the app
- Make changes based on feedback (and then get more feedback)
- Complete the Pull Request! Merge changes to master, this automatically deploys (to either Test, Staging or Prod based on process maturity)
- Email notification to the Product Owner – send a Done Email (reply to the original). Big items should have a Done Video
- Check the Acceptance Criteria for notes about email attachments (as per Do you attach emails to the PBI?).
Congrats. Your PBI is now ready to be demonstrated during your Sprint Review! (Note: This is also the same process you follow for a Bug work item)