Android 和 iOS APP 测试的区别

本贴最后更新于 1429 天前,其中的信息可能已经时移世异

目前市面上主流的移动操作系统就是Android和iOS两种,移动端测试本身就跟web应用测试有自己的专项测试,比如安装、卸载、升级、消息推送、网络类型测试、弱网测试、中断测试、兼容性测试等都是区别于web应用需要关注的测试领域。那么,对于Android和iOS两个系统来说,测试同一款APP,又有哪些区别呢?

首先,关于功能实现以及界面测试等方面,两个系统基本是一致的;只是由于系统的某些实现方式的区别,导致了个别测试领域的区别。所以,我们接下来分析一下这两种系统之间的测试区别到底有哪些?

1、安装测试

测试版本安装

Android非常简单,提供一个apk包,就可以在任何设备上安装这个APP并进行测试了;

iOS比较复杂一些,没有经过苹果审核是不允许安装的;所以需要安装测试版本,就需要采取一些额外的手段,比如手动添加UDID到开发者账号,或者使用testflight工具,具体操作,可以见之前的一篇文章【附上之前文章的链接】

线上版本安装

Android可以上传的应用商店比较多,比如谷歌商店,360商店,安智市场等,还有各大应用管家都可以上传并提供给广大android用户下载使用;所以,测试人员对Android应用的线上测试需要覆盖所有支付的渠道;

iOS众所周知,只有一个苹果官方的App Store可以下载安装应用,其他的渠道都是不允许的。因为需要上传到线上发布,是需要苹果进行审核和授权的,而且一般审核周期要等到3天-2周不等。所以,iOS测试人员,需要等到苹果审核通过之后,从App Store上下载应用,验证线上版本的可用性。

2、兼容性测试

Android

因为系统被开源,很多不同厂商在这个基础上二次进行开发,所以导致出现的操作系统类型以及版本都非常多,比较常见主流的有:华为、小米、OPPO,Vivo等,还有很多比较小众非主流的操作系统;而且每个系统都有很多的版本,包括大版本和小版本;以及每个厂商的手机屏幕大小也差异比较大,所以Android APP的兼容性测试就会比较复杂一些;

iOS

就只有单一的苹果系统,虽然也经常更新版本,但是随着苹果官方系统版本的升级,一般我们只需要维护最新的几个主流版本的兼容性测试即可;选取的主流系统版本,再覆盖iOS的几款主流的屏幕大小的机型,兼容性测试会相对来说简单很多。

2、升级测试

升级测试ios限制也比Android多一些。

iOS有严格的降级限制,最开始只能单向升级,不能降级;虽然松懈了一点可以做降级操作,但是也限制了特定机型的最低降级版本,比如iPhone X最多只能降到iOS 11.2,iPhone 5最多可以降到iOS 6.1.3,之所以有这个限制其实是因为通常新的ios系统版本中的资源库不能完全兼容低版本中的应用,低版本ios系统中的应用如果调用了新系统中的资源库,有时会直接导致闪退(Crash)出现;所以,我们做iOS的升级测试的时候,基本只需要关注对应的版本之间的升级即可。

Android系统的降级限制没有那么严格,通过一定的工具都可以降级成功。

3、权限测试

Android众所周知的就是Android的个人信息泄露比较严重的,比如很多app在安装时会要求很多权限,Android系统会提示是否允许获取手机的某个权限,但是即使用户不给,Android也有各自手段偷偷的获取这些权限,所以Android APP的这种权限测试不是很严苛;

ios一般情况下权限管理的很严格,用户没有同意的权限,APP是一定没有办法绕过并获取的,所以应用不会去获取一些没有意义的权限;而且应用要上线苹果商店时,苹果官方的审核机制也是比较严格,经常会出现审核不通过的情况。所以ios的权限一般情况下会要的很少。因此,iOS测试的权限场景较少,但是会很严格。

4、应用实现的机制

Android采用的虚拟机机制,而iOS采用的是沙盒机制。

虚拟机机制的特点是:

  1. 每个应用程序都在独立的虚拟机中,这些独立的虚拟机实例都是一个独立的进程空间。
  2. 跟linux内存管理很相似,是真正的多进程管理,虽然可用内存最后看着少,但是实际上很多程序已经分配了一定的内存了,在唤起时不会再次分配一次,而且已经有了缓存,启动和响应会比较快。

沙盒机制的特点是:

  1. 应用程序在自己的沙盒中运作,但是不能访问任何其他应用程序的沙盒;
  2. 应用之间不能共享数据,沙盒里的文件不能被复制到其他应用程序的文件夹中,也不能把其他应用文件夹复制到沙盒中;
    3)苹果禁止任何读写沙盒以外的文件,禁止应用程序将内容写到沙盒以外的文件夹中;

5、安全机制

iOS安全机制主要通过一下两个方面来实现:

  1. 通过刚刚上面讲到的**“安全沙箱**” 机制来实现安全机制。应用之间数据和文件不能共享;
  2. 通过对代码签名,Apple需要所有开发人员对自己的iPhone应用程序使用数字签名技术。这个签名用来标识应用程序的开发者以及保证应用程序在签名之后不被更改和损坏。开发者证书由Apple提供(这是与android最大的区别,android是自签名),有以下两类证书:

Developer Certificate :用于本机测试

Distribution Certificate :用于100台设备以内的测试和共享;App Store用于发布应用程序所有的可执行文件、库文件都需要Apple签名后才可以运行在iOS中。

Android安全机制通过以下两个方面来实现:

  1. 虚拟机机制,每一个Android应用程序(apk文件)会在安装时分配一个独有的linux用户ID(即一个用户id识别一个应用程序),使其不能与其他应用程序进行接触。这个用户ID在安装时分配,并在该设备上一直保持同一个数值。所有存储在应用程序中的数据都会赋予该应用程序的用户ID,使其他应用程序无法访问这些数据。
  2. 代码签名,但是跟iOS不一样的是,Android采用自签名机制,不需要权威机构签名和审核,完全由用户自行判断是否信任该程序。

总结

综上所述我们可以发现,由于近些年这两个系统之前不断的相互借鉴的原因,在设计上来说越来越通用,两个平台的使用体验也越老越比较统一,所以网上很多文章说的关于一些界面设计风格、用户使用习惯的区别,我觉得也没有特别大的参考价值。作为测试,我们可有多关注一些底层实现的原理,能够帮助我们更加深刻的理解他们在细节实现上,从而就可以帮助我们测试更加充分!

回帖
请输入回帖内容 ...