Cloud-side vs. Client-side Testing: What’s Right for Your Project?
Most developers are familiar with running Selenium or Appium tests on their local machine (or sending them to a local Appium server). While these capabilities are essential early on, many organizations need help scaling this approach. Building and maintaining internal device labs and infrastructure can quickly become a nightmare.
Here, you’ll learn about the differences between client-side and cloud-side tests and how to choose the right option for your project.
What is Client-Side Testing?
Client-side testing is the process of executing your tests locally (often directly on a real device or browser) rather than on a remote server. For example, a mobile developer working on a fitness app might connect their iPhone and run an Xcode test on the device. That way, they receive immediate feedback and can easily diagnose issues by running quick tests.
Some of the benefits include:
- Device-level Access – Testers can use specific devices with specific configuration settings. In addition, they can access in-depth logs and other metrics to diagnose problems.
- Quick Set Up – Testers can launch tests from their local development environment without uploading and scheduling a cloud-side test. This makes it easier to spot-check new features.
- Security – Organizations can secure data by keeping test hardware offline or behind a firewall while retaining full control over PII or other data for maximum compliance.
These benefits might appeal to healthcare companies that collect and compare apples-to-apples data and ensure no data leaks occur for HIPAA reasons. Or, to cite another example, companies developing internal apps may want to ensure they work in specific factory settings involving private cellular or Wi-Fi networks.
Despite these benefits, client-side testing comes with a unique set of challenges:
- Time and Test Latency – Client-side testing may take longer because it must account for many client environments. Moreover, tests cannot typically run in parallel.
- Slower Agile Cycles – The additional time spent on testing can delay software releases, which slows down Agile development cycles and can hurt app competitiveness.
- Less Test Coverage – Comprehensive test coverage may be difficult or impossible due to the wide variety of possible configurations and limited access to devices.
- Higher Cost – Client-side testing requires purchasing and maintaining a device lab, consuming upfront and ongoing capital and costly engineering hours.
What is Cloud-Side Testing?
Cloud-side testing is when tests are executed in the cloud rather than on a local client device or browser. For example, a mobile app developer might write tests in Appium, upload them to the cloud, and run them in parallel on hundreds of devices simultaneously. As a result, they can achieve better test coverage in a fraction of the time.
Cloud-side testing conveys several benefits:
- Better Coverage – Cloud testing platforms maintain large device libraries, enabling you to test the same app across a broad range of devices, operating systems, and browsers to ensure compatibility.
- Faster Tests – Cloud testing platforms enable you to run hundreds or thousands of tests in parallel, making your test suite speedy without sacrificing test coverage or quality.
- Less Overhead – You don’t need to build and maintain a device lab. This saves upfront capital costs and frees up engineering resources to work on apps rather than test infrastructure.
These benefits may appeal to browser-based gaming or mobile apps with features varying across devices. You can ensure applications work for everyone by enabling tests across different devices. In addition, cloud-side testing may appeal to apps with high UX requirements and a large test suite by allowing more comprehensive tests to run faster.
However, cloud-side testing also comes with its own set of challenges:
- Complexity – Setting up, configuring, and managing cloud test environments can be complex and may require specialized knowledge and skills.
- Security – Tests may involve sensitive data, and running tests in the cloud requires extra precautions to ensure data security and comply with data privacy and security regulations.
- Compatibility – Cloud testing platforms may provide a broad range of devices, but they may not be the best fit if you need legacy devices or specific environments.
- Cost – Cloud testing platforms often involve subscriptions, and organizations without a budget may not have access to the level of testing they require to meet their demands.
- Networks – Cloud-based tests require good network access, as local machines and the cloud platforms must transmit test commands and responses to each other.
BitBar Bridges the Gap
Client-side tests are the most common, but cloud-side testing platforms are becoming increasingly popular. Unlike many cloud-side testing platforms, BitBar offers both client- and cloud-side execution, enabling you to choose the best option for each project – or a combination of testing approaches to discover bugs more quickly.
BitBar makes it easy to run your client-side Appium tests in the cloud using a quick cURL or as part of a continuous integration process. That way, you can run them like you execute tests on your local machine. The only difference is that the Appium server and the tested device are in the cloud rather than on-premise.
Alternatively, you can upload your existing Appium tests to BitBar Cloud and then, using the API or the cloud UI, select and start test execution on multiple devices. As a result, you don’t need to modify your Appium tests, can execute tests in parallel on various devices, and receive an alert when the execution completes.
Several other features address many of the challenges of cloud-side testing:
- Simplicity – Creating automated tests is extremely simple in BitBar. You can click on “Create Automated Test” through the web interface, configure a test run, generate boilerplates for test scripts, select desired test devices and environments, run the tests with a click, and view the results in helpful reports.
- Security – The BitBar SecureTunnel enables you to run tests on web, hybrid, and mobile applications hosted on internal development environments, behind a firewall, or local host. BitBar also offers both public and private cloud deployment options.
- Scalability – BitBar enables you to execute tests on hundreds of real devices in parallel, dramatically reducing the time it takes to conduct tests. You also have access to a massive device lab with the latest, most popular iOS and Android models without the cost of building and maintaining an in-house device lab.
The Bottom Line
Client-side tests enable developers to launch tests from their local machines and quickly test new features – and BitBar makes it easy to run these kinds of tests using cloud devices or browsers. But in many cases, cloud-side tests are best for developing a robust test suite. You can achieve better test coverage and focus on building new features.