手机APP测试(测试点、测试流程、功能测试)

手机APP测试(测试点、测试流程、功能测试)1、功能测试1.1启动APP安装完成后,是否可以正常打开,稳定运行APP的速度是可以让人接受,切换是否流畅网络异常时,应用是否会崩溃:在请求超时的情况下,如果程序逻辑处理的不好,就有可能发生

大家好,又见面了,我是你们的朋友全栈君。

<span role="heading" aria-level="2">手机APP测试(测试点、测试流程、功能测试)

 

1、功能测试

<span role="heading" aria-level="2">手机APP测试(测试点、测试流程、功能测试)

1.1 启动

APP安装完成后,是否可以正常打开,稳定运行

APP的速度是可以让人接受,切换是否流畅

网络异常时,应用是否会崩溃:在请求超时的情况下,如果程序逻辑处理的不好,就有可能发生Crash。

1.2 注册、登录

1.2.1 账号密码注册登录

正向:输入正确的账号密码、Enter键,可正常注册和登录

逆向:输入的数据前存在空格;用户名、密码错误或漏填;已注册用户;是否允许多次非法登录;是否限制次数;未注册用户登录;删除或修改后用户登录;是否有注销按钮;

逆向:密码更改后,登录时是否做到了有效数据的校验:修改前的密码失效;

逆向:未登录时对一些页面的操作,是否做了控制

逆向:密码“****”展示(安全性)

逆向:账号输入框对最大长度和格式应有校验(比如邮箱账号需要邮箱格式等)

逆向:账号或密码输入错误时建议提示“账号或密码错误”,而不是“账号错误”或“密码错误”

逆向:登陆后,页面中登陆信息是否正确;

逆向:不输入用户密码或者是重复点击“确定/取消”按钮,是否允许登陆;

逆向:支持自动登录(记住密码)的应用在进行数校验时,检查系统是否能自动登录成功并且数据操作无误

逆向:考虑无网络情况下能否正常进入免登陆状态。

逆向:检查用户主动退出登录后,下次启动APP,应停留在登录页面。

逆向:登录超时时处理是否合理

逆向:页面中是否有注销按钮;

逆向:密码是否加密传输(可抓取请求查看)

逆向:切换账号登录,检验登录的信息是否做到及时更新

逆向:对于多个端都进行操作时,确保数据库操作无误,且每个端可以及时看到数据的更新

逆向:台式机和手机的同时登录同一账号,多台手机的同时登录同一账号(检查是否将原用户剔除)

1.2.2 手机号注册登录

手机号输入框格式校验检查

验证短信的接收是否及时;

用验证码可正常登录;

验证码错误时,登录失败+友好提示

验证短信文案是否符合所测APP;

重复发送验证码,前一个验证码正常失效

频繁操作验证码发送,应有操作限制

检查对登陆超时(验证码不能用)的处理。

验证码有效期校验(超过有效期无法登录)

1.2.3 注册

表单编辑页面测试;

用户名密码长度;

注册后的提示页面;

前台注册页面和后台的管理页面数据是否一致

注册后,在后台管理系统中的页面提示以及数据库中的用户信息是否正常;

1.3 所有功能是否能正常运行

业务逻辑测试:主要测试客户端业务是否正常完成

功能点测试:主要测试客户端功能点是否可以正常使用,对具体功能点一一测试,确保每个点都能正确实现相应功能。

关联行测试:主要测试客户端与PC端的交互,客户端处理完后,PC端与客户段数据一致

