Takin’ Care Of Business
Love them or hate them, ticketing systems like Jira or Asana are an essential part of modern software engineering. Misuse is rampant, but wielded well, ticketing systems align teams around common goals, unburden them from pointless status meetings, and unlock accelerated development with better accountability and fewer defects.
What are some ticketing best practices, you ask? I have thoughts:
- Work of any significance should be captured in a ticket. My rule of thumb is anything that takes longer than a few hours.
- Tickets are not a substitute for good requirements and design documentation. Instead they should capture specific tasks to be accomplished, including links to other docs as needed.
- Writing tickets is not only the responsibility of the team lead or product manager; a team should own its ticket board. If the current set of tickets does not match the reality of what is being worked on, make it so be rewriting, breaking up, and deleting tickets as appropriate.
- Being assigned a ticket is a form of promise. It says to the team “I will accomplish this task in this amount of time.” Each engineer should thoroughly understand all of the tickets assigned to them, proactively seeking out guidance if they don’t, and making clarifying edits as needed.
- Know how metrics such as velocity and completion dates are computed. Their value is only as good as the ticket data used to calculate them (garbage in, garbage out), so ensure values like story points are accurately tracked.
- Avoid Bricklin’s Law by embracing healthy use of a ticket system, and others won’t feel the need to add more status tracking. Done perfectly, it renders other status checkpoints redundant, maybe even those daily standups you dread.
- Finally, tickets are a means, not an end. Don’t lose sight of your ultimate goals. If your ticketing process isn’t helping you achieve those goals, change it.
The above list is far from exhaustive. Any other suggestions out there?
One Reply to “Takin’ Care Of Business”
Great post! I would add that educating other department (especially non-technical) on how ticketing systems work, and empowering them to use the systems, could be a huge win.
Even after many years of working for tech companies, I’m still never 100% confident on when and how to use a ticket/file an RFE. I always feel like I’m being a little intrusive in some well-oiled machine that someone else should be involved with.
Ultimately, with better understanding, I think ticketing could be utilized across all departments, not just engineering/development focused.