- 1、本文档共6页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
手机软件自动化试研究报告
手机软件自动化测试研究报告一、引言
由于最近一些事务好久没有更新博文了,望关注我博客的网友们谅解,正好最近一段时间着手自动化测试的研究特将我的一些思路及想法写出来与网友们分享,也算是2010年新年贺礼了。前段时间我也有一篇关于自动化测试的文章《手机软件自动化测试探索》相对较浅显,本文在此基础上进行了更进一步的研究探索,希望大家能得到更进一步的了解。手机软件的自动化测试一直困扰着手机软件测试从业人员,本文将最近的一些研究新发现及具体思路作详尽阐述,希望能给予大家更多的参考萌发新的思路。
通过长期的手工测试得出如下可以以自动化测试来解决的问题:
1. 压力测试:一些连续不断的操作,比如反复切换歌曲播放及联网操作等;
2. 极限临界测试:一些极限条件的构造(创建多个列表)及输入字符个数等;
3. 兼容及中断:比如在播放或下载歌曲的时候来电话或者信息;
4. 基本功能回归测试:这样大大的节约了时间和人力成本。
对于以上的测试很多也是可以通过手工来完成,但部分测试采用手工测试是不可靠的,比如最近发现一个Bug(在联网的一瞬间如果来一个信息等中断操作出现死机),类似这种Bug出现条件非常苛刻和临界的情况在手工测试中是很难发现和构造这种测试环境的,即使发现了在很大程度上也属于一种偶然,同时给开发人员定位这个问题也带来了很大的困难。【文章来源:张元礼的博客 /vincetest】
面对诸多因素,我们不得不重视手机软件的自动化测试研究。其实如果掌握了一些自动化测试要领,从简单入手,逐步实现和突破,相信一定能够解决手机软件自动化测试的难题。
二、自动化测试原理
【自动化测试原理图】
1. TestAgent
TestAgent为嵌入在手机软件系统中的一个测试代理模块,解决PC端与手机端交互处理及互联消息通讯问题,这是区别于其他桌面软件自动化测试的关键点,也是嵌入式软件自动化测试的主要特征之一。通过串口或蓝牙设备与PC端中的TestTool建立通讯,其具备的主要功能如下:
1) 接收TestTool发送的消息并向手机端软件系统分发消息及任务
2) 监控手机端软件运行情况并根据相应的约束反馈给PC端的TestTool
3) 被测软件的功能(接口)封装及消息响应
2. TestTool
TestTool自动化测试工具在PC端用于测试控制及测试操作实体,与TestAgent对应,该工具与常规的自动化测试软件一样,其具备的主要功能如下:
1) 向手机端TestAgent发送可识别的消息及任务
2) 接收来自手机端TestAgent的反馈结果
3) 对来自手机端TestAgent的反馈进行测试业务的处理
4) 将测试业务的处理结果呈现给测试人员
三、测试业务
1. 主动式测试
TestTool主动式测试是根据我们的测试需求比如(压力、性能、极限)在TestTool中编写测试脚本控制手机端软件进行测试,或者构造一些手工很难实现的测试场景,通过运行脚本向TestAgent发送消息及任务,TestAgent再向被测软件分发消息及任务,并将结果原路返回给TestTool,TestTool再通过数据处理分析得出测试结果。关键点:发送和分发消息、接收及处理反馈结果(结果判断)。
2. 回归式测试
基本功能的回归测试最为简单的方法就是录制和回放机制,通过运行录制的测试脚本达到按照先前的操作顺序、步骤、输入数据等再次测试被测软件以此达到回归测试的目的。
1) 录制:就是在执行手工测试时将手工测试的任何操作及返回结果(预期正确的结果)通过TestAgent在TestTool中保存下来,并进行分析处理形成一个可执行的脚本。录制的关键点:按键或触屏消息、坐标、响应结果(GUI界面)。
2) 回放:与录制相对应,运行录制时产生的脚本,与主动式测试方式不同的是回归式测试是事先要录制脚本,通过录制脚本来代替人工编写脚本。回放关键点:发送和分发消息、接收及处理反馈结果(结果判断)。
四、关键技术
1. 消息传送机制
利用手机Modem中提供的AT Command通过串口向手机端建立命令消息通讯,目前手机厂商提供了常用的AT Command,基本满足普通的自动化测试需求,另外厂商还提供了用户自定义AT Command的功能,当标准的AT Command不能满足自动化测试需求时,我们可以利用自定义AT Command来实现我们自动化测试中所需要的消息通讯。如下为MTK平台上实现自定义AT Command的关键样例代码:
view plaincopy to clipboardprint?//customer_at_command.c #include kal_non_specific_general_types.h #include stdio.h #include string.
文档评论(0)