Test automation and CI/CD - Quality Engineering
Technologies: Android, API, iOS, Javascript
Industry: Healthcare
MAIN ISSUE
A new joint venture required implementing a solid test automation strategy along with a new CI/CD pipeline for a new set of mobile and web applications.
CONTEXT & CHALLENGES
The project had a one-month deployment cadence with sometimes an additional two-week timeframe for manual regression testing. Using Jenkins to build CI pipelines and Selenium (Java) and Jmeter as QA tooling, it was apparent something had to change. The proposal was to start using CicleCI and select a testing tool that could allow both QA and Development to write and execute fast and reliable tests and test results that everyone could understand.
Recommended by LinkedIn
Deciding on a testing tool for a set of applications that does not exist yet is not easy. We needed to understand how the business value would be delivered and the architecture for this application's ecosystem. We knew CI/CD would be a key for this project to be successful; hence a shift-left mentality and a comprehensive test automation design and implementation would be the key.
ENROUTE'S SOLUTION
The initial scope was to have a complete automated suite for three applications: native iOS, Android, and Web. The preferred programming language was javascript, and we needed an easy-to-use framework that everyone could understand and maintain and can be easily integrated within our CI/CD pipeline. Additionally, we built a robust API integration testing suite that will run every 3 hours in all of our lower environments.
We developed the testing framework from scratch, which consisted of essential validations that were granular enough for the framework to be scalable and easy to maintain.
The tests were running on real iOS and Android devices on BrowserStack for each PR. These tests could also be executed locally within an emulator for test development purposes and local changes verification.
We created different test suites: regression, smoke, and hotfixes. These suites could be executed within CircleCI based on commit messages so the developers had complete control on which tests they could run by just specifying the test suite when pushing their changes.
The result was an increased development and deployment confidence and a continuous integration pipeline that allowed us to do weekly deployments and on-demand deployments at any given time.