Risk Management in Testing

Risk Management in Testing

Table of content

Show More

What is Risk Management?

Risk management is the process of identifying, assessing, and managing risks. It is performed in both planning and execution phases. An effective risk management strategy and application drastically reduces the chances of execution failures in software development.

Watch this Selenium Tutorial video

Video Thumbnail

The main phases of risk-based testing are:

  • Risk Mitigation
  • Risk Identification
  • Risk Impact Analysis

Risk Management in Software Development Life Cycle

The entire process of risk management is divided into three important steps, which described below in detail:

Risk Identification

Risk identification is the simple identification process that lists out the probable factors that may disrupt the smooth functioning of the software. This listing process includes all possible instances, including external errors that might disrupt the functioning of the software.

The most identified risks are late errors, lack of defined scopes, unavailability of independent test environment and workspaces, tight test schedule due to impending demand, etc. The identification process is often a prerequisite to ensure that the software has authenticity in the testing reports. The developers are also informed about the risk factors to avoid such loopholes in the future.

Get 100% Hike!

Master Most in Demand Skills Now!

Risk Impact Analysis

Once the risk is identified, we move on to the risk impact analysis. This step involves the classification of the identified risks based on their probability and force of impact on the entire project. The three classifications for impact analysis are high, medium, and low. A systematic structure is followed to analyze the risk before it gets materialized.

Impact analysis is done financially as well because the impact in that sector can have direct results on the development of the software. Major issues such as tight testing schedule and delay caused due to design issues could be a considerable hindrance; hence, getting assigned to the high-risk category after the risk impact analysis. An issue like the probability of natural disasters is classified as a low risk.

Risk Mitigation Process

The next is the most important step, the risk mitigation process. The idea is to find feasible solutions for the analyzed risk, keeping high category risk mitigation as a priority. Finding the proper risk mitigation technique is also crucial. The techniques used should be harmless for the other stages of development.

The risk mitigation factors include finding the most suitable solution that can be arranged in a limited time frame and thus, does not induce the risk of delaying the entire project. For example, the high-risk factor of tight testing schedule, causing delay, can be mitigated by informing the development and testing team to control the preparation tasks in advance as a preventative measure.

Test Execution

Risk management, at times, extends to the test execution phase. The execution of time risk management is a fast task to accomplish, as it is constructed in a very short time frame. Therefore, usually, the impact analysis classifies the risk probability based on individual modules and ranks them accordingly, making it easier for the testing team to mitigate the risk by prioritizing the module tests, finding the solutions with the highest-ranked module, and saving a lot of time and energy.

Ways to Carry Out Risk Analysis in Software Risk Management

There is no standard process for risk analysis. Different companies carry out the process in different ways. Risk analysis is also carried out on different items of a project. This is important to identify the risks and to implement the risk-based testing analysis approach. The different items in a project are as follows:

  • Functionalities
  • Features
  • User Stories
  • Use Cases
  • Requirements
  • Test Cases

In this blog, we will only be focusing on the test cases to understand the risk-based testing approach.

Procedure of Risk Analysis in Risk Management

Stakeholders from the technical and business team are involved in risk analysis. These stakeholders discuss and identify the importance of each feature of a product. This will then be made into a list of priorities, based on the risk of failure and how it will impact the end-user experience.

A few important things that shape the discussion include:

  • Project documents such as technical specification documents, architecture documents, use case documents, etc.
  • Most-used functionality
  • Consultation from a domain expert
  • Previous version data

During this discussion, the risk factors associated with each feature are identified. The risks could be technical, business-related, or operational. The likelihood of risk occurrence and its impact helps in weighing all tests and scenarios.

The risk occurrence likelihood could be due to:

  • Improper understanding of the feature by the development team
  • Poor design and architecture
  • Not enough time to design
  • Team’s incompetency
  • Not enough resources

The impact of the risk could be as follows:

  • Cost impact
  • Business impact; losing business or market share
  • Quality impact
  • Bad user experience

The focus is of examining the risk of a feature or product could be:

  • Business criticality of the functionality
  • Features that are most used and important functionality
  • Areas that are prone to defects
  • Functionalities that bear the impact of security and safety
  • Complex design and architecture areas
  • Changes that were made from the previous versions

Risk Analysis Methodology in Risk Management

We can now talk about the risk-based testing methodology in detail. RISK is the criteria in all the test cycles and phases, under the risk-based testing methodology. We can design several combinations of test case scenarios. The tests are ranked on the basis of the severity of risks. This helps find out the riskiest area of failure.

The main goal of risk analysis is to find the high-value items, such as product functionalities, features, etc., and the low-value items. This is done to ensure that the primary focus is always on the high-value items. This is the first step in risk analysis, before we can start with the risk-based testing methodology.

The categorization of high- and low-value items is done by following the steps given below:

Using a 3×3 Grid

Risk analysis is conducted by using a 3×3 grid. The stakeholders assess all functionalities, non-functionalities, and test cases for the “likelihood of failure” and “impact of failure”.

The “likelihood of failure” is categorized into “likely”, “quite likely”, and “unlikely”, along the vertical axis of the grid. This is done by a team of technical experts.

