zoukankan      html  css  js  c++  java
  • APP移动测试

    (转自网络)

    App测试与传统台式机测试相比有一定的复杂性。这些复杂性可以被分类为:
      环境(大量的设备,各种移动OSs,适应频繁OSs变化) 。
      设备(触摸式和非触摸式设备,有限的内存容量,电池耗电量) 。
      网络(不同的网络和运营商,在不好或无网络的情况下的App行为,离线支持) 。
      可用性(方向,触摸,多触摸,缩放,分页和导航的局限性,各种干扰,如来电,来电短信,闹钟,和低电量警报) 。

    一、首先是测试资源确认及准备 

    1.1 

    产品需求文档、产品原型图、接口说明文档以及设计说明文档等应齐全;

    1.2  

    测试设备及工具的准备:IOS和andriod不同版本的真机,以及相关测试工具的准备。

    二、测试用例的设计与评审

    (1)根据产品需求文档、产品原型图等文档,设计客户端的一般功能测试用例;

    (2)测试用例评审、修改与完善,评审通过后着手进入正式测试阶段。

    三、测试

    (一)UI测试

    (1)确保手头的原型图与效果图为当前最新版本,符合产品经理及用户要求;

    (2)测试过程中一切以效果图为准,若有用户体验方面的建议,可以先以邮件的形式与产品经理确认,确认通过后,可以正式向开发提出用户体验方面的问题;

    (3)由于测试环境中的数据为模拟数据,测试时必须预先考虑到正式环境中可能出现的数据类型。

    (二)功能测试

    (1)功能测试时主要依据编写的功能测试用例进行软件功能的遍历;

    (2)涉及的测试主要包括基本功能测试,安装、卸载、运行测试,异常处理(包括网络突然断开或者网速过慢、机器内存不足等异常情况的处理)测试。

    (三)中断测试

    (1)软件运行过程中接电话、收短信、锁屏、闹铃、充电,收到通知提醒后再使用软件,软件应仍可正常运行使用;

    (2)软件运行时,由前台切换到后台,再切回前台后,应仍可正常运行使用。

    (四)兼容性及适配测试

    (1)硬件的适配:不同手机厂商、硬件性能,不同屏幕大小的适配;

    (2)OS版本的兼容:IOS6-9;Andriod3以上等,如果用了一些新的API在老的系统上不支持会导致crash;

    (3)不同分辨率屏幕的适配:移动设备的分辨率多种多样,如果APP没有做比较合适的处理就可能会显示不好,甚至影响功能的操作。

    (4)兼容性测试必须在一定数量的真机上进行,由于真机类型过多,尤其Android在做兼容性测试时,可以选取典型的几种运用较多的真机,进行兼容性测试;

    (5)另外可以借助开源测试testin云测,进行更多机型的兼容性测试,testin云测提供基本的运行情况和一些截图,以及简单的测试报告,有助于扩大测试的范围。

    (五)性能测试

    (1)客户端性能测试重点关注:安装卸载时间、启动时间、页面加载时间、主要功能占用的CPU、内存、流量、耗电量等,以及与同类产品相比较是否有优势;

    (2)其中页面加载时间可以利用Android调试工具DDMS获取到,在DDMS里面搜索Displayed关键字就可以看到页面加载时间;

    (3)运行过程中主要功能占用的CPU、内存、流量等可以借助开源工具emmagee(适用于Android)获取到;

    (4)至于服务器端的性能,主要利用接口对服务器施加压力,重点关注响应时间、吞吐量、并发数、事物通过率等,可以视同工具loadrunner、jmeter进行测试。

    (六)稳定性测试

    (1)安卓APP的稳定性常常使用monkey命令进行测试,通过随机事件流模拟人的操作,对检查程序的内存溢出、空指针有很大的作用。

    (2)Monkey主要用来检测系统ANR及Crash等问题

    (七)其他

    (1)验证设备内存不足时App的表现

    (2)用不同的支持语言验证App行为

    (3)不同网络类型间的切换验证App的行为

     

    四、测试分析及测试报告输出

      以上各项测试结束后,应该形成完整的分析及报告文档(包括buglist、性能及稳定性结果分析,版本上线风险分析等内容),输出给各项相关人员。

    五、移动端测试用例的实践经验

      每种测试方法其实都有一个最佳测试时间,如在版本测试阶段,我们应当要先做基本功能测试,边界分析测试和中断,交互功能测试,快速发现bug提单给开发去快速修复,保证主体功能可以尽快得到保证,而不是一开始就先纠结与性能,压力和兼容测试。一方面这类测试往往所消耗的时间会很长,降低了发现bug的速度,另一方面先做这部分测试后,再去发现主体功能的bug,那么在开发人员动了大量代码之后,还是要再执行一遍性能,压力和兼容测试的相关用例,不仅劳命伤财,效果还事倍功半。

      所以在实际项目测试中,当前我们的项目将测试内容分为功能测试,兼容性测试,性能测试,稳定性测试四项,分别在不同的测试阶段进行(具体排期在测试计划时确定):

    (1)功能测试 —— 版本测试阶段

      (2)兼容性测试 —— 回归测试阶段前期

      (3)性能测试 —— 回归测试阶段,版本功能稳定后执行

      (4)稳定性测试 —— 贯穿整个测试阶段,每晚执行monkey

    总结

    APP页面类型功能的测试点,大致如下:

      1. UE体验

      (1)布局与交互图保持一致

      (2)真机效果与UE图没有视觉上的严重偏差,如字号,字体大小,加粗,字体颜色,行高,行间距,按钮摆放位置,间隔,尺寸等。

      (3)资源图正确使用,没有不必要的拉伸,压缩或其他效果。

      (4)各种提示,文字通顺不产生歧义,展示符合用户使用习惯。

      (5)动画效果不卡顿,正常展现。

      2. 页面操作

      (1)是否有防重复点击,即连续快速点击不会出现多个页面或弹窗

      (2)单指滑动,单指单击,单指双击,单指长按,单指缩放,多指点击

      (3)摇一摇,横竖屏切换,前后台切换

      (4)长时间使用,长时间放在后台

      3. 不同场景下的页面操作

      (1)不同网络,弱网下的页面跳转,点击响应的展现效果

      (2)修改本地参数后的页面操作展现效果,如修改日期,时间,时区,语言,键盘等

      (3)修改系统权限后的页面操作展现效果,如打开关闭定位,摄像,照片,通讯录等的授权等

      (4)页面操作过程中有系统打断,如来电,短信,闹钟提醒,日历提醒,蓝牙提醒,插拔数据线,插拔耳机,待机,锁屏,低电量提醒等

      (5)页面操作过程中进行前后台切换,如当页面数据交换时,有弹窗,提示框的时机进行切换容易发现问题。

      (6)针对非主线程调用的接口,前端要对异常及无网络情况做异步处理,不提示异常且不影响主线程操作。

      4. 页面数据获取和展现

      (1)页面是否有缓存,缓存机制是怎样的,缓存的内容有哪些

      (2)在提交页面数据失败后是否有重试机制,重试的接口参数是否保持不变

      (3)在页面操作过程中,异步接口返回的内容,是否对用户透明(客户端兼容忽略请求返回msg)

      (4)在页面操作过程中,对于接口返回的异常数据,客户端需兼容,保证程序不crash。

  • 相关阅读:
    Database mirroring connection error 4 'An error occurred while receiving data: '10054(An existing connection was forcibly closed by the remote host.)
    [转载]——Automatic Tuning of Undo_retention Causes Space Problems (文档 ID 420525.1)
    [转载]——Full UNDO Tablespace In 10gR2 and above (文档 ID 413732.1)
    SQL Server Agent作业执行CmdExec(bat)命令报权限问题
    SQL Server有意思的数据类型隐式转换问题
    pymssql的Connection相关特性浅析
    pymssql默认关闭自动模式开启事务行为浅析
    Azure上MySQL的离线备份:将备份拷贝到Azure Blob上
    crontab中部署Python脚本注意事项
    TypeError: expected string or bytes-like object
  • 原文地址:https://www.cnblogs.com/czhang2-12/p/9648248.html
Copyright © 2011-2022 走看看