1.4 应用的前后台切换是否正常

    APP切换到后台,再回到APP,检查是否停留在上一次操作界面。

  APP切换到后台,再回到APP,检查功能及应用状态是否正常。

  APP切换到后台,再回到APP前台时,注意程序是否奔溃,功能状态是否正常,尤其是对于从后台切换回前台数据有自动更新的时候。

  手机锁屏解锁后进入APP注意是否会奔溃,功能状态是否正常,尤其是对于从后台切换回前台数据有自动更新的时候。

  当APP使用过程中有电话进来中断后再切换到APP,功能状态是否正常。

  当杀掉APP进程后,再开启APP,APP能否正常启动。

  出现必须处理的提示框后,切换到后台,再切换回来,检查提示框是否还存在,有时候会出现应用自动跳过提示框的缺陷。

  对于有数据交换的页面,每个页面都必须要进行前后台切换、锁屏的测试,这种页面最容易出现奔溃的现象。

1.5 数据更新

1.6 离线浏览

  在无线网络情况下可以浏览本地数据。

  退出APP再开启APP时能正常浏览本地数据。

  切换到后台再回到前台可以正常浏览本地数据。

  锁屏后再解锁回到应用前台可以正常浏览本地数据。 

  手动刷新时,是否有对连接网络的提示 

1.7 定位,照相机服务等等

1.8 时间测试

1.9 Push测试

  检查push消息是否按照指定的业务规则发送。

 检查不接收推送消息时,用户不会再接收到push消息。

 如果用户设置了免打扰的时间段,检查在免打扰时间段内,用户接收不到push消息;

  在非免打扰时间段内,用户能正常接收到push消息。

 当push消息是针对登录用户的时候,需要检查收到的push消息与用户身份是否相符。

 不打开应用时,能否接收消息

 打开应用时,能否接收消息

 登录与不登录情况下,接收消息是否有区别

 精确推送,是否只推送给指定用户

1.10 界面测试

1.窗体

  测试窗体的方法:

  a,窗体大小,大小要合适,控件布局合理;

  b,移动窗体.快速或慢速移动窗体,背景及窗体本身刷新必须正确;

  c,缩放窗体,窗体上的控件应随窗体的大小变化而变化;

  d,显示分辨率.必须在不同的分辨率的情况下测试程序的显示是否正常;

  进行测试时还要注意状态栏是否显示正确;工具栏的图标执行操作是否有效,是否与菜单懒中图标显示一致;错误信息内容是否正确,无错别字,且明确等等;

2.控件

月份和日期对应(比如2月有28天,7月31天)

闰年2月,应有29天

跨年时,年份应有增加。

  测试方法:

  a,窗体或控件的字体和大小要一致;

  b,注意全角,半角混合

  c,无中英文混合.

菜单,进行测试时要注意:

  a,选择菜单是否可以正常工作,并与实际执行内容一致;

  b,是否有错别字:

  c,快捷键是否重复;

  d,热键是否重复;

  e,快捷键与热键操作是否有效;

  f,是否存在中英文混合;

  g,菜单要与语境相关,如,不同权限的用户登陆一个应用程序,不同级别的用户可以看到不同级别的菜单并使用不同级别的功能;

  h,鼠标右键快捷菜单;

    g,手机拍照功能可以正常显示;

3. 文本框、按钮等控件测试

文本框的测试

  如何对文本框进行测试

  a,输入正常的字母或数字。

  b,输入已存在的文件的名称;

  c,输入超长字符。例如在“名称”框中输入超过允许边界个数的字符,假设最多255个字符,尝试输入 256个字符,检查程序能否正确处理;

  d,输入默认值,空白,空格;

  e,若只允许输入字母,尝试输入数字;反之;尝试输入字母;

  f,利用复制,粘贴等操作强制输入程序不允许的输入数据;

  g,输入特殊字符集,例如,NUL及 等;

  h,输入超过文本框长度的字符或文本,检查所输入的内容是否正常显示;

  i,输入不符合格式的数据,检查程序是否正常校验,如,程序要求输入年月日格式为yy/mm/dd,实际输入yyyy/mm/dd,程序应该给出错误提示

