51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

查看: 4237|回复: 10
打印 上一主题 下一主题

Flash游戏自动化的实现—自动化方案分析

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2011-9-23 09:34:20 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本帖最后由 xunmi 于 2011-9-23 09:40 编辑

这是本人技术博客上的一篇原创文章(http://www.cnblogs.com/xunmi/),现在也在51testing论坛上分享出来(不能完整贴出,因为论坛帖子有字数限制),希望通过自己在Flash游戏自动化实施过程中累计的经验分享,让更多测试人员了解和分析如何更好的实现Flash游戏的自动化,希望自己抛出的砖,能够收获到大家回敬的玉,谢谢!

前端时间收到测试经理分配的任务:要求配合自动化组实现体感Flash游戏的自动化,因此根据自己对Flash游戏的测试了解以及其他自动化测试工具的使用经验,首先跟组员一起讨论确定体感Flash游戏的实现方案,Flash游戏的原理是通过ActionScript来控制帧动画的播放、暂停以及鼠标键盘在帧动画中的动作响应,但是体感Flash游戏由于有体感设备,因此与其他的Flash游戏交互上稍有不同:





体感Flash游戏的具体交互过程:1)首先玩家通过辅助识别设备和识别手柄,在体感设备前进行手臂挥动的动作,这些动作会被体感设备进行捕获,然后通过内置算法将玩家的动作分解为三维空间坐标数据和二维空间坐标数据;
2)体感设备引擎的动作识别模块会建立管道将三维空间坐标数据写入到指定目录下的管道文件中,而二维空间坐标数据则会被体感设备引擎坐标换算模块分解为横坐标数据、鼠标按键数据、键盘Esc按键数据分别写入Linux  input子系统中的系统Event、触摸屏Event、键盘Event中;
3)体感Flash游戏启动之后,会首先调用公共的3D动作模型库,将指定目录中的管道数据作为动作模型的输入进行解析,目的是将玩家的头部、双臂等关键部位通过球状、线形、带状识别点进行区分,并分析出各自的动作轨迹,这些不同的轨迹数据会被Scaleform播放器内置模拟器读取,并进行按键映射。
4)体感Flash游戏启动之后,还会从Linux input子系统中读取系统Event、触摸屏Event、键盘Event文件,由模拟器传给FlashActionScript执行游戏中的人物横坐标的移动、鼠标左键和右键触发的动作、键盘Esc按键操作。



按键映射的作用:如果是3DFlash游戏,则会有人物角色或道具在3D场景的前后移动、道具的抛出、物体的旋转等动作,这些动作在Flash游戏中是通过不同的键盘按键来触发的,因此按键映射的作用就是将动作与键盘按键进行关联,模拟器通过键盘事件让Flash游戏知道应该进行怎样的三维动作。


要实现体感Flash游戏的自动化,可以以Flash游戏的数据获取来入手,Flash的播放器Scaleform是通过3D动作模型库的管道文件和Linux input子系的Event文件获取Flash执行的动作数据,因此自动化实现思路就是Flash自动化工具通过封装好的数据和测试脚本来替换体感设备引擎产生的动作数据,如下图所示:

接下来进行Flash自动化工具实现方案的具体分析:首先是操作模拟,要能够逼真地让自动化工具模拟玩家动作,需要考虑以下几个方面:


单用户操作模拟


Flash自动化工具对于游戏需要的三维动作数据可以用事先封装好的一系列动作数据来进行模拟,因为三维动作很难仅仅通过一系列坐标值来进行模拟,二维平面动作数据则通过解析测试脚本,然后将数据写入Linux input子系统的Event来进行模拟,但是体感设备引擎也会向交互数据文件写入数据,所以Flash自动化工具启动之后,通过脚本来停止体感设备的运行。



玩家操作多样性


实际当中用户的操作是多种多样的,没有既定的操作路线来模拟多个用户的不同操作,因此自动化测试工具的操作模拟功能还需考虑不同玩家在同一界面的随机性操作。这方面可以从工具的测试脚本设计中入手,实现思路是:在测试脚本中的位移、操作按键加入概率值,来让测试工具通过设置的
0~100%之间的概率值增加对用户分支操作的覆盖。
游戏界面的切换

