Mistakes are inevitable. We’re only human, after all. But when it comes to delivering software or websites to our clients, we want to make that happen with as few errors as possible. It sounds like a great goal, but how do you systematically achieve it?
The key to minimizing errors is to design a quality assurance process that is efficient and reliable. In this article, I discuss exactly how to do that, whether your company is big or small or a one (wo)man show.
Every step should be designed with that simple point in mind, that we are in fact only human. Even the most detail-oriented person will be more effective with a clear and consistent system than relying on their skill alone.
The Right Person for the Job
The first challenge in establishing a proper QA routine is picking who will perform the quality assurance reviews. If mistakes were easy to notice in our own work, we would just fix them ourselves. Since that’s not easy to do, it’s best to have a pair of fresh eyes checking the project.
If your company has enough capacity, the best option is to hire a QA specialist. Naturally, they won’t have the problem of being so involved in the project that they overlook issues. Moreover, a specialist will typically become faster and better at their task than someone who just reviews for errors occasionally.
But if you’re a small agency, hiring a QA specialist is not always possible. Our own company only created the role in the past year, as we transitioned from two dozen to over 50 employees. You can still keep the principle of “fresh eyes” in a smaller organization by having developers or team leaders check other developers’ work.
What about if you are freelancing? In this case, the most effective solution is to build in a couple of days into your timeline that you can put a project aside before a review. Work on something else for a little while. Then, when you come back, you will have a more objective eye for the work.
Writing a Checklist
Checklists save lives, literally. Hospitals and airlines are examples of areas where checklists have proved absolutely indispensable.
Obviously, the stakes are not life or death when it comes to websites. But the principle is still the same: checklists work because humans are not good at remembering a long list of tasks with 100% accuracy.
How you write your checklist depends on what kind of work you do. If your projects are relatively standardized, like building websites, it will be useful to make a QA checklist template. This template should cover the elements that should be reviewed for correctness for every project.
The more specific and concrete the checklists are, the better. In our case, our QA specialists focus on both visual and functional accuracy. To give an example of how concrete a checklist should be, our checklist for functionality includes the following points:
- A logo should be linked to the Home page (Check behaviour when you hover over the link)
- All external links should have target=”_blank”
- Click all elements on the site (all buttons, all forms) and make sure that all clickable elements have the correct behaviour
- For any form:
- Try to send an empty form and make sure that text of errors is readable and have the same style as other pages on the site
- Make sure proper recipient is emailed, the FROM address and SUBJECT lines are correct per directions and the user is brought to a confirmation page (Thank you page) if applicable
- Check search functionality and formatting of search results
If you work on software development, most projects may have common elements but also some aspects that are unique to each one. You can still start with a template, but to account for the unique features it may be useful to write up additional items to check based on the project description, before starting development.
Setting Up the Workflow
Now you have the basic ingredients: your quality assurance reviewer and a checklist of issues to look out for. How you put them together and build your workflow is key.
Whatever tools or system you decide to use, it needs to fulfil two features:
- Centralizing the checklists and additional tasks to be done so they are visible in one place. See again: humans being bad at remembering long lists of tasks.
- Distinguishing who has responsibility for moving the project to the next stage. This keeps the project on track when everyone is juggling multiple projects at once.
We use Trello in combination with Usersnap to do this. We start with a template in Trello, where lists indicate who is in charge of a particular stage of the workflow.
We use one board for the internal QA process, which only involves the developer and the QA specialist. We use a second board to process the external feedback from the client. This board incorporates the account manager and the client themselves in addition to the QA specialist and developer.
The templates also have standardized checklists built-in for all participants as needed. This setup can easily be adapted given the individuals you choose to include as part of your process.
As the QA specialist goes through their list, they add cards as needed to the developer’s list to indicate issues to be addressed. The Trello integration with Usersnap makes this process even simpler by directly adding cards to Trello when the reviewer gives feedback. It also includes additional useful information for the developer, like what browser and type of device is being used.
Whether you use Trello or another task manager, this combination of visually tracking who should be working through their part of the process and exactly what they have done will let you scale up and still keep errors down.
We’ve talked about how to set up a QA workflow so you can minimize errors in projects before delivering them to clients for external feedback. But what can be done to decrease the number of bugs that get to the internal QA stage, much less to the client?
Sometimes (though not always) there are patterns of issues that pop up. To identify these patterns, you need to collect metrics. This could involve assigning the QA specialist in your organization to categorize the types of issues that come up as they are identified. Such information can then be aggregated about a given developer to provide continuous feedback for improvement.
There’s a big caveat about collecting comprehensive metrics like this: on a small scale, it’s often not worth it.
Collecting and organizing information for metrics is time-consuming. While it could help improve the process, the improvement may not be worth the investment of time. It usually only pays off in very large-scale processes, when a small improvement provides benefits many times over.
For example, even with several dozen employees, in our company, we are only just beginning to discuss future implementation of metrics on the feedback and QA process. Even so, our initial plans will be to give a general metric on quality, by tracking whether client feedback identifies bugs or additional “out of scope” requests, rather than giving detailed analyses of patterns of issues.
It’s not always possible to do everything at once when you want to improve the quality of your company’s work. By breaking it down, you can focus on tackling one step at a time to achieve improvement:
- Reviewing projects for quality with “fresh eyes”
- Writing thorough and detailed checklists
- Setting up a workflow that centralizes to-dos and distinguishes responsibilities
- Incorporating continuous improvement metrics where possible
The above are concrete steps you can take build an effective quality assurance process, which starts from recognizing how mistakes creep into the process.
What tools or systems does your team use to optimize the quality assurance process? Share your tips with us in the comments!
About the author:
Bobby King is the Chief Operations Officer of The White Label Agency. He has managed the production of 2500+ websites over the past 3 years.
About The White Label Agency:
The White Label Agency is a B2B partner helping marketing agencies, web agencies, and digital agencies build custom WordPress websites for their clients. Our partners create the designs, and we do the coding as their invisible back office.
7 most important bug reporting skills every QA agent should have
A while ago, someone asked me: ”Thomas, what skills do I need to have when tracking bugs and joining a QA team?” I was astonished by the question and more importantly, quite disappointed that I wasn’t able to come up with a great answer. But it made me think. And it pushed me to do…
Fundamentals on setting up your bug reporting workflow
With all these emerging new devices – from mobile devices, to wearables, to VR, to smart devices – having a proper bug reporting workflow in place becomes quite a challenge. Building web applications in particular might seem quite painful due to the different screen sizes of the used devices. It can even be worse than…
Agile: The Right Way to Build Innovative Digital Products
Agile, both as a methodology and a mindset, can accelerate growth by increasing quality and speed to market. In addition, it can dramatically improve workflows. But what about innovation? Can agile methods foster innovation as well? Company-wide adoption is recommended for taking full advantage of this way of building digital products. Basically, everyone from developers…
Timeless Design Feedback Systems (+ Free Design Feedback Checklist)
Imagine this. The web designer of your team has spent the last week working on design drafts for a new website of yours. She perfectly highlighted user stories and designed all possible user interactions on that particular site. She presents the design drafts and user stories to the team. And her design presentation ends with…
10 mistakes to avoid when tracking bugs. A glimpse into the world of bug tracking.
Errors happen during the entire web development cycle. And that’s perfectly normal. No matter how hard a team tries, errors creep into projects. But this means that there is always room for improvement. You’ll find hundreds of lists out there talking about mistakes that can be avoided during web development projects. However, most of these…
What is Software Testing?
Your software application is acting weird: it’s crashing during quality analysis and the front-end application isn’t working as expected! You need a software testing team to figure out the problem areas of your application. The testing team finds and reports bugs to the developers. The testers just saved the project team from a nightmare! That’s…