When there is work to do, we can simply go to the person we think should do it and say something like:
Hey, can you just make all the buttons purple?
Then walk away.
Chances are that the work won’t be done correctly and won’t be done at the time we need it doing. If the work is done at all, it’s likely we won’t get the result we want. Why are the results of such requests usually wrong?
- Is this the right person to fulfil the request?
- Did the person make a note of the request or forget it?
- Was the request from a valid person i.e. should we be the person making the request?
- Was the request a valid change request i.e. should the 2 people in this exchange make the decision to make these changes?
- Will anyone get into trouble making the changes?
- How much work has the person got to do before they can start this request?
- Is this request more important than other requests?
- Who says what is more important?
The above list contains some of the problems coming from the people involved, it does not list problems with the request, below are some of the problems with the request itself:
- What is the actual job e.g. ALL buttons across all sites or just 1 customer, what purple in HEX or RGB, are there other changes like outline, shadow, pill?
- Do we have any artwork/designs?
- When is the deadline for ‘on production’?
- Who is the request coming from e.g. CEO to manager to person or design team?
- Who is responsible for answering questions?
- Who needs to be notified before/after the work goes into production?
- Where does this request fit into the other work in the workflow, assuming 1 job at a time?
- Why are we doing this, is it an off the cuff remark, part of a rebrand or something else?
These are just a few questions that might come from the request, but if the person asking for the work and the person doing the work do not have a conversation then the task is guesswork.
Scrum & Agile & XP
While I’ll try not to use Scrum, Agile or Xtreme Programming for this article, I do take a lot from each of them. I’ll try to keep this about Tickets and what works, so some of these frameworks obviously help and I do take from them. As I do, I’ll try to link them up but there is so much cross over and change it’s sometimes difficult. I don’t use the Waterfall method too much, there is too much down time for everyone involved.
If you find this article interesting, I’d advise reading up on these frameworks.
Problem space
Let’s take all our issues with the way this 'request' was given and turn them into a list of things we want solve:
- Who want’s the work done (in scrum this is who is paying for the work). This person is responsible for questions and must be notified as the status changes.
- Show the work being done now.
- Show the work that needs to be done.
- Show importance of work (priority).
- Questionable definition i.e. Definition of the work that can be amended as questions arise and are answered.
- Extras added as needed like:
- why
- cost
- architectural diagram
- designs
- attachments
- Deadline: on production, not code complete or with the testers/QAs
There are a few solutions for this (sticky notes, group emails, tickets, etc.), but for a simple fix to all these problems (without adding more problems e.g. work blowing away) a ticketing system is the most simple and safest solution.
What Ticketing System to use?
For my work, both personal and for Huyton Web Services, I use Trello as it’s free (to a point) and has the functionality I need. However, the free version has become more restricted over recent years, and it has become a little bloated with functionality I do not want or need, so I may move to another system like Monday.com.
Lots of companies use Jira for its ticketing, and it is a great system, but is does much more than ticketing, it’s a full project management system, so can be a little daunting at first. I would suggest this Jira for all projects and all businesses if the business has the time to set it up correctly.
If emailing in tickets and getting them answered quickly is the most important to you, there are many options like HelpDesk or Zendesk, but these do not allow column views and boards to show who is working on what and importance in order, so won’t solve the problems we are looking to solve.
There are many ticketing systems, with many great features and it’s worth taking some time to compare systems and set up correctly. Also, some systems will do more than you think so it’s worth reading the documentation.
Now we know a little about the system to use to create tickets, let's look at who should create them.
What is a Product Owner?
The Product owner will take work from the different places it comes from and turn it into tasks that can be completed. They are the person the business and the people doing the work speak to, so the business shouldn’t need to speak directly to the people doing the work. A Product Owners responsibilities are:
- Maximizing product value
- Managing the product backlog
- Learning customer, business and market requirements
- Communicating Product Backlog Items
- Ensuring that the Product Backlog is transparent, visible and understood
In smaller companies the Product Owner maybe a leader or manager that takes the responsibility of the Product Owner, but the Product Owner should never be a Developer or Scrum Master. In larger companies a Product Owner is part of the Product team that has responsibility of all projects.
To find out more about what a Product Owner does, see the page about Product Owners.
How do we get work? The Product Owner, right?
This seems a strange question "How do we get work?", but it can be key to the system we need to implement. Do we have clients that speak to their contacts or do the bosses think up the next milestones pass it down? Are emails sent in that lead to new functionality and fixes, or does the team just develop and make things better. In scrum, the work can come in from anywhere, but it goes to one person (per project), the Product Owner, who writes the tickets. In larger companies there is a Product Team and of Product Owners that own all the projects.
We will take the approach all work is with the Product Owner and pretend emails are answered, functionality is filtered, and priority is delt with by the Product Owner (and their team in the background).
We have 1 person that takes in the work and passes it to the people to do the work, this can cause an issue when the Product Owner is not available, so they will need a second (usually part of the Product team) to quickly take over in an emergency.
Who works on tickets? Developers do!
In scrum, anyone who works on tickets is a developer, they develop something i.e. grow or change into a more advanced, larger, or stronger form which is what anyone working on tickets is doing.
From here on I will refer to anyone working on a ticket is a Developer, whether the project is writing a book as a team, building a house, or creating a web app.
Implementation
Implementing a ticketing system is quite simple and (can be) free but does require an agreement between the company that wants the work to happen and the people doing the work. This is simple on paper, but falls apart when the CEO or higher up manager speaks to a person with a “can you just” e.g.
Hey, can you just make all the buttons purple?
When a few managers realise they can get around the system like this, they will use this route and we will quickly find the ticketing system is not being used. So, the first rule of adding a ticketing system is:
All work goes through the ticketing system, no exceptions.
The CEO wants something, a customer requests a feature, a bug needs squashing, it all goes into the ticketing system.
Cards, Tickets & Stories; Oh my
We have a Product Owner writing tickets on our ticketing system, Trello, and Developers doing the work, we even have our first rule “All work goes through the ticketing system”, but we don’t have a definition of a ticket and we don’t know how cards and stories fit in yet. Let’s define these here:
Ticket
A ticket is for capturing, tracking, and managing tasks and can start as an idea with just a title or a suggestion that needs discussion. We can come back and add more information to the ticket as we have it. As the ticket is closer to being ready to do it should be more ‘fleshed out’ until it is ready.
Card
A card is simply another name for the ticket, in this case. In other cases they can be user interface parts that hold summary information about a product, person or something else. It easy to mix things up (which has happened in meetings I’ve took part in) so best to clear the definitions up in writing using a glossary.
Story
This is an agile approach to creating tickets which goes:
As <a user>, I want <feature>, so that <problem to solve, need> + Acceptance Criteria.
Here is our example as a story:
As a guest user, I want all buttons to look the same purple colour, so I understand I am on the same site and have not moved to another site.
A user is the person the feature is targeted at, the feature is what we need to do, the problem is what we will solve by completing the ticket, and acceptance criteria is anything we must do to complete the ticket.
In the case above guest user has not asked for this feature, someone in the company has. We have not done any UX type planning, so we do not know why, or even if, any user will want this. In reality, it should read something like:
As a design manager, I want all buttons to look the same purple colour, so we keep brand consistency.
Unfortunately, a design manager is not a user so the whole thing makes no sense if we write the story in this way. I don’t use this approach often because it is usually too contrived, but it can help write tickets quickly and simply and help the reader think about why we are doing the ticket.
Creating our first ticket
For our fist ticket we are going to look at our purple button problem and see if we can fix it, let’s look at a first draft from our new Product Owner:
change all the buttons to purple should take matt about an hour to just change the css file do it the same colour as the stupid hat bob had on in the smc party any questions see derek
This is no good and listed below are 10 reasons why:
- Has missing gramma, which can make the person writing the ticket look less intelligent and makes the ticket difficult to read.
- Does not give the actual colour other than a vague reference to a hat.
- Uses acronyms which can cause issues if the person doing the work thinks the acronym is different to the person writing the ticket.
- Mentions a name for questions, but no contact info.
- Passes the onus on to a third party, Derek (can be fine, we don't know).
- Calls out a team member in a bad light.
- Tells the developer how they should do the work with “just change the css” when the Product Owner is not doing the work.
- Gives a time scale to do the work when the Product Owner is not doing the work.
- Has missing information about the buttons - all buttons on what app, site or document? Open to interpretation that could cause the work to be completed incorrectly.
- Gives a specific name of a person to do the work.
The ticket above has lots of issues, let’s look at fixing these.
- Issue 1 is a simple fix, we add gramma.
- For issue 2 we ask the design team for the exact colour, with any other changes, and add that to the ticket along with any other attachments and images.
- CSS should be “Cascading Style Sheets” and SMC was the “Senior Management Christmas” party. Acronyms and Abbreviations should be avoided, this blog post from Louise Chapman really spells it out.
- Issue 4 & 5 “passing the buck” is a terrible idea for a Product Owner. All questions should go through the Product Owner to allow the developers to develop. If there is a good relationship or the third party (Derek) is in the meetings or part of the team, then that is a different matter. If we do want to question a 3rd party, then contact details should be given.
- Never add a person’s name in a bad light, this can be detrimental to a carer and as it is petty it can be the Product Owners carer that is affected so we will remove this.
- The ticket tells the developer they should change the CSS, this may or may not be correct as there are many buttons across the site. Chances are there will be more than just the CSS file to change. In fact, all the buttons need to be found first which may need QA help. The Product Owner is not doing the work so should not tell anyone how to do it. However, suggestions from the Product Owner (when sure) are acceptable.
- It is not up to the Product Owner to add time to a ticket. In this case the person doing the work has to find all the buttons across the site, including contact pages, forms, add to basket, etc, etc. then change them all. Depending on the site this could be days of work and without help some may be missed.
- Issue 9 has been fixed by the design team adding some extra information.
- Lastly, the Product Owner does not know who will do the work when they write the ticket. The person they expect to do the work may not be available due to other workload, holiday, or some other reason, or they may not be the best person to do the work.
Our second draft ticket looks like:
Problem: Buttons have several different styles across the site (pill, shadowed, etc.), this ticket is to bring them into brand.
Change all buttons across the site to purple #7b0085 with a 2px border and sharp corners. Space 10px between buttons if there are 2 together. See attached for more including button height with text over 1, 2 or 3 lines and mobile and desktop.
If there are any questions let the Product Owner know and I’ll go to the design dept.
However, we have lost the information on who does the ticket and how long the ticket may take which we'll look at below. There is also no Acceptance Criteria, let’s look at that next.
Acceptance Criteria or ACs
The acceptance criteria or ACs is a list we need to have completed to say the whole ticket is complete. Usually, it is as simple as the title, but there may be a few acceptance criteria to look at. It’s worth noting if there is more than one acceptance criteria it could be a sign the ticket needs breaking down to smaller tickets, but not always.
In our case, with our example ticket, we can add “AC: All buttons on the website are the correct style and colour”.
Assigning tickets, let’s not
Our example ticket is now ready to work on, and we can pass it to any of the developers to get it done. Or can we?
Being a good Product Owner, we probably know the best people to do this as different developers have different strengths. We probably know the who might have time and we should know what the most important work is but is giving the work to someone the best way to get it done? What if they have something that takes a while before they can start? What if they get sick? What happens if someone else has done something similar and knows the best route to complete the ticket. There are too many problems to list that might mean the ticket will be stuck waiting to start.
We may find other Developers than we expect are better placed to do complete the ticket. They could finish work faster than expected or are waiting for something outside their control and have no other work. Even the best Product Owner or Manager cannot know everything that will happen in the future.
Instead of passing work out to the developers, we could let them pick up the next ticket from the pile. For this to work we need 3 columns, Todo, Doing and Done. The Product Owner keeps the tickets in Todo in priority order and as developers complete work they simply pick up the next ticket, assign it to themselves and put it in Doing. They are only allowed to pick one ticket up at any time and if they can’t complete a ticket the comment on it as to why and put it back in Todo.
So, that is our second rule, each developer has only 1 ticket in the Doing column.
Once a ticket is complete, and in production, the last developer to work on it moves the Ticket to done and picks up the next ticket from the pile. This will be the next rule, a ticket is Done when it is in Production.
A Ticket is owned by the developer until it is in production, and it is their responsibility to get it there. Ops, QAs, etc., will all help a developer get the ticket into production, but it is the responsibility of the developer to get it live.
To the managers thinking this won’t work because the Developers won’t bother if they are not given work, you’ll be surprised when the productivity and moral go up.
Columns, Buckets & Status
This is a good time to mention the status of each ticket. Depending on the program we use or the person we speak to we may hear column, bucket, or status, but these are usually the same thing. I use the word column, because it’s very visible and easy to understand and difficult to confuse with and DB or cloud properties. Another rule, A ticket can only have 1 status and will only be in 1 column.
Tickets need to be in Priority order at all times with the ‘most ready’ Tickets at the top of any column, the least ready tickets are at the bottom. The tickets should also be in business priority order, but if a ticket is business priority but not ready it should be further down, Ready trumps business Priority as no one can complete a ticket if it’s not ready, no matter how urgent.
When I first start a project, I create a board for the project (1 board to 1 project) then 3 columns, Todo, Doing and Done, but there are many more columns we might add as we go along. Here are some I use:
Backlog, Product Backlog, Todo
Different names, same thing. Anything can go in here from ideas and suggestions to fully fleshed out tickets but the Ticket close to the top should be closer to being ready to work on while the Tickets at the bottom are pretty much place holders.
Sprint Backlog, Ready (a Todo column)
These are the tickets that are ready to be worked on. If we are not working in sprints the Product Owner simply keeps pulling from the Backlog to the Ready column as the tickets are ready, the Developers keep taking the top ticket from this column.
If we are working in sprints, then these are the tickets that have been agreed for this sprint. Usually the column is renamed with the sprint name or a new column created at the beginning of each sprint.
Doing, In Progress
The tickets that are being worked on. There should be no ticket in this column that is not assigned to the person working on it. There should not be any tickets in this column that are not being worked on. There should not be more than 1 ticket assigned to a Developer in this column. If a ticket is ‘blocked’ for any reason, then is it up to the Developer to unblock it or move it back to the Todo column.
With QA, Testing (a Doing column)
These are the tickets that have been developed and are ‘complete’, but now need to run through the Quality Assurance tests.
Having this column can cause major issues because it can cause problems with ownership and developers picking up new tickets. For example, if we say the person that first picked the Ticket up owns the ticket, they could be waiting for a QA / Tester for a while. Do they pick up a new ticket or wait?
If there are less QAs, then this column will fill up and cause a backlog.
The fix for this is to move all testing to the Developers in the Doing column including, Unit, Integration, End-to-End and automate as much as possible. Only basic Manual testing happens with the QAs / Testers so it’s quick and simple. The manual testing should be done with the developer, not as pair programming (driver/navigator won’t work), but as QA running through the tests, developer making notes on the comments of the ticket and could be fixing as they go or Developer takes the ticket back to complete fixes so they don’t hold up the QA / Tester.
Remember, a developer should not pick up another ticket until their ticket is live and in Production.
Production Ready (a Doing column)
These are tickets that are ready to go into production or live on the next scheduled release. If even 1 ticket is in here, a release should be scheduled. A developer should not pick up another ticket if they have a ticket that is production ready, but not in production.
Done
Once a ticket is in production it should be moved to done. At this point the developer still owns it so should not be un-assigned. This means if there is a problem with the ticket in the future the person that knows most about it can be traced.
Scrum Master
This would be a good time to mention the Scrum master. They have several responsibilities like:
- Facilitating stakeholder collaboration
- Facilitating meetings
- Removing obstacles
- Ensuring agile practices are followed
- Serving the product owner
- Serving the development team
Like a Product Owner, a Scrum Master may or may not work as a Scrum Master full time and may be a manager or a leader. However, Product Owner, Scrum Master and Developers MUST be different people because these roles have conflicting priorities.
When will the work start?
We have a Product Owner that takes work from the business and turns it into tickets, we have places we can put the tickets as work progresses with Columns and people to do the work with the Developers, but how do we get things moving?
If we choose Kanban, we can simply tell the Developers to take the tickets from the Ready column and work will simply keep going until all the work on the project is complete.
If we use Scrum, we have sprints with a start and end and as a team we tell the business how much we can do in that time through the Product Owner. A sprint can last any length of time but is usually 2 weeks.
Both types have issues, Kanban is more difficult for tracking productivity in the team and sprints mean more meetings. If there is a small project that a team is built around, then Kanban is probably best, but if we have more static teams that are fed projects one after another then sprints will probably work best.
Kanban works well at the beginning of a project, then a switch sprints and if there is a change or morale is low a change can help. I like to change as needed and listen to the team.
Points to Time
Wait a moment, we didn’t give the ticket a time, we gave it a number. Is that number hours? Days? Weeks?
The answer is none, it’s a number. It means nothing, but it will.
Take this example:
If I said you are 20 xnb tall, that means nothing to you, but if I say Bill is also 20 xnb tall you know he is the same hight as you, right? If you are 1.8m tall, then 20 xnb is about 1.8 meters and about 6ft. Now I say my desk is 18 xnb and it’s the same as yours, you know how tall 18 xnb is. The more I tell you about xnb the more you know about it as a size.
We do the same with points, 3 points means nothing, it is almost a random number. We could have picked 3000 or 0.23, it means nothing, but after the ticket is complete, we know how long, and how much work is involved in 3 points, and as we get more data, we know more about it.
We never say 3=2 days or 3=5 days or whatever, but we get a feel for how long any ticket takes.
It will take time, but our numbering system will start to make sense to the team and by saying there is about the same amount for work in this new ticket as that ticket we can guess time.
NB. Never compare teams with points. For example, if we said, “Team A only does 20 points a sprint, but Team B does double the work with 40 points”, that would be wrong. The teams may do the same amount of work or Team A may do more, points are only applicable to the team and if a person leaves or comes in the work to points may change. We could skew the results by saying “All Team A tickets will add a 0 to the points” so a 3 point ticket is now a 30 point, 5 is a 50 and suddenly Team A does 200 points per sprint.
Points may seem like a bad idea and time might seem correct, but what you actually find is the Tickets using time are completely wrong and predictions are wrong and tickets that use points, after a few weeks are quite accurate.
Meetings & Events
Most people dislike meetings, so the best way to keep people interested is to keep them short. Try to keep all meetings under an hour. Be inclusive, if part of the team is in the office, still conduct the meetings using webcams and headphones for everyone.
Meetings should be held at the same time/day as much as possible so there is consistency. Communication is the key to a successful team, so there must be meetings, or the project will not go to plan. Below are some of the meetings I use:
Standup, Camp Fire, Morning Prayers, Daily scrum
No matter what other meetings you have there should be a very quick meeting every morning of about 5 minutes, but never over 15 minutes. This meeting is for the Developers to quickly go over anything that is blocking their work, blockers. All Developers should also say what they are working on. No managers should speak, neither should the Product Owner and the Scrum Master should say very little but does control this meeting. This is not a meeting to solve problems, it is a meeting to air and record them, from these meetings there may need to be actions or follow up conversations for more information.
Planning, Sprint Planning
Set the sprint goal (if there is one) and the developers decide what tickets they can do in the sprint. Usually starts the sprint. This meeting is usually ran by the Scrum Master. If there are no sprints, then this meeting is not needed.
Refinement, Backlog refinement
This is where tickets are refined. The Developers can ask about tickets in a ready condition, the Product Owner can ask any questions about any tickets they are trying to get ready. To get a ticket into the ready state Developers and Product Owner must agree a Ticket is Ready. This happens in this meeting. This is also the meeting in which tickets are given a points values or time to completion. This is usually a long meeting, so should probably be split up over different days. This meeting is usually run by the Product owner.
Retrospective, Sprint Retrospective
Looking back over the sprint the Scrum Master with the team will assess the sprint, analyse achievements, and identify problems. There are lots of different apps to help with sprint retros, ScatterSpoke is quite good for this, but looking for a good tool is something the Scrum Master will want to do.
Sprint review, Review
This is a chance for the Developers to show what work they have completed to the people who have asked for it, Stakeholders. It is up to the Scrum Master and Product Owner to get the Stakeholders into the meeting and the Product Owner will manage the presentation, but not take part (they did not do the work). This is the meeting most Developers dread because speaking isn’t usually their forte, but after a few of these meetings they seem to enjoy showing the fruits of their labour.
This meeting is also a chance for Stakeholders to ask questions, so is a two-way communications meeting. It is also the chance to build a relationship between the people working on the project and the people who need the work doing. This is important.
If there are no sprints, it is worth still doing a review meeting at regular intervals.
Types of Ticket
Our ticket is almost ready, but we have 1 more thing we can add to help understand the Ticket, the Type. A Type might simply be a tag for quickly viewing or reporting on or it might change the fields on the ticket as we need different types of information per ticket, like different templates for different types. After much trial and error, I find it best to not add and remove fields for types because the Product Owners can end up giving the wrong type just because they need a field for a ticket.
There are a bunch of types we can give the ticket; some I’ve used are:
Epic
An Epic is an initiative or feature that needs breaking down. Product Owners can use these to work with developers to create task tickets. For example, a “Create API” ticket from the Architect might have all the information the API needs, but to create the API the developers will break it into Tasks. An Epic is never estimated by the Developers as they are always higher level.
Task, User Story, Improvement, Enhancement
This is the bread-and-butter ticket. A task is used for any task a Developer must do (unless it is Technical Debt or a bug) and should include documentation, testing and deployment. If any of these cannot be added to the task, then testing or deployment may be too complex and a less complex solution should be looked at.
Documentation
This is not a good ticket type, because all documentation should be done with the ticket, not separately. This type can be used when there is front facing documentation that must be done separately to tickets or documentation that is system wide. This ticket type should NOT be used to leave the documentation until after the ticket has gone to production.
Technical Debt, Tech Debt
The definition for technical debt can vary wildly and when not understood can cause much heated discussion so a definition should be written. In some cases, the cause is completing tickets quickly instead of ‘correctly’ and in some cases it could be duplicated code that should be refactored (code changes without functionality changes) or many other reasons for a refactor. In most situations, if you work with sprints there should be at least 1 Technical Debt ticket on each sprint.
The Article from Martin Fowler has a great description of Technical Debt.
These types of Tickets are usually written by the Developers and added to the backlog, then edited by the Product Owner with help from the Developer.
Research, Spike
This is the only ticket that I would argue needs a time limit. I usually say half, 1 or 2 days on these tickets. They can be set to 0 points and a note of the time agreed with the Developers and Product Owner or given a point number that corresponds best to the time. It’s usually used for a Proof Of Concept (POC) or comparing different options.
Another rule is the output for a Spike should always be a report.
QA, Testing
Use this ticket type when there are no changes, but there needs to be testing. This can be for a data change, automated update or 3rd party change. We need testing, but nothing is to be developed. This ticket type should NOT be used to leave the testing of the ticket until after it has gone to production as testing should be part of every task, whatever testing has been agreed.
Release, Deployment
This is not a good ticket type, because all tickets should be released. I have used it in the past when there where a bunch of tickets that didn’t get released or code needed a number of 3rd parties and department heads present. Today, I would argue this ticket type is redundant and would be part of a task.
Bug, Defect, Issue, Fix
The definition of a bug can vary wildly, so I like to use the type “Bug / Issue / Fix” when I create this type. This way the business and developers can understand this type and there is no room for argument. We use this type of ticket when something unexpected happens.
Unfortunately, these types cannot be estimated as there is usually no knowing how much work there is. To solve this problem, we can either give a 0 points and time-box, similar to a Spike or we can give this type a point value (e.g. 2) and it should average out over time.
Dates
The last part of putting a ticket together is the dates. There may be an “Expiry” date e.g. adding a banner for a Halloween sale is useless after Halloween. There may be a “Switch on” date so the Ticket must be complete before that but left switched off (feature switches or A/B testing) e.g. Black Friday sale or a “Due” date so the Ticket must be complete before that e.g. a client needs it for that date, but it can go live before.
If any dates are given, we must add them to the ticket with a descriptor for the date and a reason (if we have it) e.g. If we are given the 5th of November for the switch on date for the Halloween sale it is likely someone will pick up on the mistake, but if we give no reason for the date, then no one can pick up on the mistake.
Finished Example ticket
I've added the finished example ticket below, we can add the type as a Label in Trello, with our Columns ready to move the ticket across. We can add Story points via a Power-up and Our ACs can be added as checklists.
Problem: Buttons have several different styles across the site (pill, shadowed, etc.), this ticket is to bring them into brand.
Solution:
Change all buttons across the site to purple #7b0085 with a 2px border and sharp corners. Space 10px between buttons if there are 2 together. See attached for more including button height with text over 1, 2 or 3 lines and mobile and desktop.
If there are any questions let the Product Owner know and I’ll go to the design dept.
Type: Task
AC: All buttons on the website are the correct style and purple.
Points: 3
Rules
- All work goes through the ticketing system.
- Each developer has only 1 ticket in the Doing column/s.
- A ticket is Done when it is in Production.
- A ticket can only have 1 status and will only be in 1 column.
- Developers and Product Owner must agree a Ticket is Ready.
- A ticket must have a description, point/time, and a type before it is Ready.
- To be complete a Ticket must have passed all agreed tests.
- The output for a Spike should always be a report.
Summary
Work comes in through the business, a ticket is created with a type by the Product Owner and added to the backlog. The ticket is discussed with the team and split/changed as needed, then given points/time. When ready the ticket is worked on (when on sprint if we work that way) by a developer, tested, and released to live. Once the ticket is on production and live then the ticket is moved to done.
And that’s it for tickets, good luck creating and working on them in the future. If you have any stories on tickets, good or bad, then please comment.
For more information, clarification, or if I’ve made a mistake let me know in the comments or contact us.