玩家在体验Flash游戏时会在主界面、选择界面、游戏中界面、成绩界面等界面进行切换,如果自动化工具不能区分多个游戏界面,并根据界面来执行不同的操作的话,那么自动化工具运行之后,可能就会在Flash游戏的某个界面上无法进入下一个界面操作。因此需要考虑自动化工具如何区分Flash游戏的不同界面,并自动执行相应的测试脚本。实现思路是:Flash游戏在播放器中进行界面切换时,Sacleform调用自动化工具的库文件,将约束好的唯一窗体名写入到系统的共享内存当中,自动化工具会实时监测共享内存中标识位、如果标识位为“未读取”状态,自动化工具则读取此数据,并跟测试脚本的窗体名进行匹配,查看是否存在相同项:如果存在,则执行脚本中的相应操作并将标识位置为“已读取”状态。如果不存在相同项,则工具不进行任何操作,只将标识位置为“已读取”状态。











分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

该用户从未签到

2#
 楼主| 发表于 2011-9-23 15:11:20 | 只看该作者
貌似都没人给出自己的建议~~~~~
回复 支持 反对

使用道具 举报

该用户从未签到

3#
发表于 2011-9-23 16:59:17 | 只看该作者
刚好现在在找flash游戏自动化测试的资料,非常有借鉴意义,先顶再看,感谢。
回复 支持 反对

使用道具 举报

该用户从未签到

4#
发表于 2011-9-23 17:23:56 | 只看该作者
楼主的测试更接近硬件+软件类型的测试,一般的游戏测试比较少考虑操作输入(按键、平移或触摸),更注重游戏实现本身。
很特殊的是,体感游戏本身借用引擎要把三维、二维的数据转换为机器可识别的码数据,我觉得楼主的思路没错,都是将脚本数据进行封装然后执行,建立场景,这个和一般游戏测试的自动化很类似,其实我好奇的是你们的场景设计细粒度到底是怎么划分的。
如果划分的很粗,那基本上可以用普通的人力操作去做用例覆盖了,如果划分的很细,以每个操作为组合基本,那这样组合的情况会很多,特别是实际用户在游戏时,意料外的情况就更多了,那这里你们是怎么做划分与覆盖的?
回复 支持 反对

使用道具 举报

该用户从未签到

5#
 楼主| 发表于 2011-9-23 21:49:33 | 只看该作者
本帖最后由 xunmi 于 2011-9-23 21:51 编辑

恩,很感谢小t给予的回馈,实际上Flash游戏的场景设计细度主要集中在每个关卡的过关条件、道具不同效果、游戏人物状态变化这些方面,这些地方的测试占游戏测试用例的大部分,而这部分通过我们的Flash自动化测试工具是没法很好测试的,因为会导致测试脚本需要设计的测试数据太复杂,每个测试面对应的3D数据也不太好封装,所以我们的Flash自动化测试工具的主要目的是进行稳定性测试,通过操作模拟来让Flash游戏长时间的运行,来做进程和资源监控,因为测试人员很难知道在长时间的Flash游戏重复体验过程中,游戏的CPU占用和内存消耗(CPU占用太多或内存太大会造成较低配置的用户无法较好体验游戏,内存泄露是性能缺陷)是怎么变化的,因为手工只能记录某个时间点的;通过每步操作的自动截图,测试人员可以查看长时间运行时是否会有错误产生,功能测试的场景设计粒度只能停留在Flash游戏各种界面按键、图片点击触发的异常、各种界面跳转以及游戏当中的随机操作可能引发的异常错误上面。
回复 支持 反对

使用道具 举报

该用户从未签到

6#
发表于 2011-10-8 18:28:34 | 只看该作者
本身我最近也在研究flash的自动化测试,无奈研究了半天,发现市面上的工具基本上都不支持flash
楼主的情况要复杂一些,像这些复杂的内容我想用自动化测试也仅仅只能做到冒烟测试的级别,如果做动作类测试的意义不是很大,我想应该把主要精力集中在做一些UI功能上的测试会更有效果一些,另外说的记录内存泄露方面可以让程序写一个输出程序定时输出到一个文本文档中即可
我现在在做一个模拟城市经营类的游戏,相对来说要简单一点,无非是模拟一个客户端消息,然后从服务器上获取最新的数具进行对比检查结果
回复 支持 反对

使用道具 举报

该用户从未签到

7#
 楼主| 发表于 2011-10-9 15:42:25 | 只看该作者
