A more advanced variation of this approach is where you "rent time" to access a particular handset in a hosted service model. It is still testing using a real handset, you are just accessing it remotely. Testing with real handsets allows you to verify that what is shown on the LCD of the device "looks cosmetically correct" for each step of the test case. The downside of this approach is that you have limited access to any type of diagnostic information other than what is shown on the LCD of the real handset. If your question is "Why is the page slow to load?", testing with a real handset does not provide detailed root cause analysis information needed to solve this problem.
For testing mobile internet content, a second approach is based on a "virtual device" or emulator. In this approach, the handset under test is mostly based in software. Why would you want to test using this approach? One of the biggest reasons is that a virtual device approach lets you see what is happening "behind" the LCD. Since the virtual device is in control of its own software stack, you can collect important testing information on "each component" of a content page. For example, how long does it take for each image on the page to load? Does the page contain URL redirects that slow down the loading process? Are all the images returned in a size that is compatible with the target device? What is the full URL of a broken link on the page? These questions can all be easily answered using a virtual device testing approach.
Each approach offers answers to certain types of testing questions. Using both techniques offers a holistic approach to mobile internet testing.
For example if the testing goal is to validate that the LCD "looks cosmetically correct", then the right approach is to test with the real device. Any type of virtual device could never mimic the exact behavior of the real handset.
On the other hand, what if you are testing with a real device and you receive the dreaded "Page Cannot Be Displayed" error? If you are testing with a real device, you can not quickly determine the root cause, but with a virtual device you could access the markup code of the returned page, as well as the headers of the content request. For these types of errors the virtual device is superior in finding the root cause of the problem.
There is also the issue of economics. To test with a real device you need physical access to that device. If you have multiple testers, and-or multiple groups doing testing in different geographies, then providing access to physical devices becomes problematic. You could "rent time" on remote devices, but the costs of this activity used for every single test case could quickly add up to huge amounts.
For certain types of test cases where "cosmetic accuracy" is not the goal of the test, a much cheaper testing model based on a virtual device can be used. Many types of content compatibility tests such as verifying image sizes, or identifying broken links can be accurately and quickly performed using the virtual device model. In most cases virtual device testing tools are downloaded and installed on your local PC. There is no hourly rental fee.
Lastly, the virtual device approach solves the "device scarcity" problem. What if you need to test on a device that has not been released? What if you need to test on a device that is brand new in the market place and because of demand, few real devices are available for purchase? These types of problems are also solved using the virtual device approach. The virtual device approach allows you to quickly define and configure new device "profiles". The speed of deployment is much faster than waiting for a scarce physical real device. Multiple testers can also share virtual device definitions so that scalability is achieved within the testing group.
Both approaches should be used in concert to create a testing methodology that is thorough, practical, and economical. In the same way that a mechanic or carpenter uses different tools for different purposes, so should the mobile testing group use a collection of tools in order to produce the highest quality result.
Comments