Skip to content

πŸš€ A rough guide for people working with InFact as Product Owners

Notifications You must be signed in to change notification settings

InFact-coop/product-owner-guide

Β 
Β 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

76 Commits
Β 
Β 

Repository files navigation

Product Owner Guide

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.

Contents

What is a Product Owner?

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:

  1. Owner and creator of the product backlog πŸ‘‘
  2. Adding new features to the backlog. πŸ†•
  3. 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) πŸ“
  4. Clearly define, understand and empathise with the end-user πŸ‘© πŸ’‘
  5. Approving or critiquing development work for release. βœ…
  6. Involving customers or users and getting their feedback to continuously shape the product development πŸ‘ πŸ‘Ž
  7. Maintaining and updating the backlog: adjusting the features and priority as needed after each sprint or iteration. πŸ”Ί πŸ”»
  8. 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 πŸ’Έ
  9. Have a clear picture of "competitors" and the "market" for similar products/service to avoid "re-inventing" something that already exists! πŸ”
  10. Be familiar with existing UX/UI through personal use of other/existing apps/services to know what can be done/re-used ♻️
  11. 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) πŸ‘Š
  12. 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 πŸ’ͺ

Glossary of Key Terms

  • 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

What is the backlog?

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.

Where can I find the backlog?

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'.

Why github when we could use trello / basecamp / <-insert-other-site-here->?

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. πŸ“§

Product Owners should create issues rather than Infacsters

Why?

  • 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.

Template for making an issue

The 3 components you should include when creating an issue are:

  1. A User story
  2. Acceptance Criteria
  3. 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.

User Stories

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

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 screenshot or mock up of a new design

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."

Real world exemplar issue

The following issue has a clearly defined user story and detailed acceptance criteria:

image

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.

What are priority labels?

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.

The lifecycle of an issue

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'.

When to create a new issue when dealing with bugs πŸ› and enhancements πŸŽ€

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.

Why?

  • 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:

image

So what changes count as bugs πŸ› then?

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?"

What is a staging area/site and what is it used for?

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.

image

Responsiveness standards for testing

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.

How to test using standard device sizes

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:

image

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:

image

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:

image

Timing demos and deployments

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.

What is Technical Debt?

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.

How do I know what's happening on a project?

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.

image

About

πŸš€ A rough guide for people working with InFact as Product Owners

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published