104~牛牛 发表于 2017-12-29 16:37:58

接口自动化测试在游戏测试中的运用

一、游戏为什么要做接口测试
  如果只是单纯做游戏的功能测试(黑盒),对于一些问题就无法测试到,游戏上线后会产生严重的后果。
  举个例子,重复领取奖励的问题:例如玩家完成一个任务后去领取奖励,领完奖励后【领取】按钮就消失了,对于正常玩家是没有问题的。但如果领取奖励的判断只依靠客户端来做(领奖后按钮消失),而服务器没做判断,那么遇到坏玩家时,就会被刷奖励(例如玩家截取到请求,通过发送请求可以重复领取奖励;或者在领奖时快速点击领取按钮,也会得到多次奖励)。
  因此,游戏的接口测试作为功能测试的补充,是十分有必要。
  二、游戏如何去做接口测试
  1、如何获取接口协议
  由于我们游戏项目的通信协议,要么是TCP、要么是WebSocket,并没有通用的第三方工具直接获取接口协议的。因此我们做接口测试是依赖研发写的工具,用来模拟协议的发送与返回结果。
  2、如何做接口测试
  接下来我根据自己负责的游戏项目,来具体说一下游戏的接口测试是怎么做的。
  (1)拿到接口协议文档、返回码文档、参数配置文档等等,熟悉上述文档与游戏玩法,准备接口测试用例。



  (2)拼凑所需测试的接口协议
  协议模板为:
  tools:handle(角色ID, 协议号, {pt_协议号_c, 参数1, 参数2, 参数3.....})
  例如上面截图中,我要升级剑士的旋风斩技能,那么协议是:
  tools:handle(1678,5702,{pt_5702_c,1005})
  (3)登录游戏账号,打开接口测试工具,准备好测试条件后,发送接口协议,查看返回结果是否符合预期。

  例如我是法师职业,去发送一条升级剑士技能的协议,返回结果为1902,查看返回码文档,显示为技能不适合该职业,符合预期。

  三、总结:
  1、由于我定义的游戏接口测试是作为功能测试的补充,因此并不需要每条协议都去测试,而是挑选游戏核心功能的协议,或者是一些容易被刷的协议。例如充值、领取奖励、出售物品、活动开启结束等等。
  2、拼凑接口协议,要根据具体情况进行拼凑,前提是要熟悉接口协议文档与参数文档。因为有的协议是不带参数的(测试时不用考虑错误参数的情况),而有的带一般参数(就是上面我举例升级技能的协议),最怕的是带嵌套参数(这个需要把多条协议嵌套在一起,组合成一条协议去发送,测试的复杂度也比较高)。
  3、接口的测试,重点要考虑边界值(例如条件不满足,达到下限、上限等),以及错误参数情况(例如负数、0、特殊字符等)。而且测试条件需要熟悉游戏的玩法。

jingzizx 发表于 2017-12-29 20:17:32

:victory:

gametestinwm 发表于 2022-2-10 17:44:31

您好,请问方便细聊一下关于游戏性能和自动化测试的相关内容吗
页: [1]
查看完整版本: 接口自动化测试在游戏测试中的运用