Suppose we have to develop an ecommerce product. There are many features in an ecommerce product like
- Home Page
- Login/Signup
- Products, Searching and Filtering
- Product Detail Page(PDP)
- Wishlist
- Recommended Products
- Cart and Checkout Page
- Payments
- CANS(Communications Alerting and Notification System)
- Thank You Page
I think these are major features for a typical ecommerce product or we can say that we can divide an ecommerce product into 10 parts.
Now if we have to deliver this product then first we have to design its system flow diagram, system architecture, database design, UI/UX, APIs development etc. To develop a product we have to break down the entire product into different sprints and different teams or individuals. Each and every feature will be developed independently in individual Git branches. Each and every feature would be tested separately. But we can’t send the individual feature into production, right?
So for that we need integration of all the separate branches into a single branch. Let’s say we called it “Main_Feature_Branch”. We have tested each individual branch in a QA environment. After integration of all the branches into the “Main_Feature_Branch” branch, we have to test the entire feature once again end-to-end which is called integration testing.
Integration testing is a software testing technique that aims to verify the proper functioning of the individual software components that have been integrated or combined to form a larger system or application.
The purpose of integration testing is to identify any issues or defects that may arise due to the interaction between these components, and to ensure that they work together as expected.
In integration testing, the individual components are tested as a group or as a subsystem, and the testing focuses on how these components interact with each other. The goal is to ensure that the integrated system meets the specified requirements and works as expected.
Now there would be a question in your mind that what are different types of integration testing approaches, right?
Yes, you have a genuine question. There are different integration testing approaches are available as
- Top-down Testing: In this approach, the higher-level modules are tested first, followed by the lower-level modules. The modules are integrated in a hierarchical manner until the entire system is tested. This approach is useful when the top-level modules are more critical or complex than the lower-level modules.
- Bottom-up Testing: In this approach, the lower-level modules are tested first, followed by the higher-level modules. The modules are integrated in a reverse hierarchical manner until the entire system is tested. This approach is useful when the lower-level modules are more critical or complex than the higher-level modules.
- Big-bang Testing: In this approach, all the modules are integrated and tested together. This approach is useful when the system is small, or when there are time constraints.
- Sandwich Testing: This approach combines top-down and bottom-up testing. In this approach, the integration testing starts from the top and bottom simultaneously, with the middle modules being tested last. This approach is useful when both the top-level and lower-level modules are equally critical.
Now you would be thinking which approach is best, right?
There is no one-size-fits-all approach to integration testing, as the best approach depends on various factors, such as the software architecture, project requirements, and resources available. Each approach has its advantages and disadvantages, and the choice of approach depends on the specific situation. Therefore, it is essential to choose the approach that best suits the project’s needs and objectives.
If I talk about an ecommerce product there are around 15–16 features. So what you think about which approach is suitable for that. Personally I would prefer a top down approach for that kind of product.
Why?
Because our ecommerce product depends on major features like login/signup, product search/filtering, product details page, cart, checkout, payments and thank you page. First we have to test all these major features then we can proceed with other small features like wishlist, my account, recommended products etc.
But it’s my choice based on what I think but it totally depends on the product size, criticality, team size and all other factors. You can go with anyone.
First we have to deploy our main branch “Main_Feature_Branch” in a QA environment and we have to start our testing from major features first. If issues come, report all the issues in Jira or any other tool which you are using. Once the single iteration is complete, ask your developers to fix all the issues in the same branch and deploy it again in the same environment.
If everything is fine there are no issues on the QA environment then ask the devops team to deploy the branch on the Pre-prod server and again repeat the same process. Now if on the Pre-prod server if there are no issues then we have to ask our stakeholders to test their respective functionalities.
We know now there are no functionality issues but they can ask for any additional features which they missed initially or may ask to change or modify any flow. It happens in startups. But I know the pain of a developer as I am a developer, how a developer feels when they put in their hard work and the product is not going live.
Initially I also felt bad many times but slowly I understood that it’s the beauty of startups. This is the reason they are called startups. If you are a developer, you should be patient in such scenarios, why?
Ultimately we all are working for an organization to make our product better and better day by day. No one is doing anything intentionally. You have to understand that. Sooner or later your efforts will be appreciated.
We can easily understand the integration testing flow by the help of the following diagram as

CONCLUSION
To develop any product we have to divide it into different parts or features. Each feature has been assigned to a different team or individuals. Each feature has its own branch for development. So there are multiple branches for a product. To deliver that product we have to send all the branches into production after testing. For that we have to integrate all the branches into a single branch which is called integration. After integration we need to test the entire product on Pre-prod before sending it into production which is called Integration Testing. There are various integration approaches for integration testing. Based on our requirements or product we can choose any one.