在测试过程中所用到的测试方法:

  1,输入非法数据;

  2,输入默认值;

  3,输入特殊字符集;

  4,输入使缓冲区溢出的数据;

  5,输入相同的文件名;

 4.  命令按钮控件的测试

  a,点击按钮正确响应操作。如,单击确定,正确执行操作;单击取消,退出窗口;

  b,对非法的输入或操作给出足够的提示说明,如,输入月工作天数为32时,单击”确定“后系统应提示:天数不能大于31;

  c,对可能造成数据无法恢复的操作必须给出确认信息,给用户放弃选择的机会;

  单选按钮控件的测试

  a,一组单选按钮不能同时选中,只能选中一个。

  b,逐一执行每个单选按钮的功能。分别选择了“男”“女”后,保存到数据库的数据应该相应的分别为“男”“女”;

  c,一组执行同一功能的单选按钮在初始状态时必须有一个被默认选中,不能同时为空;

5. up-down控件文本框的测试

  a,直接输入数字或用上下箭头控制,如,在“数目”中直接输入10,或者单击向上的箭头,使数目变为10;

  b,利用上下箭头控制数字的自动循环,如,当最多数字为253时,单击向上箭头,数目自动变为1;反之亦适用;

  c,直接输入超边界值,系统应该提示重新输入;

  d,输入默认值,空白。如,“插入”数目为默认值,点击“确定”;或,删除默认值,使内容为空,单击“确定”进行测试;

  e,输入字符。此时系统应提示输入有误。

6.组合列表框的测试

  a,条目内容正确,其详细条目内容可以根据需求说明确定;

  b,逐一执行列表框中每个条目的功能;

  c,检查能否向组合列表框输入数据;

7. 复选框的测试

  a,多个复选框可以被同时选中;

  b,多个复选框可以被部分选中;

  c,多个复选框可以都不被选中;

  d,逐一执行每个复选框的功能;

8.列表框控件的测试

  a,条目内容正确;同组合列表框类似,根据需求说明书确定列表的各项内容正确,没有丢失或错误;

  b,列表框的内容较多时要使用滚动条;

  c,列表框允许多选时,要分别检查shift选中条目,按ctrl选中条目和直接用鼠标选中多项条目的情况;

9.滚动条控件的测试

  要注意一下几点:

  a,滚动条的长度根据显示信息的长度或宽度及时变换,这样有利于用户了解显示信息的位置和百分比,如,word中浏览100页文档,浏览到50页时,滚动条位置应处于中间;

  b,拖动滚动条,检查屏幕刷新情况,并查看是否有乱码;

  c,单击滚动条;

  d,用滚轮控制滚动条;

  e,滚动条的上下按钮。

各种控件在窗体中混和使用时的测试

  a,控件间的相互作用;

  b,tab键的顺序,一般是从上到下,从左到右;

  c,热键的使用,逐一测试;

  d,enter键和esc键的使用;

  在测试中,应遵循由简入繁的原则,先进行单个控件功能的测试,确保实现无误后,再进行多个控件的的功能组合的测试。

  ps:密码输入框测试时要特别注意进行字母大写输入的测试。

2、UI测试

原型与效果图对比(导航测试)

图形测试

内容测试

3、兼容性测试(比如testin云测平台)

与本地以及主流APP是否兼容

不同操作系统的兼容性,是否适配

不同手机屏幕分辨率的兼容性

4、交叉测试

冲突测试,即一个功能正在执行过程中,同时另外一个事件或操作对该过程进行干扰的测试

5、安装,升级,卸载,更新

<span role="heading" aria-level="2">手机APP测试(测试点、测试流程、功能测试)

5.1 安装、卸载测试

正向:应用是否可以正常安装(命令行安装;apk/ipa安装包安装 )(有网、无网是否都正常)

正向:APP的速度是否流畅

逆向:应用是否可以在IOS和Androoid不同系统、版本、机型上进行安装

逆向:是否可以正常删除(三方软件删除;命令行删除;桌面删除)

逆向:APP安装完成后,是否可以正常打开,稳定运行