The “impact of failure” is categorized into “minor”, “visible”, and “interruption”, along the horizontal axis of the grid. This is generally assessed by the end customer, but if for some reason that is not possible, a group of business specialists carry out the assessment.

Likelihood and Impact of failure

Test cases are positioned in the quadrants in the grid. This is based on the identified values of the likelihood and impact of failure. These are shown as dots.

The test cases with high likelihood of failure and high impact of failure are grouped on the top right corner of the grid; they are the high-value items. While the low-value items are grouped together in the bottom left corner of the grid.

Testing Priority Grid

The tests are prioritized based on their positioning on the grid. They are labeled numerically according to their priority. The tests are executed according to their priority. The high priority tests are executed first and the low priority tests are executed last or just chucked out.

Details of Testing

Now, the level of details of testing has to be decided. The scope of the testing is decided based on the ranking in the grid.

High priority tests that rank 1, are tested “more through(ly)”. Experts are deployed to execute these test cases. The rest of the test cases are also labeled according to their priority. The least priority test cases can be executed, if there is enough time and resources left.

This entire process helps testers identify the high-value tests and also guides them on the details of testing to be conducted.

Risk Management Process

The risk management process involves three stages:

  • Risk Identification
  • Risk Assessment or Impact Analysis
  • Risk Mitigation

Risk Identification

A risk has to be first identified before it can be solved. The first step in the risk identification stage is to make a list of everything that could go wrong.

This step is usually led by a QA manager, lead, or representative, but the entire QA team’s contribution is important.

Let us take a look at a sample list of risks; the application that is being tested is not the focus here; the focus is how the QA phase will pan out:

  • The testing schedule has been tight.The test started late because of design tasks and, now, it cannot be extended beyond the user acceptance testing (UAT) start date.
  • The resources weren’t enough, and the onboarding took a lot of time.
  • The defects were found late and they are going to take a lot of time to resolve.
  • The scope was not completely defined.
  • The occurrence of any natural disaster.
  • The unavailability or inaccessibility to an independent test environment.
  • The emergence of new issues causing the testing to be delayed.

Once we get the complete list of risks, we can move on to the next stage.

Risk Assessment or Impact Analysis

In this stage, all the risks are quantified and prioritized. Each risk’s probability and impact is determined systematically. Values are assigned to the probability and impact of the risks as high, medium, or low. High-priority risks are taken care of first, followed by medium- and low-priority risks.

If we create a sample table for the list of risks we mentioned above, it would look something like this:

RiskProbabilityImpact
The testing schedule has been tight.The test started late because of design tasks and, now, it cannot be extended beyond the UAT start date.HighHigh
The resources weren’t enough, and the onboarding took a lot of time.MediumHigh
The defects were found late and they are going to take a lot of time to resolve.MediumHigh
The scope was not completely defined.MediumMedium
The occurrence of any natural disaster.LowMedium
The unavailability or inaccessibility to an independent test environment.MediumHigh
The emergence of new issues causing the testing to be delayed.MediumHigh

Risk Mitigation

The last stage of the risk management process involves coming up with solutions to handle each of the listed risks. Here is a sample of what the list of risks mentioned-above would look like after this stage:

RiskProbabilityImpactMitigation Plan
The testing schedule has been tight.The test started late because of design tasks and, now, it cannot be extended beyond the UAT start date.HighHighThe testing team can control the tasks in advance.Some buffer time can be added to the schedule.
The resources weren’t enough, and the onboarding took a lot of time.MediumHighVacations and holidays have been built into the schedule.
The defects were found late and they are going to take a lot of time to resolve..MediumHighDefect management plan has to be put in place for quick communication and fixing bugs.
The scope was not completely defined.MediumMediumThe scope has to be well defined.
The occurrence of any natural disaster.LowMediumThe teams have to be distributed into two geographical areas. This way, in case a natural disaster happens, the other team can continue the process further.
The unavailability or inaccessibility to an independent test environment.MediumHighThis will impact the schedule of test execution and cause delay.
The emergence of new issues causing the testing to be delayed.MediumHighDefect management and issue management procedures are put in place to provide a quick resolution.

Best Practices for Risk Management in Software Testing

Let us take a look at some of the best practices for risk management in software testing:

  • Involve stakeholders in every step of the risk management process.
  • Build a strong risk culture in the company; this includes attitudes, values, and beliefs. The importance of risk awareness should be instilled in the employees so that everyone is prepared.
  • Communicate risks throughout your company. High-value risks should be monitored by all departments.
  • Clearly document the company’s risk management policy. It should be further communicated to the employees.
  • Clear risk monitoring processes must be in place.

Conclusion

Risk management in testing is a crucial step in delivering the final product to the customers. It helps in improving the planning and execution process as well as reducing the potential of failures.

In this blog, we have discussed the stages involved in risk analysis and management. If carried out effectively, these are definitely going to help improve the software development cycle. Therefore, make sure to identify and manage risks before the final testing. Good luck!

About the Author

Senior Associate - Automation and Testing

Akshay Shukla, a senior associate at a multinational company, is an experienced professional with a rich background in cloud computing and software testing. He is proficient in frameworks like Selenium and tools like Cucumber. He also specialises in Test-Driven Development and Behavior-Driven Development.