Buggy, underperforming solutions rarely delight users or drive business outcomes. High-quality products are what we strive for.
In this guide, we’ll explain what quality assurance (QA) means, describe why it is distinct from testing, and outline the the role QA specialists play in the software development lifecycle.
The process of ensuring product quality is called quality assurance (QA).
Some make the mistake of simplifying quality assurance into just testing, but there’s so much more to it. The actual testing phase is a drop in the ocean within the quality assurance discipline.
Quality assurance isn’t the same thing as testing — a true QA specialist is more than just a tester. Testing is a small part of a broader discipline:
Simplifying a bit:
Ultimately, a QA is responsible for ensuring the quality of the end product, which requires much more than manual testing.
The most common misconception about quality assurance is that it’s an activity done at the end of the development lifecycle. This misunderstanding originates from a waterfall development model:
However, quality assurance is not left at the end, even in the waterfall model. Although feature testing is one of the last steps, it doesn’t mean the whole quality assurance is non-existent until then. It’s prevalent in every single phase:
Quality assurance includes ensuring the analysis group is built adequately and consists of the right people from the onset. QA specialists do whatever they can to ensure no crucial element is missing.
The more problems that arise during the analysis phase the more unaddressed risks and change requests you’re likely to encounter, which could cause quality to deteriorate.
High-quality requirements lead to high-quality solutions. QA managers study requirements religiously, looking for any gaps, contradictions, and unclarities there might be. Finding any logical issues during the requirements phase is much cheaper than finding them in the production code.
QA specialists play a critical role when the exact details are defined and designed. They ensure everything is covered and the design is free of errors.
They ask themselves meticulous questions such as:
The more error-free the design, the more error-free the final product.
During the development phase, QA specialists mostly prepare for the testing and integration phase. It includes preparing test plans and test cases for further tests. This preparation helps them to perform more robust and efficient testing down the road. Sometimes, QAs also write automation tests alongside the development team.
Testing is the execution phase for QAs, where they take the developed increment and execute the test cases they prepared earlier. Depending on the scope of testing and complexity of the increment, they can test functionalities at a high level or triple-check every single input field.
Quality assurance doesn’t end with deployment. After a product or feature is launched, QAs usually double-check to make sure what worked for staging also works for production. They also monitor product quality metrics and ensure the product doesn’t break after new updates.
Regardless of whether your company uses a waterfall model, V-model, or agile software development framework such as scrum or kanban, the overall scope of QA activities is rather similar.
No matter what model you adopt, you will always have the analysis, design, development, testing, and deployment stages. The main difference is when these phases take place and how big the pieces of work are.
To provide a snapshot of what a QA specialist does, let’s dive deeper into their day-to-day activities. The exact scope of activities done by a QA depends heavily on the product itself and the company’s approach to ensuring quality:
Although quality assurance also includes quality control and testing, let’s focus on activities preventing issues:
Quality should be built into the entire development process. How problems are analyzed, requirements are documented, and issues are communicated significantly impacts the overall quality.
QA experts ensure that the processes and practices within the team lead to high-quality products.
Whenever there’s an incident, a QA specialist, usually leads or heavily contributes to the post-mortem process. They ensure that the teams learn and improve from each mistake, not just fix and forget.
Proper documentation helps you prevent errors and troubleshoot problems when they appear. In the long run, it also helps you speed up development time.
Although documentation is the whole team’s responsibility, documentation review is often a part of quality assurance practices.
QAs often ensure the required audits are done or conduct the audits themselves.
For example, an app might need to fulfill specific GDPR requirements, or a card payment processor might require regular external audits. QAs might perform these (pre-) audits and often play a pivotal role in cooperating with external auditors.
Quality assurance is the responsibility of the whole team. After all, everyone’s actions impact the final outcome.
QA specialists help the team understand best quality practices, explain how to write better documentation, and sometimes teach the team how to write automated tests independently.
Quality control is all about ensuring the product meets the agreed-upon quality standards. The various activities that contribute to keeping quality in check include the following:
Non-functional requirements, such as scalability, reliability, performance, and security, should meet some of the quality benchmarks
Whether, in a continuous (e.g., resource usage monitoring) or ad-hoc (e.g., load tests) manner, QAs keep non-functional quality in check with additional support from other specialists like DevOps engineers.
As the product scales, it becomes inviable to rely entirely on humans. At some point, it’s essential to automate core test scenarios.
Quality experts prepare and configure test environments and write tests that execute and report specific test cases.
In the long run, automating tasks is more efficient and prevents the team from having to manually test everything every time.
Some organizations rely on QA specialists to write and maintain automated tests, while some decide to have dedicated quality assurance automation (QAA) specialists.
The product changes and evolves all the time. Thus, the scope of testing should also evolve continuously.
The feature that was critical a year ago might be irrelevant or even depreciated today.
QAs ensure that the scope of all testing (manual, automated, documentation, non-functional, and so on) is adequate to address the current needs of the product.
Ultimately, it’s impossible to test everything, so QAs ensure the team picks the right battles.
Testing is a core element of quality control.
There are different types of tests a QA can perform. The most common ones are:
A smoke test is the quickest and most rudimentary type of test.
The objective is to test the app’s main flows and functionalities superficially. It might be scripted or done based on a gut feeling. It has two purposes:
In simple words, scenario testing includes designing and executing particular test cases. They have step-by-step instructions on what to test and how to test it:
The reasons to write test cases include:
The most significant disadvantage is how time-consuming testing can be when writing and maintaining an ever-growing repository of test cases. Complex products can have as many as a few thousand test cases.
These are unscripted, skill-based tests that combine learning, test design, and test execution. QA tests the app without any specific scenario and user flows, often just clicking through the whole app in somewhat random order.
Since the tester has to design and execute tests on the go, past experiences and domain knowledge are extremely valuable.
Exploratory tests serve various purposes. They:
The fact that something worked once doesn’t mean it will work forever, especially when it comes to developing software.
By changing one application element, a developer could accidentally change component settings used in different parts of the app.
Breaking things that worked in the past is quite common. We call this phenomenon “regression.”
Regression testing means double-checking if things that should work still work. Usually, regression testing is done before releasing a new version of the product, with QAs checking to see if the most critical user flows work as expected.
That means if there’s a release twice a week, a key component, such as the login process, should also be checked twice a week. Hopefully, this testing is done by an automat, not a poor human being.
Contrary to popular belief, quality assurance is present at every stage of the product development lifecycle, not just the final testing phase. Quality experts ensure the analysis phase is done correctly, review the requirements and designs, and monitor how the app behaves in the product environment.
Additionally, QAs also perform various other activities, such as process improvement, training, documentation review, audits, automation, etc.
Quality is the responsibility of the whole team. However, with the meticulous planning and complex principles that go into ensuring quality, every team could benefit from gaining knowledge from a dedicated QA specialist, or even a few of them.
LogRocket identifies friction points in the user experience so you can make informed decisions about product and design changes that must happen to hit your goals.
With LogRocket, you can understand the scope of the issues affecting your product and prioritize the changes that need to be made. LogRocket simplifies workflows by allowing Engineering, Product, UX, and Design teams to work from the same data as you, eliminating any confusion about what needs to be done.
Get your teams on the same page — try LogRocket today.
What exactly is founder mode, and is it really better than manager mode? Let’s discuss what this phenomenon could mean for the PM world.
Chaos engineering is the practice of deliberately introducing failures into a system to test its resilience and identify hidden weaknesses.
Arman Javaherian talks about the importance of setting aside time to help grow and mature product managers on his teams.
Enablement refers to the process of providing others with the means to do something that they otherwise weren’t able to do.
One Reply to "What is quality assurance (QA) in software development?"
Nice Blog! Thanks for the information.