回复 6# zlclclzl
你所说的复杂内容我想应该就是指Flash游戏的功能测试吧?Flash游戏的功能测试项比较多,而且不同的Flash游戏所需测试的功能差异也很大,所以市面很难有一种工具能够进行Flash游戏的通用测试。UI上的自动测试存在随机性问题,就拿祖玛这款游戏来说,除了每关关卡设置是固定的,每关出现的泡泡都是随机性的,自动测试无法判断随机情况的正确性。内存泄露是由于程序占用了内存空间,但最后没有正确释放或被系统回收掉而造成内存占用不断增大,比较严重的可以通过几次操作看出,但如果泄**不严重,Flash游戏没有加载所有的场景元素,没有长时间地运行,那么就无法保证内存不存在泄露问题,所以当我们可以实现Flash游戏的长时间自动运行时,就会考虑进行资源监控,并且让工具根据监控数据画出曲线图,供测试人员分析。模拟一个客户端消息,然后从服务器上获取最新的数据进行对比检查,这个有点类似我所做的平台服务器接口测试,测试的关注面主要集中在客户端与服务器交互上面,能够测试服务器接口是否正常运行,但客户端是否会根据各种触发条件来正确的发送数据给服务器这个是怎么保证的?
回复 支持 反对

使用道具 举报

该用户从未签到

8#
 楼主| 发表于 2011-10-9 15:42:31 | 只看该作者
本帖最后由 xunmi 于 2011-10-25 11:58 编辑

回复 6# zlclclzl
你所说的复杂内容我想应该就是指Flash游戏的功能测试吧?Flash游戏的功能测试项比较多,而且不同的Flash游戏所需测试的功能差异也很大,所以市面很难有一种工具能够进行Flash游戏的通用测试。UI上的自动测试存在随机性问题,就拿祖玛这款游戏来说,只有每关关卡加载的场景是固定的,但每关出现的泡泡都是随机性的,自动测试无法判断随机情况的正确性。内存泄露是由于程序占用了内存空间,但最后没有正确释放或被系统回收掉而造成内存占用不断增大,比较严重的可以通过几次操作看出,但如果泄**不严重,Flash游戏没有加载所有的场景元素,没有长时间地运行,那么就无法保证内存不存在泄露问题,所以当我们可以实现Flash游戏的长时间自动运行时,就会考虑进行资源监控,并且让工具根据监控数据画出曲线图,供测试人员分析。模拟一个客户端消息,然后从服务器上获取最新的数据进行对比检查,这个有点类似我所做的平台服务器接口测试,测试的关注面主要集中在客户端与服务器交互上面,能够测试服务器接口是否正常运行,但客户端是否会根据各种触发条件来正确的发送数据给服务器这个是怎么保证的?
回复 支持 反对

使用道具 举报

该用户从未签到

9#
发表于 2011-10-11 14:26:31 | 只看该作者
1.功能性方面其实还果看游戏是不是适合做自动化,像你说的祖玛游戏,肯定是不适合自动化的,本身游戏的核心功能只了很大比重,其他内容做自动化是没有意义的
2.内存泄露方面不仅仅是是看内存方面,你可以把句柄也监控起来
3.模拟发包类,这些不仅仅是可以自动化测试,而且还是防外挂测试上
4.关于自动化测试的一些想法,不要抱太大希望他是帮你做一遍全新测试,他能够做的就是跑冒烟测试,回归BUG和功能,所以在测试前还是需要你先全面跑一遍新系统后才把这个系统做成自动化来代替自己重复劳动,所以(客户端是否会根据各种触发条件来正确的发送数据给服务器这个是怎么保证的)不需要你来保证,如果真想保证那也是可以的,但是会比较麻烦,例如不直接通过消息层,而是模拟鼠标键盘操作,纯粹的发送鼠标键盘消息给客户端,由客户端来执行相关的操作触发消息,发送给服务器
5.自动化的代价,其实我一直不是很提倡游戏自己动化功能测试,需求变化块,脚本维护代价高,需要开发工具,覆盖面不够广,如果人手够的情况下,尽量用人来跑一遍冒烟测试
回复 支持 反对

使用道具 举报

该用户从未签到

10#
 楼主| 发表于 2011-10-11 14:54:26 | 只看该作者
没有人回复了。。。
回复 支持 反对

使用道具 举报

该用户从未签到

11#
发表于 2011-11-1 11:34:06 | 只看该作者
我想问下现在Flash自动化工具有哪些
回复 支持 反对

使用道具 举报

本版积分规则

关闭

站长推荐上一条 /1 下一条

小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

GMT+8, 2024-5-3 05:37 , Processed in 0.076779 second(s), 26 queries .

Powered by Discuz! X3.2

© 2001-2024 Comsenz Inc.

快速回复 返回顶部 返回列表