对于手机项目(应用软件),主要是进行系统测试。数据库
而针对手机应用软件的系统测试,咱们一般从以下几个角度开展测试工做:缓存
一、功能模块测试:根据软件需求说明书或者用户需求验证app的各个功能是否实现,采用以下方法实现并评估功能测试过程:安全
运行服务器
1)App安装完成后的试运行,可正常打开软件。网络
2)App打开测试,是否有加载状态进度提示。app
3)App打开速度测试,速度是否可观。框架
4)App页面间的切换是否流畅,逻辑是否正确post
5)注册性能
--同表单编辑页面
--用户名密码长度
--注册后的提示页面
--前台注册页面和后台的管理页面数据是否一致
--注册后,在后台管理中页面提示测试
6)登陆
--使用合法的用户登陆系统。
--系统是否容许屡次非法的登录,是否有次数限制。
--使用已经登录的帐号登录系统是否正确处理。
--使用禁用的帐号登录系统是否正确处理。
--用户名、口令(密码)错误或漏填时可否登录。
--删除或修改后的用户,原用户登录。
--不输入用户口令和用户、重复点(肯定或取消按钮)是否容许登录。
--登录后,页面中登录信息。
--页面中有注销按钮。
--登录超时的处理。
7)注销
--注销原模块,新的模块系统可否正确处理。
--终止注销可否返回原模块,原用户。
--注销原用户,新用户系统可否正确处理。
--使用错误的帐号、口令、无权限的被禁用的帐号进行注销
应用的先后台切换
1) APP切换到后台,再回到app,检查是否停留在上一次操做界面。
2) APP切换到后台,再回到app,检查功能及应用状态是否正常,IOS4和IOS5的版本的处理机制有的不同。
3) app切换到后台,再回到前台时,注意程序是否崩溃,功能状态是否正常,尤为是对于从后台切换回前台数据有自动更新的时候。
4) 手机锁屏解屏后进入app注意是否会崩溃,功能状态是否正常,尤为是对于从后台切换回前台数据有自动更新的时候。
5) 当App使用过程当中有电话进来中断后再切换到app,功能状态是否正常
6) 当杀掉app进程后,再开启app,app可否正常启动。
7) 出现必须处理的提示框后,切换到后台,再切换回来,检查提示框是否还存在,有时候会出现应用自动跳过提示框的缺陷。
8) 对于有数据交换的页面,每一个页面都必须要进行先后台切换、锁屏的测试,这种页面最容易出现崩溃。
免登陆
不少应用提供免登陆功能,当应用开启时自动以上一次登陆的用户身份来使用app.
1) app有免登陆功能时,须要考虑IOS版本差别。
2) 考虑无网络状况时可否正常进入免登陆状态。
3) 切换用户登陆后,要校验用户登陆信息及数据内容是否相应更新,确保原用户退出。
4) 根据MTOP的现有规则,一个账户只容许登陆一台机器。因此,须要检查一个账户登陆多台手机的状况。原手机里的用户须要被踢出,给出友好提示。
5) app切换到后台,再切回前台的校验
6) 切换到后台,再切换回前台的测试
7) 密码更换后,检查有数据交换时是否进行了有效身份的校验
8) 支持自动登陆的应用在进行数据交换时,检查系统是否能自动登陆成功而且数据操做无误。
9) 检查用户主动退出登陆后,下次启动app,应停留在登陆界面
数据更新
根据应用的业务规则,以及数据更新量的状况,来肯定最优的数据更新方案。
1) 须要肯定哪些地方须要提供手动刷新,哪些地方须要自动刷新,哪些地方须要手动+自动刷新。
2) 肯定哪些地方从后台切换回前台时须要进行数据更新。
3) 根据业务、速度及流量的合理分配,肯定哪些内容须要实时更新,哪些须要定时更新。
4) 肯定数据展现部分的处理逻辑,是每次从服务端请求,仍是有缓存到本地,这样才能有针对性的进行相应测试。
5) 检查有数据交换的地方,均有相应的异常处理。
离线浏览
不少应用会支持离线浏览,即在本地客户端会缓存一部分数据供用户查看。
1) 在无网络状况能够浏览本地数据
2) 退出app再开启app时能正常浏览
3) 切换到后台再切回前台能够正常浏览
4) 锁屏后再解屏回到应用前台能够正常浏览
5) 在对服务端的数据有更新时会给予离线的相应提示
App更新
1) 当客户端有新版本时,有更新提示。
2) 当版本为非强制升级版时,用户能够取消更新,老版本能正常使用。用户在下次启动app时,仍能出现更新提示。
3) 当版本为强制升级版时,当给出强制更新后用户没有作更新时,退出客户端。下次启动app时,仍出现强制升级提示。
4) 当客户端有新版本时,在本地不删除客户端的状况下,直接更新检查是否能正常更新。
5) 当客户端有新版本时,在本地不删除客户端的状况下,检查更新后的客户端功能是不是新版本。
6) 当客户端有新版本时,在本地不删除客户端的状况下,检查资源同名文件如图片是否能正常更新成最新版本。若是以上没法更新成功的,也都属于缺陷。
定位、照相机服务
1) App有用到相机,定位服务时,须要注意系统版本差别
2) 有用到定位服务、照相机服务的地方,须要进行先后台的切换测试,检查应用是否正常。
3) 当定位服务没有开启时,使用定位服务,会友好性弹出是否容许设置定位提示。当肯定容许开启定位时,能自动跳转到定位设置中开启定位服务。
4) 测试定位、照相机服务时,须要采用真机进行测试。
时间测试
客户端能够自行设置手机的时区、时间,所以须要校验该设置对app的影响。
--中国为东8区,因此当手机设置的时间非东8区时,查看须要显示时间的地方,时间是否展现正确,应用功能是否正常。时间通常须要根据服务器时间再转换成客户端对应的时区来展现,这样的用户体验比较好。好比发表一篇微博在服务端记录的是10:00,此时,华盛顿时间为22:00,客户端去浏览时,若是设置的是华盛顿时间,则显示的发表时间即为22:00,当时间设回东8区时间时,再查看则显示为10:00。
PUSH测试
1) 检查push消息是否按照指定的业务规则发送
2) 检查不接受推送消息时,检查用户不会再接收到push.
3) 若是用户设置了免打扰的时间段,检查在免打扰时间段内,用户接收不到PUSH。
在非免打扰时间段,用户能正常收到push。
4) 当push消息是针对登陆用户的时候,须要检查收到的push与用户身份是否相符,没有错误地将其它人的消息推送过来。通常状况下,只对手机上最后一个登陆用户进行消息推送。
5) 测试push时,须要采用真机进行测试。
二、交叉事件测试:又叫事件冲突测试,是指一个功能正在执行过程当中,同时另一个事件或操做对该过程进行干扰测试。如:App在前/后台运行状态时与来电、文件ixaz、音乐收听等关键运用的交互状况测试等。
执行干扰的冲突事件不能致使软件应用软件异常、手机死机或者花屏等严重问题,还须要注意各交叉事件的优先级别,检验系统是否能依据各事件的优先级别依次进行处理。不能因执行优先级别高的事件而致使优先级别较低的事件吊死。另外有中英文模式切换的手机要注意中英文模式切换后的功能实现存在的问题。
三、性能测试:评估App的时间和空间特性 ;
--内存满时安装App
--运行App时手机断电
--运行App时断掉网络
--App安装、卸载的响应时间
--App各种功能性操做的影响时间
--App反复进行安装卸载,查看系统资源是否正常
--其余功能反复进行操做,查看系统资源是否正常
四、安全测试:
--扣费风险:包括发送短信、拨打电话、链接网络等
--隐私泄露风险:包括访问手机信息、访问联系人信息等
--对App的输入有效性校验、认证、受权、敏感数据存储、数据加密等方面进行检测
--限制/容许使用手机功能接人互联网
--限制/容许使用手机发送接受信息功能
--限制/容许应用程序来注册自动启动应用程序
--限制或使用本地链接
--限制/容许使用手机拍照或录音
--限制/容许使用手机读取用户数据
-- 限制/容许使用手机写人用户数据
--检测App的用户受权级别、数据泄漏、非法受权访问等
--应用程序应能正确安装到设备驱动程序上
--可以在安装设备驱动程序上找到应用程序的相应图标
--是否包含数字签名信息
--JAD文件和JAR包中包含的全部托管属性及其值必需是正确的
--JAD文件显示的资料内容与应用程序显示的资料内容应一致
--安装路径应能指定
--没有用户的容许, 应用程序不能预先设定自动启动
--卸载是否安全, 其安装进去的文件是否所有卸载
--卸载用户使用过程当中产生的文件是否有提示
--其修改的配置信息是否复原
--卸载是否影响其余软件的功能
--卸载应该移除全部的文件
--当将密码或其余的敏感数据输人到应用程序时, 其不会被储存在设备中, 同时密码也不会被解码
--输人的密码将不以明文形式进行显示
--密码, 信用卡明细, 或其余的敏感数据将不被储存在它们预输人的位置上
--不一样的应用程序的我的身份证或密码长度必需至少在4一8 个数字长度之间
--当应用程序处理信用卡明细, 或其余的敏感数据时, 不以明文形式将数据写到其它单独的文件或者临时文件中。以
--防止应用程序异常终止而又没有侧除它的临时文件, 文件可能遭受人侵者的袭击, 而后读取这些数据信息。
--当将敏感数据输人到应用程序时, 其不会被储存在设备中
--备份应该加密, 恢复数据应考虑恢复过程的异常通信中断等, 数据恢复后再使用前应该通过校验
--应用程序应考虑系统或者虚拟机器产生的用户提示信息或安全替告
--应用程序不能忽略系统或者虚拟机器产生的用户提示信息或安全警告, 更不能在安全警告显示前,,利用显示误导信息欺骗用户,应用程序不该该模拟进行安全警告误导用户
--在数据删除以前,应用程序应当通知用户或者应用程序提供一个“取消”命令的操做
--"取消” 命令操做可以按照设计要求实现其功能
--应用程序应当可以处理当不容许应用软件链接到我的信息管理的状况
--当进行读或写用户信息操做时, 应用程序将会向用户发送一个操做错误的提示信息
--在没有用户明确许可的前提下不损坏侧除我的信息管理应用程序中的任何内容Μ
--应用程序读和写数据正确。
--应用程序应当有异常保护。
--若是数据库中重要的数据正要被重写, 应及时告知用户
--能合理地处理出现的错误
--意外状况下应提示用户
--在运行其软件过程当中, 若是有来电、SMS、EMS、MMS、蓝牙、红外等通信或充电时, 是否能暂停程序,优先处理通讯, 并在处理完毕后能正常恢复软件, 继续其原来的功能
--当创立链接时, 应用程序可以处理由于网络链接中断, 进而告诉用户链接中断的状况
--应能处理通信延时或中断
--应用程序将保持工做到通信超时, 进而发送给用户一个错误信息指示有链接错误
--应能处理网络异常和及时将异常状况通报用户
--应用程序关闭或网络链接再也不使用时应及时关闭) 断开
-- HTTP、HTTPS覆盖测试
--App和后台服务通常都是经过HTTP来交互的,验证HTTP环境下是否正常;
--公共免费网络环境中(如:麦当劳、星巴克等)都要输入用户名和密码,经过SSL认证来访问网络,须要对使用HTTP Client的library异常做捕获处理。
--返回菜单总保持可用
--命令有优先权顺序
--声音的设置不影响应用程序的功能
--应用程序必需利用目标设备适用的全屏尺寸来显示上述内容
--应用程序必需可以处理不可预知的用户操做, 例如错误的操做和同时按下多个键
五、容量测试:即存储空间已满时的测试,包括手机用户可用内存和SIM卡的全部空间被完成使用的测试。此时再对可编辑的模块进行和存储空间有关的任何操做测试,若是软件在极限容量状态下处理很差,有可能致使死机或严重的花屏等问题出现。
六、兼容性测试:也就是不一样系统框架,不一样品牌、款型、分辨率的手机,不呕吐那个网络,不一样容量大小的SIM卡之间的互相兼容测试。
--与本地及主流App是否兼容
--基于开发环境和生产环境的不一样,检验在各类网络链接下(WiFi、GSM、GPRS、EDGE、WCDMA、CDMA1x、CDMA2000、HSPDA等),App的数据和运用是否正确
--与各类设备是否兼容,如有跨系统支持则须要检验是否在各系统下,各类行为是否一致
--不一样操做系统的兼容性,是否适配
--不一样手机屏幕分辨率的兼容性
--不一样手机品牌的兼容性
七、接口测试:服务端通常会提供JSON格式的数据给客户端,因此咱们在服务端须要进行接口测试,确保服务端提供的接口并转换的JSON内容正确,对分支、异常流有相应的返回值。此块测试能够采用itest框架进行测试。最方便的是采用httpclient进行接口测试。
进行服务端测试时,须要开发提供一份接口文档。
八、易用性/用户体验测试:易用性这个这里就不说了你们都知道。
用户体验测试:以主观的普通消费者的角度去感知产品或服务的温馨、有用、易用、友好亲切程度。 经过不一样个体、独立空间和非经验的统计复用方式去有效评价产品的体验特性提出修改意见提高产品的潜在客户满意度。
九、硬件环境测试:
--手机开锁屏对运行中的App的影响
--切换网络对运行中的App的影响
--运行中的App先后台切换的影响
--多个运行中的App的切换
--App运行时关机
--App运行时重启系统
--App运行时充电
--App运行时kill掉进程再打开
手机的网络目前主要分为2G、3G、wifi。目前2G的网络相对于比较慢,测试时尤为要注意此块的测试。
--无网络时,执行须要网络的操做,给予友好提示,确保程序不出现crash。
--内网测试时,要注意选择到外网操做时的异常状况处理。
-- 在网络信号很差时,检查功能状态是否正常,确保不因提交数据失败而形成crash。
--在网络信号很差时,检查数据是否会一直处于提交中的状态,有无超时限制。如遇数据交换失败时要给予提示。
--在网络信号很差时,执行操做后,在回调没有完成的状况下,退出本页面或者执行其余操做的状况,有无异常状况。此问题也会常常出现程序crash。
后台服务牵涉到DNS、空间服务商的状况下会影响其稳定性,如:当出现域名解析故障时,你对后台API的请求极可能就会出现404错误,抛出异常。这时须要对异常进行正确的处理,不然可能会致使程序不能正常工做。
十、安装/卸载测试:验证App是否能正确安装、运行、卸载以及操做过程和操做先后对系统资源的使用状况。
--软件在不一样操做系统(Palm OS、Symbian、Linux、Android、iOS、Black Berry OS 6.0、Windows Phone 7)下安装是否正常。
--软件安装后的是否可以正常运行,安装后的文件夹及文件是否写到了指定的目录里。
--软件安装各个选项的组合是否符合概要设计说明
--软件安装向导的UI测试
--软件安装过程是否能够取消,点击取消后,写入的文件是否如概要设计说明处理
--软件安装过程当中意外状况的处理是否符合需求(如死机,重启,断电)
--安装空间不足时是否有相应提示
--安装后没有生成多余的目录结构和文件
--对于须要经过网络验证之类的安装,在断网状况下尝试一下
--还须要对安装手册进行测试,依照安装手册是否能顺利安装
--直接删除安装文件夹卸载是否有提示信息。
--测试系统直接卸载程序是否有提示信息。
--测试卸载后文件是否所有删除全部的安装文件夹。
--卸载过程当中出现的意外状况的测试(如死机、断电、重启)。
--卸载是否支持取消功能,单击取消后软件卸载的状况 。
--系统直接卸载UI测试,是否有卸载状态进度条提示 。
十一、升级/更新测试:新版版发布后,配合不一样网络环境的自劢更新提示及下载、安装、更新、启劢、运行的验证测试。