逆向:安装过程中断网或网络不稳定的情况下,是否有相应提示

逆向:网络异常时,应用是否会崩溃:在请求超时的情况下,如果程序逻辑处理的不好,就有可能发生crash

逆向:卸载过程中出现死机、重启,断点等意外情况,待环境恢复后是否可以继续正常卸载

逆向:卸载是否支持取消功能,单击取消后软件卸载情况是否正常

逆向:安装过程中是否可以暂停,再次点击,是否可以继续安装

逆向:安装空间不足时如何表现,是否有相应提示,提示是否友好

逆向:安装过程中断网或网络不稳定的情况下,是否有相应提示

逆向:安装在手机卡上或SD卡上(不同的IOS和安卓版本)

5.2 升级测试

5.3 更新测试

正向:客户端有新版本时,有更新提示

逆向:取消版本后,老版本可以正常使用

逆向:当版本为非强制升级时,用户可以取消更新,老版本能正常使用。用户在下次启动APP时,仍出现更新提示

逆向:APP更新后新增功能和老功能是否可以正常使用

逆向:当版本为强制更新升级时,用户没有做更新,退出客户端,下次启动APP时,仍出现强制升级提示(且无法关闭),点击更新是否正确调整到后台配置的更新页面

逆向:APP更新后检查版本号应该有更新

逆向:当客户端有新版本时,在本地不删除客户端的情况下,直接更新检查是否能正常更新

逆向:当客户端有新版本时,在本地不删除客户端的情况下,更新后的客户端功能是否是新版本功能

逆向:当客户端有新版本时,在本地不删除客户端的情况下,检查资源同名文件如图片是否有正常更新最新版本

逆向:升级安装意外情况的测试(如死机、断电、重启)

逆向:强制更新(APP开启后,自动更新APP,否则无法使用APP),多次关闭和打开APP后是否正常跳出更新弹窗,且无法关闭;点击更新是否正确跳转至后台配置的更新页面

逆向:非强制更新(只提示一次更新):可以正常关闭弹窗;重启APP更新提示按照需求再次显示或者不再显示;点击更新是否正确跳转至后台配置的更新页面

逆向:当有新版本时,不删除客户端的情况下,直接更新是否成功

逆向:升级安装意外情况的测试(如死机、断电、重启)

逆向:允许内网访问的APP,在连接到外网时是否有友好提示

 

6、用户体验测试

 

整体产品或服务的舒适度

 

7、安全测试

敏感信息是否加密,用抓包工具分析

密码是否过于检查检查

重要数据,如支付密码会不会保存到设备

同一账号在不同终端登陆,是否有提示

异地登录是否有提示

系统会否运行多次非法登陆,是否有提示

限制或者允许使用手机某些功能

注册的验证码是否重复使用,是否有超时限制

协议抓取,反编译

8、性能测试

服务器的性能测试和手机端的性能测试
比如:CPU、内存、上传流量、下载流量、电量使用情况等

极限测试

响应时间

压力测试

耗电量测试

电量流量测试

一般CPU使用率与手机端电量使用率成正比,CPU使用率不能超过10%以上,流量不要超过10M以上,可以通过android手机端一些监控软件获取数据

CPU、内存消耗

app使用占用的CPU和内存

APP启动时长

app启动需要的时间

crash率

奔溃率

内存泄露

android的程序由Java语言编写,所以android的内存管理与Java的内存管理相似。程序员通过new为对象分配内存,所有对象在java堆内分配空间,然而对象的释放时有垃圾回收器完成的。
android的虚拟机是给予寄存器的Dalvik,它的最大堆大小一般是16M,有的机器为24M。

9、手机app测试流程

需求分析->需求评审->开发人员编写排期->测试计划排期->编写测试用例->用例评审->提交基线->具体测试流程->测试通过

10、手机App测试工具

云测平台、testin、百度MTC、其他工具GT

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/155638.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号