โ๏ธDefect Life Cycle
Last updated
Last updated
Defect Life Cycle or Bug The life cycle in software testing is the specific set of states that a defect or bug goes through in its entire life.
The purpose of the defect life cycle is to easily coordinate and communicate the current status of the defect, which changes to various assignee's and make the defect fixing process systematic and efficient.
As a software testing professional, understanding the defect life cycle, also known as the bug life cycle, is crucial to ensuring changes, software quality.
In this tutorial, weโll explore the stages of the defect life cycle and their importance in ensuring software quality.
We can define the defect/bug as the abnormal behavior of any software. The defect life cycle is a process that describes the stages of a defect from discovery to closure. By following the defect life cycle, we can ensure that defects are discovered, documented, and resolved in a structured and efficient manner.
We have seven steps in the defect life cycle. Letโs look at each one of them in the following subsections.
1๏ธโฃ Defect Discovery
A defect is discovered during testing.
๐ A user reports that the application crashes when they try to upload a file.
2๏ธโฃ Defect Logging
The defect is logged in a defect tracking tool with details such as the defect description, severity, and priority.
๐ The QA engineer logs the defect in the tracking tool with a description of the issue and assigns it a high priority.
3๏ธโฃ Defect Assignment
The defect is assigned to the appropriate developer or team to fix the issue.
๐ฅ The QA lead assigns the defect to the development team responsible for the affected module.
4๏ธโฃ Defect Fixing
The developer fixes the defect and verifies the fix, ensuring that the defect is resolved.
๐ง The developer fixes the issue and unit tests the code to ensure that the fix works as expected.
5๏ธโฃ Defect Verification
The QA team verifies the fix and retests the software to ensure that the defect is no longer present.
โ The QA engineer tests the fix and verifies that the issue is resolved, then updates the defect tracking tool with the test results.
6๏ธโฃ Defect Closure
The defect is closed once it is verified that it has been fixed and is no longer present in the software.
๐ช The QA lead reviews the test results and closes the defect in the tracking tool if the issue has been resolved.
Everything starts by discovering that a defect exists.
We can discover defects during various stages of software development, such as design, coding, testing, or even after the software has been released. For example, during the testing phase, a tester may encounter a functionality issue or unexpected software behavior, which indicates a defect.
Once we discover the defect, we must log it into a defect tracking tool, such as JIRA, Bugzilla, or Trello. This process involves capturing as much information as possible about the defect, such as its severity, priority, and steps to reproduce it.
Letโs consider a software-:crashing example scenario. A tester may log this defect with the following information:
Description: The software crashes when the user clicks the โSaveโ button
Severity: High (the defect causes a critical system failure)
Priority: Urgent (the defect needs to be fixed before the software can be released)
Steps to reproduce: 1. Open the software; 2. Create a new file; 3. Type some text; 4. Click on the โSaveโ button
In this phase, the project manager reviews and assigns the defectโs severity and priority. The severity level indicates the impact of the defect on the system, while the priority level indicates the urgency to fix the defect.
For example, a critical defect with a high priority may need to be fixed immediately to avoid causing significant damage to the system or the end-user experience.
After triaging a defect, we should assign it to a developer who will work on resolving the defect. The developer receives all the necessary information about the defect, such as its reproduction steps and the expected behavior to resolve the issue.
The developer starts working on fixing the defect. Once the developer completes the fix, they mark the defect as โFixedโ in the defect tracking tool.
For example, a developer may fix the above-mentioned defect by identifying the code responsible for the crash and correcting it. After the fix is complete, the developer marks the defect as โFixedโ.
After fixing the defect, we need to verify the fix. The tester verifies this by executing the test cases related to the defect. If the tester finds the fix does not solve the defect, it is reassigned/reopened.
For example, a tester may verify the fix for the above-mentioned defect by repeating the steps to reproduce the issue and checking that the software no longer crashes when clicking the โSaveโ button.
Once the defect has been verified, it is marked as โClosedโ in the defect tracking tool. The defect is considered closed when it meets the criteria for closure, such as passing all the related test cases and receiving approval from the project manager.
Letโs look into the visual representation of the various stages that a software defect goes through, from its discovery to closure:
As we can see, the defect life cycle involves multiple stages, from triaging and assigning defects to developers for fixing to verifying the fix. If a previously closed defect is found to have a similar issue, it may be reopened and assigned for fixing again.
Sometimes, after a bug has been reported and worked on, it goes through a few different states before it is resolved. Here are some examples of those states:
Rejected: If a developer disagrees with a bug report from a tester and considers itโs not a problem or something that needs to be fixed right now, it can be marked as โRejectedโ
Duplicate: If the reported bug is the same as another bug already in the โOpenโ state or fixing a different bug will also take care of this one, it can be marked as a โDuplicateโ so we donโt waste time working on it separately
Deferred: Sometimes, we may decide that a bug doesnโt have a high priority โ maybe itโs not a big problem, or it would be too difficult or expensive to fix right now. In that case, we can mark the bug as โDeferredโ and plan to work on it in a future release of the software
Not a Bug: If we investigate a bug report and find that itโs not really a problem โ maybe itโs just a misunderstanding or something that doesnโt affect the softwareโs performance โ we can mark it as โNot a Bugโ. In such a way, we can focus on the other relevant defects that must be fixed
The defect life cycle in Agile Environment differs from traditional software development because it is iterative and incremental.
Agile methodologies involve continuous testing and integration, which allows defects to be discovered and addressed early in development.
The stages in the defect life cycle in the agile environment include discovery, logging, triage, assignment, fixing, testing, and closure. But, unlike traditional software development, these stages are not always linear and may overlap or simultaneously happen.
For example, defects may be discovered during testing and immediately fixed by the developer without going through the triage and assignment stages.
Tester - Logs defects, retests fixes ๐ต๏ธ
Developer - Fixes defects ๐จโ๐ป
QA Manager - Reviews and prioritizes defects ๐ผ