目前市面上主流的移动操作系统就是 Android 和 iOS 两种,移动端测试本身就跟 Web 应用测试有自己的专项测试,比如安装、卸载、升级、消息推送、网络类型测试、弱网测试、中断测试、兼容性测试等都是区别于 Web 应用需要关注的测试领域。
那么,对于 Android 和 iOS 两个系统来说,测试同一款 APP,又有哪些区别呢?
首先,关于功能实现以及界面测试等方面,两个系统基本是一致的;只是由于系统的某些实现方式的区别,导致了个别测试领域的区别。所以,我们接下来分析一下这两种系统之间的测试区别到底有哪些?
一、安装测试
测试版本安装
Android 非常简单,提供一个 apk 包,就可以在任何设备上安装这个 APP 并进行测试了。
iOS 比较复杂一些,没有经过苹果审核是不允许安装的。
需要安装测试版本,就需要采取一些额外的手段,比如手动添加 UDID 到开发者账号,或者使用 testflight 工具,具体操作,可以见之前的文章:《iOS APP测试方法和测试工具大揭秘》
线上版本安装
Android 可以上传的应用商店比较多,比如谷歌商店,360 商店,安智市场等,还有各大应用管家都可以上传并提供给广大 Android 用户下载使用。
所以,测试人员对 Android 应用的线上测试需要覆盖所有支付的渠道;
iOS 众所周知,只有一个苹果官方的 App Store 可以下载安装应用,其他的渠道都是不允许的。因为需要上传到线上发布,是需要苹果进行审核和授权的。
而且一般审核周期要等到 3 天-2 周不等。所以,iOS 测试人员,需要等到苹果审核通过之后,从 App Store 上下载应用,验证线上版本的可用性。
如果你想学习自动化测试,我这边给你推荐一套视频,这个视频可以说是B站播放全网第一的自动化测试教程,同时在线人数到达1000人,并且还有笔记可以领取及各路大神技术交流:798478386
二、兼容性测试
因为系统被开源,很多不同厂商在这个基础上二次进行开发,所以导致出现的操作系统类型以及版本都非常多。
常见的有:华为、小米、OPPO,vivo 等,
还有很多小众非主流的操作系统;
每个系统都有很多的版本,包括大版本和小版本;
每个厂商的手机屏幕大小也差异比较大,
所以 Android APP 的兼容性测试就会比较复杂一些。
就只有单一的苹果系统,虽然也经常更新版本。
但是随着苹果官方系统版本的升级,一般我们只需要维护最新的几个主流版本的兼容性测试即可;选取的主流系统版本,再覆盖 iOS 的几款主流的屏幕大小的机型,兼容性测试会相对来说简单很多。
三、升级测试
升级测试 iOS 限制也比 Android 多一些。
iOS 有严格的降级限制,最开始只能单向升级,不能降级;虽然松懈了一点可以做降级操作,但是也限制了特定机型的最低降级版本。
比如 iPhone X 最多只能降到 iOS 11.2,iPhone 5 最多可以降到 iOS 6.1.3,之所以有这个限制其实是因为通常新的 iOS 系统版本中的资源库不能完全兼容低版本中的应用。
低版本 iOS 系统中的应用如果调用了新系统中的资源库,有时会直接导致闪退(Crash)出现;所以,我们做 iOS 的升级测试的时候,基本只需要关注对应的版本之间的升级即可。
Android 系统的降级限制没有那么严格,通过一定的工具都可以降级成功。
四、权限测试
Android 众所周知的就是 Android 的个人信息泄露比较严重的。
比如很多 app 在安装时会要求很多权限,Android 系统会提示是否允许获取手机的某个权限,但是即使用户不给,Android 也有各自手段偷偷的获取这些权限,所以 Android APP 的这种权限测试不是很严苛;
而 iOS 一般情况下权限管理的很严格,用户没有同意的权限,APP 是一定没有办法绕过并获取的,所以应用不会去获取一些没有意义的权限;而且应用要上线苹果商店时,苹果官方的审核机制也是比较严格,经常会出现审核不通过的情况。
所以 iOS 的权限一般情况下会要的很少。因此,iOS 测试的权限场景较少,但是会很严格。
五、应用实现的机制
Android 采用的虚拟机机制,而 iOS 采用的是沙盒机制。
虚拟机机制的特点是:
每个应用程序都在独立的虚拟机中,这些独立的虚拟机实例都是一个独立的进程空间。
跟 Linux 内存管理很相似,是真正的多进程管理,虽然可用内存最后看着少,但是实际上很多程序已经分配了一定的内存了,在唤起时不会再次分配一次,而且已经有了缓存,启动和响应会比较快。
沙盒机制的特点是:
应用程序在自己的沙盒中运作,但是不能访问任何其他应用程序的沙盒;
应用之间不能共享数据,沙盒里的文件不能被复制到其他应用程序的文件夹中,也不能把其他应用文件夹复制到沙盒中;
苹果禁止任何读写沙盒以外的文件,禁止应用程序将内容写到沙盒以外的文件夹中。
六、安全机制
iOS 安全机制主要通过以下两个方面来实现:
通过刚刚上面讲到的安全沙箱机制来实现安全机制。应用之间数据和文件不能共享;
通过对代码签名,Apple 需要所有开发人员对自己的 iPhone 应用程序使用数字签名技术。这个签名用来标识应用程序的开发者以及保证应用程序在签名之后不被更改和损坏。开发者证书由 Apple 提供(这是与 Android 最大的区别,Android 是自签名),有以下两类证书:
Developer Certificate :用于本机测试
Distribution Certificate :用于 100 台设备以内的测试和共享;App Store 用于发布应用程序所有的可执行文件、库文件都需要 Apple 签名后才可以运行在 iOS 中。
Android 安全机制通过以下两个方面来实现:
虚拟机机制,每一个 Android 应用程序(apk 文件)会在安装时分配一个独有的 Linux 用户 ID(即一个用户 id 识别一个应用程序),使其不能与其他应用程序进行接触。这个用户 ID 在安装时分配,并在该设备上一直保持同一个数值。所有存储在应用程序中的数据都会赋予该应用程序的用户 ID,使其他应用程序无法访问这些数据。
代码签名,但是跟 iOS 不一样的是,Android 采用自签名机制,不需要权威机构签名和审核,完全由用户自行判断是否信任该程序。
总结
综上所述我们可以发现,由于近些年这两个系统之前不断的相互借鉴的原因,在设计上来说越来越通用,两个平台的使用体验也越来越统一。
所以网上很多文章说的关于一些界面设计风格、用户使用习惯的区别,我觉得也没有特别大的参考价值。
作为测试,我们可有多关注一些底层实现的原理,能够帮助我们更加深刻的理解他们在细节实现上,从而就可以帮助我们测试更加充分!