Skip to end of metadata
Go to start of metadata

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

Version 1 Next »

Because Kanban focuses on visualising the steps in the workflow, highlighting work in progress and optimising throughput between steps in the workflow, it is important that everyone is clear about two things:

  1. how we define when something is fit to be pulled from one step in the workflow to the next;

  2. how we respond as a team to common day-to-day scenarios.

One tool for achieving this is defining ‘policies’ as reference points for both the above. These are designed to be organic (like the Definition of Done that we’re already familiar with).

Following the team workshop around these policies, I’ve set them out here as a draft for you all to review, comment on/modify.

Policy

Workflow step / scenario

Description

  1. Ordered backlog

  2. Size of backlog

Backlog

  1. Everything should be ordered - product-development and tech improvement tickets. As a team we need to align these two sides of the backlog wherever possible (Refinement meetings, Planning ones and Stand ups)

  2. The Backlog should contain detailed tickets enough for the team to work on for the next 3-6 iteration, maximum. Our current velocity is c.13 tickets / iteration. Therefore the Backlog should be between 39-78 tickets. It’s currently 863. It needs radical pruning (for duplicate tickets, placeholder tickets, old tickets that we ‘thought we might work on at some point’ but that will actually never get prioritised)

  1. Shared understanding of the ticket

  2. Clarity on when something is a ticket, when it is a Sub-task and when it should be an Acceptance Criteria

  3. Include uncertainty and positivity bias elements when estimating

  4. Focus on small vertical slices (no more mega-tickets)

  5. Small enough for rapid throughout, big enough for collaboration

Refinement

  1. For a ticket to be flagged as Refined, requires it to be detailed enough that anyone in the team could lead on working on the ticket

  2. A ticket needs to meet INVEST criteria.
    Acceptance Criteria should be a list of statements that can be turned into tests to determine whether the ticket is complete.
    Sub-tasks should focus on how to split the ticket into pieces that enable collaboration.
    ”Good stories involve multiple people. Each subtask only involves one person.”

  3. Some degree of uncertainty is acceptable in a Refined ticket. But where that uncertainty is too great, create a SPIKE ticket(s) to get sufficient confirmation to proceed. Indicate elements to investigate early in a ticket

  4. Vertical slicing can be hard to do. It can take some thought and even lateral thinking. Consider this framework for how to vertically slice work, if you can think of nothing obvious.

  5. Agile working with Kanban is about finding a happy balance between tickets that are small enough to move through the steps in the workflow rapidly, but that also encourage (require?) collaboration between team mates with different perspectives

  1. Anyone can pick the ticket up and make a start

  2. Clear, testable Acceptance Criteria

  3. Appropriately Sub-tasked

  4. Flagged as Refined

Ready for Development

  1. Essentially, has the ticket been Refined correctly

  2. Allow time at the start to enable a TDD approach to development - as a team we have committed to TDD by default

  3. Write Sub-tasks specifically to encourage collaboration (and get multiple perspectives on the ticket from the start - to avoid siloed working and the natural assumptions that are made when working in that way)

  4. Check that the ticket has been Refined - it should have been flagged, and appear as a yellow ticket with a red flag on it on the Kanban board

  1. How will we test this has added value for the customer

  2. Timely documentation

  3. #Terraformfirst

  4. Considered for ‘exception’ monitoring

  5. Avoid scope creep

  6. Leave Slack for #fire-fire

Implementing

  1. As well as TDD as a coding approach, also consider how the ticket will be tested to confirm it is adding value to the customer at the end of development

  2. Consider at what point to start, contribute to and complete associated documentation (might be easier to do some as you go through, rather than as a task at the end of development)

  3. #Terraformlast is hard, and when collaborating on a ticket, will often result in issues before you get round to it

  4. Does this work require specific monitoring (and logging)

  5. Notify POs / highlight in Stand up when adding >1 Sub-task after Refinement

  6. [ Joseph (Pepe) Kelly - did you mean that fire-fire tickets should go straight to Documenting, and the resolution of them should be handled in the dedicated fire-fire channel for that specific incident? ]

  1. Clear breakdown of what’s been done and why

  2. If you merge it, you own it too (who checks the pipeline?)

  3. Do not amend and force push after comments have been added

  4. Use the PR as a record of discussions

  5. Respect the reviewers

