Automated software testing is all the rage in the industry and for good reason. Although manual testing is still in place in many technology companies, many fast-growing organizations have adopted QA automation testing to speed up processes, redirect manual efforts and minimize the chances of error.
It is quite common for businesses to outsource the quality assurance processes of their software development cycle. It saves them time, cost, and resources.
This means, it’s essential for technology organizations like ours, that offer software quality assurance services, to adopt one of the most accurate, efficient, and reliable approaches to quality assurance, i.e. automation. In this article, I’ll talk about how the QA team at VentureDive carried out automation testing for the Muslims App. It is a community engagement app by IslamicFinder that aims to unite Muslims around the world through a single platform, offering networking, knowledge sharing, and learning.
Let’s dive in!
How did we manage before QA automation?
Muslims is a hybrid mobile application developed in React-Native. It has the same code hierarchy for both, Android and iOS platforms. This means we have the same code base for QA automation as well.
While the app was in the development phase, and new features were getting integrated into Muslims continually, we were carrying out manual quality assurance side by side. The process was consuming a lot of effort – with every issue reported, the QA team had to dig down into the apps again and again, and ensure that the overall performance of apps remains optimal. Every time an issue was reported or any new build was shared with the QA team, they had to go through all the features of the app, which made quality testing a tedious and time-consuming process.
In short, we dreaded it!
As the application got bigger and more complex with every sprint – that meant more issues popped up that needed fixing – it was no longer possible for us to test each and everything over and over again. So we decided to create and implement an efficient testing process to reduce the testing effort of the team, as well as enhance the overall quality of the apps. Enter: a hybrid automation system for mobile apps for both, iOS and Android platforms.
QA automation covers a lot of things we previously had to do manually and repeatedly. It took on the menial, and repetitive tasks for us, delivered better testing quality, with minimal chances of error, and helped deploy high-quality, bug-free apps. Our automation engineers began developing the QA automation process for hybrid apps so we can test each and every feature more thoroughly, using both manual and automated systems, and deliver a seamless product to the users.
Why did we decide to automate the Muslims app?
The thought process behind automating the Muslims app was that we wanted to reduce the overall testing time of the app on both, Android and iOS platforms. The idea was that once any new feature is developed and ready to merge, we automate its testing. Over time, this would enable us to have a full-fledged testing process in place, that would streamline quality assurance efforts, reduce time and cost spent, and deliver efficient and high-quality apps to customers within record time.
The whole QA automation team brainstormed a lot on how to automate the hybrid application for Muslims. We discussed different technology stacks and their pros and cons with the goal to increases the overall quality and performance of the app through a smooth QA automation process.
Why did we use the same codebase for Automation?
The grounds behind using the same code base for automation of Muslims app was that we are developing a hybrid framework, and a single code base would mean a lesser number of changes required in the automation framework. Whenever there is a change in the application hierarchy, the same code base would mean reduced development effort in the hybrid framework. Here’s a resource to help you understand the difference between hybrid and native applications, and which might be a better choice for your project.
We can also reuse this QA automation framework for any hybrid app developed in react-native as well as native apps to make lives easier for automation engineers. This would make managing the code base simpler, with lesser changes and easy integration of new features within the automation framework.
What technology did we use for QA automation?
Our QA automation engineers adopted WebDriverIO, a tool that allows you to automate any application written with modern web frameworks such as React, Angular, Polymer, or Vue.js, as well as, native and hybrid mobile applications for Android and iOS.
We can develop any web or mobile automation framework easily using WebDriverIO due to its exciting feature set and many valuable plugins. Its libraries are easily available and can be integrated with the framework quickly, so it saves a lot of time for automation engineers.
Many technology companies choose to go with Selenium WebDriver, another tool used for automating browser testing. We used WebDriverIO and javascript for the development of automation scripts for Muslims app with integration of unit test frameworks like mocha and chai, the assertion library, in it.
However, we chose WebDriverIO over Selenium because of a multitude of technical reasons:
- WebDriverIO libraries are wrappers of selenium libraries as these are developed on top of selenium libraries – it provides faster execution than using Selenium APIs with Appium, a test automation framework.
- WebDriverIO provides a runner class where we can define all the necessary prerequisites, which makes it easier to configure the execution of automation scripts. Whereas, we have to write a lot of lines of code to set up the configuration process of Selenium with Appium.
- WebDriverIO has its own Appium service so it takes only a few minutes to configure Appium with it.
Using a hybrid automation framework like WebDriverIO has many advantages. For instance, a one-page object class is developed for both Android and iOS platforms so we don’t need to create a separate repository for this platform. A generic helper class package is also created to reuse the utilities within the project and we can use this framework with any project in the future if we want to develop a framework for hybrid and native apps.
Wrap up
For the QA automation of hybrid apps, you can easily develop an automation framework with WebDriverIO and Appium as it provides a lot of flexibility in developing, structuring, and maintaining the codebase. It will be up to the individual’s expertise on javascript and node.js as it requires javascript skills for a person to work on these frameworks. If you have used Selenium with Appium, it will be easier for you to use a switch on these javascript frameworks. According to my experience, if you are developing your own hybrid application, I would suggest you give WebDriverIO a shot and feel free to share your experience of working with javascript frameworks.