Testing iOS testing on real devices vs. Simulator

2019-07-15 14:02发布

问题:

I am new to iPhone/iPad development and I am close to finishing up my first app and I am looking for some general advice.

I know it is important to test on actual devices and not just the simulator. What are the types of things people generally encounter when testing on a deal device that they don't see in the simulator?

The app itself is mainly a way to track online deals and that type of thing. It doesn't need anything special in term of using things like the camera or GPS.

回答1:

It's just general usage testing. The device performs in an entirely different environment than your computer, and it's the best way to make sure if you push your app out to devices, that nothing unexpected will happen. For example, the phone/pad may have limited data coverage, low memory situations, incoming calls etc.. These situations are a lot more common on devices, then when people emulate it though the simulator.

On a hardware point of view, the device uses a different processor architecture than your Mac, which also needs to be accounted for (not as much as other cases, but you need to cover your bases). The Mac also cannot reliably emulate RAM, Disc Space, Processor Speed etc...hence testing on the device is useful here also.

Obviously there are some features you can only test on devices, such as Camera, GPS (and not so obviously iPod library usage), and if your app uses them it'd be careless not to test on a device.

Overall if you're intending to release your application to the App Store, or to devices at least, it's worth testing on the device itself. Only then can you be sure that it will act and perform as expected on the platform you intend to target. The simulator is only a simulator after all, not the real thing!



回答2:

First of all: the user experience is very different.

The mouse based interaction is very different from a touch interaction. focusing at a monitor feels very different then looking on a device on the palm of your hand.

Also the experience of animations running on the simulator and the real device can be very different.

And the usage in the simulator won't tell you anything about the battery consumptions to be witnessed on the real device.

My opinion: every app that will be shipped to the App Store or customer for testing should be tested several different real devices. No excuses.



回答3:

  • In app purchases, if you have included them
  • Orientations (not that they are unavailable on simulator, but it is easy to forget it there!)
  • App life cycle testing - bringing your app to foreground and background.
  • Network access - can matter when you access the network from device through wireless or cellular network vs LAN/wifi on your mac. There is a huge testing to be done under the umbrella called Reachability if your app uses any of the resources across the net. You are bound to provide an alert if network is unreachable before using any such resources, as per app store requirements.


回答4:

  • Simulator runs a lot slower than the real device.
  • Real device could run out of memory when Simulator doesn't or vice versa.