PR

  1. Often useful to restate the problem, and describe the solution developed

  2. Tickets should normally be written in a way that ensures collaboration, so as a team we need to appreciate everyone involved in contributing to the ticket ‘owns’ that code. By default, anyone approving a PR should therefore merge the code. Recent developments enable flagging a PR for auto-merging on approval, which is an option to consider vs using the approach of creating a draft PR

  3. Comments are left as a proxy for a two-way constructive conversation. Respond with gratitude for the comment, or justification for your approach. And request confirmation, review, merging

  4. Discussions on a ticket often happen on a Slack chat or a Slack/Teams call. Make sure these are included, linked, summarised on the PR, for a full version history

  5. Reviewing code shouldn’t be regarded as a tick-box exercise. You should be encouraging reviewers to properly review the code, not just sign it off. By aware that when you necessarily have to submit a PR of >500 lines, you are asking a colleague for a potentially significant investment of time/effort.

  1. Check all amended services are up and working

  2. All E2E tests passed

  3. Independent verification

  4. Manual check

Verifying on Stage

  1. Use Prometheus by way of systematic review that the services touched on by the PR are all up and working

  2. Don’t ignore E2E test errors

  3. Early in the Implementation step, ask a colleague to be ready to do the verification - so they are already aware of the work ahead of time

  4. Log into the Stage app and manually check the changes have worked as anticipated and not broken anything obvious

  1. Add a how to for testing

  2. Independent verification

  3. Review customer value added

  4. Manual check

Verifying on Prod

  1. Where testing the new code is not obvious, help out the verifier by adding a how to (e.g. need to push specific job into Lambda, attach test materials, etc)

  2. As for Verifying on Stage, request a different team member carries out verification on Prod

  3. Final opportunity to recheck the value added from the customer perspective (of course, this should have already been considered at Refinement and PR at least, if not all the way through the dev process)

  4. Log into the Prod app and manually check the changes have worked as anticipated and not broken anything obvious - this may be more difficult in the Live environment

  1. Ensure the affected repo’s READ.ME file(s) are up to date

  2. Ensure the Dev handbook is up to date

  3. Add to the Review page on Confluence

Documenting

  1. This may have already happened, during Implementation

  2. Has anything you’ve done necessitated an update to the Dev handbook and was this done during Implementation, or is it outstanding?

  3. Tickets by default will normally be ones where we will want to present our work at Review for feedback. Ensure we’re clear how to walk stakeholders through what’s been done, what feedback we’re looking for and any questions we want to ask stakeholders in terms of advising us on next steps

  1. Check DoD if unsure

  2. Check Review page is complete

Done

  1. See https://hee-tis.atlassian.net/wiki/spaces/NTCS/pages/1286635576/Definition+s+of+Done and

  2. 2021 Reviews

  1. Who, how and where

Creating a ticket

  1. Anyone, as a result of having a 3 amigos conversation as a minimum. Remember a Jira ticket is the result of the 3 Cs process - card, conversation, confirmation

  1. Who and how

Prioritisation

  1. PO Group for Product development tickets.
    Tech leads (and dev team) for Tech improvement tickets.
    Combine the two ‘buckets’ at Refinement and Planning when feasible

  1. Who, how and where

Tech improvement

  1. Periodic reviews of the Tech improvement spreadsheet.
    Periodic feeding in of top items to the Trello roadmap.
    Periodic feeding in of current items to Jira Backlog.

  1. Pull system, not push

Kanban board mechanics

  1. Kanban is a PULL model, whereas Scrum is a PUSH model. This means tickets should only transition between steps in the workflow at the point that team members are going to work on them in the new step, not pushed to the next step in the workflow when a team member has finished with them in the previous step.
    eg. a ticket is moved from PR to Verifying in Stage when a team member has approved and merged the PR and is going to start Verifying in Stage.

*a SPIKE ticket is a time-boxed (usually a few hours only) piece of work to research an element of uncertainty around the Refinement of a ticket. Eg. what software could we use to achieve the goal of the ticket, will a certain approach work with the infrastructure we have in place or will we need to modify that as part of the ticket, what is the simplest thing we can program that will convince us we are on the right track?

The term ‘Spike’ is believed to have originated in rock-climbing, where the act of driving a spike into the rock does nothing to your progress to the top, other than to anchor you on the path and enable future climbing.

  • No labels

0 Comments

You are not logged in. Any changes you make will be marked as anonymous. You may want to Log In if you already have an account.