This guide is borrowed and built on the guide created by our friends @dwyl, thanks so much for sharing :)
A rough guide for those who are product owners on an InFact project.
- What is a Product Owner?
- Glossary of Key Terms
- What is the backlog?
- Product Owners should create issues rather than infacsters
- Template for making an issue
- What are priority labels?
- The lifecycle of an issue
- When to create a new issue when dealing with bugs and enhancements
- What is a staging area/site and what is it used for?
- Responsiveness standards for testing
- Timing demos and deployments
- What is technical debt?
- Optimal Team Size - Brooks' Law
- How do I know what's happening on a project?
A Product Owner (PO) is someone who represents the views and needs of the target audience, stakeholders and the business they represent in agile scrum methodology. They must understand and communicate the vision of the product to the rest of the team.
They are the liaison between customers and us. This means that they are responsible for working with stakeholders and user groups to determine their needs. Then through collaboration with our team they prioritise and discuss these ideas moulding them into features to be built.
PO Responsibilities:
- Owner and creator of the product backlog π
- Adding new features to the backlog. π
- Describing the user-persona(s) in as much detail as possible to make the "pain" they feel real (especially useful when the team is remote and don't often meet with the end-users) π
- Clearly define, understand and empathise with the end-user π© π‘
- Approving or critiquing development work for release. β
- Involving customers or users and getting their feedback to continuously shape the product development π π
- Maintaining and updating the backlog: adjusting the features and priority as needed after each sprint or iteration. πΊ π»
- Attach a business or customer value to each story/task in the backlog to ensure that we are building features that are genuinely wanted/needed by users πΈ
- Have a clear picture of "competitors" and the "market" for similar products/service to avoid "re-inventing" something that already exists! π
- Be familiar with existing UX/UI through personal use of other/existing apps/services to know what can be done/re-used β»οΈ
- Trust the expertise of your technical team on matters of technical importance (although feel free to ask questions to learn more about why certain things matter when you may not be familiar with them) π
- Note, in order to be able to perform these responsibilities it's important that POs have been given the authority and means necessary to complete them πͺ
- Product backlog: a prioritised features / to do list for the product found on github. See our 'What is the backlog?' section for more detail.
- Milestone: a visual way to group issues in GitHub
- Sprint milestone: the to-do list that we aim to complete within the given sprint period.
- Sprint: a 1-3 week working lifecycle of planning, building, presentation and reflection. We tend to work in 2 week (10 working day) sprints, but schedule them for 12 days to allow time for agency work.
- UI / User Interface: how the site looks from a design perspective.
- User testing: interviews, focus groups and other forms of research conducted with potential/actual users of your product to give feedback and provide insight into what the user's needs are.
- To see definitions on the Sprint Ceremonies such as stand ups, sprint demos, retrospectives and sprint planning go to: https://github.com/infact-coop/process-handbook/#ceremonies
The backlog is your project's to do list, a list of all the features and things that need doing. This list contains not only the things that you're planning imminently but also ideas you want to discuss in the future or feature requests that are yet to be validated. As not all of the issues in the backlog are ready to work on we use labels to indicate things like priority or whether something is blocking an issue from being worked on. With the labels as a visual cue you can scan the backlog and get a flavour for what's important on the project at present.
In order to keep track of progress on a project we use github, see https://github.com/dwyl/github-reference to learn more about using Github. To see the backlog click on the 'issues' tab at the top of your project.
This will display a list of all of the individual things to do in your project. Something which needs doing on github is called an 'issue'.
We use github because unlike other platforms it acts as a single source of truth πΌ. What does this mean? It means that github is the one place where the whole team can see the status of the project at a given time.
To keep github as the single source of truth, we ask that (non-confidential) communication regarding the product is also carried out on github, rather than in emails. π§
- As owner of the backlog the PO should know what's in it and how it's been outlined.
- It ensures the team and PO are on the same page. The PO should describe what their imagining of the issue is in their own words. Had another team member written it assumptions or misinterpretations could be made. When it's in the PO's words the team can talk through these in the sprint planning to discuss any areas that don't feel clear.
- Helps you to get familiar with Github and in the practice of using it. Practice will make perfect, you'll see what kinds of questions the team may ask you which will help you realise how you can improve your issue descriptions.
The 3 components you should include when creating an issue are:
- A User story
- Acceptance Criteria
- A screenshot of a mock-up or a bug on the site (where possible)
Followed by... any other useful/ relevant information for completing the issue.
A user story is a phrase which describes the what (you want to do), the who (the issue is for) and the why (this should be done). To write one, complete the following three starters:
As... a team member (WHO)
I want to... see a user story on every issue I read (WHAT)
so that... I know the context in which the issue is set to help me understand
it better (WHY)
Here's another example:
As someone in need of a new bin
I want to be able to filter on the online shopping site by 'lid type'
So that I can find a bin that closes securely to stop mice getting into my
bin π β π π§
Acceptance criteria are checkboxes that a developer knows they need to complete before that issue can be considered 'done'. They are the points against which the issue will be tested.
A picture which illustrates what the issue should be creating or a screenshot of an existing page showing where a bug is occurring. Remember to include mock ups of both mobile and desktop views for new designs. Give as much contextual detail as possible for bugs e.g. "occurs on iPhone 8 and chrome on desktop - see screenshots."
The following issue has a clearly defined user story and detailed acceptance criteria:
This issue doesn't have mock-ups/screenshots but note that the second checkbox says the delete button should follow existing conventions set out in the style guide.
We have 5 priority labels. Issues are worked on in priority order from 1 down to
5. priority-1
is reserved for emergency use e.g. the live site crashing. In most
situations when there are no open priority-1
issues, priority-2
issues are
therefore the first ones to be worked on. Whilst at the other end of the scale
a priority-5
could be used for an idea for a new feature that's not been fully
outlined yet.
At InFact we use github labels to help indicate the type, duration and status of an issue. The following image outlines the lifecycle of an issue using labels. In this example there are 3 actors, the Product Owner (PO), the dev team (Scrum Master and developers) and in this case the developer who has completed the issue: 'Cleop'.
An existing issue is labelled please-test
when the team have finished working on
it and all of the acceptance criteria have been fulfilled. You, the product
owner, test the issue and on reflection you decide that you think the designs
would look better with a couple of tweaks - maybe removing the bold on the
title, making the logo a bit bigger and changing the copy by a few words. What
do you do in this situation?
These changes might relate to the changes made in the issue but if they are fundamentally not what you asked for in the first place or not what was shown on the mock-up then they belong in a new issue NOT as a 'bug' or as a request at the bottom of the existing issue. Small as they seem, these issues are enhancements and new scope and they should be dealt with separately.
- These kinds of small changes add up, especially if you change your mind a couple of times or if there are a few across multiple issues.
- The title of the issue may no longer reflect the content inside making it more complicated for people to follow the chains of conversations.
- The extra changes will impact the developer's initial time estimate which is damaging for their accuracy when trying to estimate how long issues will take.
- The extra scope may push something else out of the sprint. Had you prioritised the changes as a new issue you may not have put this tweak above the other issues in the sprint.
Here's an example where a new issue should have been made:
Bugs are places where the acceptance criteria has not been met β
e.g. "You were meant to change the font size across all titles on this page but you missed out the last title - please can you change it?"
e.g. "I submitted the form but I didn't receive an email notification as specified in the acceptance criteria. Please can you fix whatever is stopping the email from being sent?"
A staging site is a replica of your live (aka production) website. It is used as a first stage for testing when you deploy new code / features. It acts as a testing ground so that errors can be caught and fixed before finally deploying and updating the live site. Your staging site is meant for internal not public use.
When you begin a project it is likely you will discuss target audience and device compatibility. These conversations will cover the important behaviours of your customers including browser type, device type and any other specific compatibility requirements e.g. accessibility.
Generally speaking most projects will focus on being mobile, tablet and desktop friendly and for these measures we use the inbuilt device sizes provided by browsers to test the application. These devices sizes cover a range of dimensions and a variety of the most popular iOS and android devices. Testing using these devices is not only capturing a large part of the user market but it is also a shared metric and easy way to spot and communicate bugs across a team.
E.g. 'The subheading on the landing page is currently obscured on iPhone 6' gives the development team a quickly understandable and recognisable way of finding and fixing a given problem.
To open 'Inspect' right click on your computer with your browser open or if you are a mac user press control and then click. This menu should appear, then click on 'Inspect':
Now your browser has 'Inspect' or 'Dev tools' open you should make sure you are using the device mode. Look for this symbol in the menu:
If the symbol is orange then you're already in device mode. If it is not, then click on it so it turns orange. Next, look for this bar and click on the left-hand dropdown menu to select a device:
This list is an automatically updated list contained within your browser. It contains the most popular standard devices sizes for you to test your site against.
Your page will now display according to the dimensions of the device you have selected: E.g. iPhone 7:
iPad:
So if you come across a bug π remember to include lots of detail to help your team replicate it. Think:
- What pathway did I take to get to the error? ie. who was I logged in as? :busts_in_silhouette: what was I trying to do when it happened?
- What device or browser was I using? π±π» e.g. Internet Explorer v10 or iPhone 8 view.
Then take a screenshot of the bug and put it all into an issue to be fixed :wrench: :sparkles:.
Here is an example of an issue that contains a description of the bug, the critical steps required to reproduce it and which devices it was experienced on:
We liaise with the PO to find a time and day suitable for sprint demos and deployments. We do however recommend the following on all occasions:
- Don't deploy on a Friday, if anything breaks it may not be discovered until after the weekend or may need working on over the weekend.
- To avoid bugs disrupting sprint demos the team will demo the work they completed up until a few hours before the demo. If you continue deploying to staging up until the demo you drastically increase the likelihood of a last minute rush or a semi-complete feature causing a bug and disrupting the demo.
For these reasons it is important that we set up demos in advance so all of these factors can be taken into consideration.
Technical debt is the cost to "re-work" a feature (or entire app) because it was rushed the first time it was built.
Think of Technical Debt like a "loan shark" for your project, if you take "shortcuts" to implement a feature quickly (e.g. by skipping tests) you will pay for it later and usually with "interest".
It may feel abstract and hard to understand but it is crucially not to ignore.
In other words, whilst in agile methodology we often talk about iterative growth and only building what is necessary, this should not mean that corners are cut in the short term. This will inevitably end up with greater costs of time and resources later down the line.
If technical debt does accrue it is worth reducing it systematically. If left ignored, as other development continues, the debt will grow as the new work added will also need reworking when the debt is finally addressed. Just like how financial debt grows when untouched because of interest.
Note: this is related but distinct to retrospective changes that can be made to a project to make it more performant/relevant/consistent but that could not have been known/foreseen at the time the code was written.
This illustration is a guide for POs who want to know the status of their project at any given time. See the glossary if you need reminding what some of the key terms mean.