HiKariのTechLab

光の技术屋


  • 首页

  • 关于

  • 标签

  • 分类

  • 归档

  • 站点地图

  • 搜索

【极客日常】游戏测试开发干货——Python进阶与游戏自动化测试攻略

发表于 2022-11-24 | 更新于 2025-08-10 | 分类于 极客日常

在互联网上,关于游戏测试(开发)领域的技术分享,实际是非常稀少。尤其针对游戏功能测试领域,很多文章的思想维度仍然停留在很久以前,关注的更多是测试用例设计以及质量管理这些更加偏向业务方面的内容。很多同学认为游戏业务测试缺乏技术含量,其实本质上是因为,很少同学愿意投入精力去研究这个领域的技术,以及研究这些技术如何更好地契合到实际的业务当中。

为此,针对游戏测试(开发)的工作特性,笔者根据自己以前的博客整合了两个文集,分别是:

阅读全文 »

【测试人生】UE4大世界游戏寻路效果自动化测试

发表于 2022-11-20 | 更新于 2024-04-07 | 分类于 测试人生

在一些无缝大世界的游戏当中,我们通常能够体验到游戏的自动寻路功能,通过自动寻路,玩家可以不用任何操作就到达任务或者玩法的目的地,从而让游戏过程更加轻松。在测试寻路功能时,不仅需要检查寻路是否成功到达,而且也需要关注寻路路径呈现的效果,从而确定玩家是否走在策划预想的路径上。

由于寻路起点、终点选择的随机性,人工执行寻路测试时,往往需要根据自定义的规则遍历多个特定的起点终点,这样操作起来不仅非常耗费人力,而且针对再后台存储navmesh数据、做动态烘焙以及计算寻路路径的场景,在验收寻路效果时,测试人员还需要多次手动从后台拉取一定范围的navmesh数据并绘制在客户端的路面上,才能知道玩家是走在什么样的路面。为了解决寻路效果测试的效率问题,引入自动化技术显得非常有必要。

因此,笔者将结合自己实际的工作经验,分享一种在UE4大世界游戏中,寻路效果自动化测试的方案。

阅读全文 »

【Game Of AutoTest】5、游戏自动化测试的价值

发表于 2022-11-02 | 更新于 2024-04-07 | 分类于 Game Of AutoTest

《Game Of AutoTest》的最后一篇文章,聊一下游戏自动化测试的价值。

一千个人心中有一千个哈姆雷特。仅以笔者的角度,游戏自动化测试的价值,可以体现在这几个方面:

  • 效率提升
  • 缺陷发现
  • 质量监控
  • 技术支持

做好自动化测试的价值分析,不仅能够自动化测试技术落地做足理论基础,而且也能在任意时候指引自动化技术落地者做好当下的决策,从而逐渐把自动化测试做出更大的规模跟成果。

阅读全文 »

【DIY小记】Ubuntu22.04去掉侧边菜单栏Floppy Disk图标的方法

发表于 2022-10-15 | 更新于 2024-04-07 | 分类于 DIY小记

近期装Ubuntu22.04虚拟机,发现侧边菜单栏多了个Floppy Disk图标。软驱这东西毕竟是上世纪的了,2022年也没什么用,但就是找不到入口去掉这个冗余的图标。

今天偶然之间发现去掉图标的方式,供大家参考:

  • 右上角点电源/声音/网络按钮,选择Settings设置
  • 选择Appearance,就是能调Light/Dark风格的页签
  • 下拉,在Dock栏目下,点击Configure dock behavior
  • 里面的Show Volumes and Devices下,有一个Include Unmounted Volumes项。反正软驱一般也不会挂载,所以取消点选这个项,Floppy Disk图标就没了。

【GitHub探索】ebook-boilerplate——批量转markdown为PDF和电子书

发表于 2022-10-05 | 更新于 2024-04-07 | 分类于 GitHub探索

正值十一假期,近期准备把自己的python笔记精编整理,做一个pdf电子书。在调研如何把多个markdown文档转化为单个pdf的时候,试了很多种方法。最后找到了最佳方案,也就是本文的主角,由phodal前辈整理的电子书生成项目ebook-boilerplate。这个项目不仅支持批量转markdown为pdf,而且还支持转成ebook等多种格式。

使用这个项目的时候,也踩了一些坑,需要做一些额外的配置。以笔者的场景为例,电子书生成环境是Ubuntu22,需要转化一堆中文的markdown。clone了这个项目之后,除了ebook-boilerplate本身README.md里描述的内容之外,实际还需要留意以下环节:

阅读全文 »

【Game Of AutoTest】4、游戏自动化测试的稳定性保障

发表于 2022-10-03 | 更新于 2024-11-03 | 分类于 Game Of AutoTest

在游戏自动化测试技术落地过程当中,如何保证自动化测试的稳定性,是一个需要重点优先解决的困难问题。

以手机游戏客户端自动化测试为例,和一般服务架构的自动化单元测试或集成测试不同,自动化驱动的过程,其本质更加类似于网络爬虫,每次测试执行都是一个时间较长的过程,而流程一长,不稳定因素则随之而来。游戏自动化的整个过程,大致是这样的:

  • 前置环境准备(setup):设置用例运行环境、设备状态与玩家状态,保证用例运行的条件
  • 用例脚本执行(run):执行自动化用例脚本
  • 后置恢复操作(teardown):恢复测试环境、设备状态与玩家状态
  • 测试报告输出(report):整合跑测期间游戏的运行数据与用例脚本收集/导出的数据,生成测试报告

要分析如何保障整个自动化过程的稳定性,我们可以根据这几个步骤进行细节切分,对每一个环节影响稳定性的因素逐个理顺,从而最终,我们就可以得到一整套自动化稳定性保障的解决方案。在这四个步骤当中,前置环境准备和用例脚本执行这两步,对自动化流程稳定性的影响面最大,而最后面两步的影响程度,则相对较低。

阅读全文 »

【Python随笔】PyQt5的QListView兼容左键双击事件和右键上下文菜单的方法

发表于 2022-10-02 | 更新于 2024-04-07 | 分类于 Python随笔

近期笔者因工作原因,需要做一个安卓手机的文件浏览功能,集成在笔者以前用PyQt5做的一个的工具当中。文件浏览功能大概做成这样:

  • 一个列表界面,列出某个目录下的所有文件名(不区分文件和文件夹)
  • 双击某个文件名,尝试进入这个文件名代表的文件夹(文件的情况会失败)
  • 右键某个文件名,弹出上下文菜单,可以进入这个文件名对应的文件夹,也可以复制路径到其他的输入框

其中,文件列表选型用了QListView组件,但在实现兼容双击进入文件夹+右键菜单功能时,稍微踩了下坑。为了解决这个问题,笔者在网上查阅了许多资料,最后找到一种解决方法,决定记录于本文当中。

首先需要了解,Qt对于QListView这类数据容器组件,是遵循MVC的设计模式的。QListView数据的初始化,方法是这样的:

阅读全文 »

【测试人生】GAutomator安卓UE4版本的实现机理与优化实战

发表于 2022-09-12 | 更新于 2024-04-07 | 分类于 测试人生

在2年以前的一篇文章中,讲述了游戏UI自动化方案GAutomator的基础机理、使用方式和一些工具扩展的想法。今天,趁着Game Of AutoTest系列的连载,结合游戏自动化技术选型一文,笔者将深入剖析GAutomator作为UE4安卓游戏UI自动化方案的实现机理,以及自己在实际工作中对GAutomator的优化实践。

工作原理

GAutomator是这样的调用链路:

阅读全文 »

【Game Of AutoTest】3、游戏自动化测试的框架设计

发表于 2022-09-04 | 更新于 2024-04-07 | 分类于 Game Of AutoTest

自动化在技术层面上,除了基础的技术选型之外,最终还是需要落实到具体的工具框架,才能够助力我们自动化脚本开发的过程。因此,本文将讲述一下如何对游戏自动化测试框架进行设计。

在上一篇文章讲到,自动化测试的方式可以有客户端、服务器、编辑器三种方式,除了编辑器需要强依赖引擎层面的特性之外,其他两种自动化方式在工具或者框架的技术实现上有这么几个特点:

  • 框架模块设计具有共通性,只是最终执行自动化用例/脚本的方式不同
  • 许多框架模块可以不依赖游戏本身的特性去实现,可以实现很多企业业务功能的集成
  • 由于和产品没有太多的耦合,可以做成易于在不同项目测试之间迁移通用的形式

考虑到当前我国有许多游戏企业的工作习惯是,测试由中台dispatch到各个项目,不直接参与研发过程(Code Review?不存在的),项目产品以提测的方式交付测试,测试侧可以运用自己的测试手法和工具去完成任务。从这样的角度看,拥有一个功能性强且通用的自动化测试工具,不仅是对于项目所需要自动化测试的场景,更是对于测试组整体的技术基建提升而言,都显得非常重要。

以笔者工作经验为参考,要做到游戏自动化框架得以通用,设计上需要遵循如下准则:

阅读全文 »

【Python随笔】python的web开发——WSGI、ASGI、uvicorn与FastAPI

发表于 2022-08-14 | 更新于 2024-11-02 | 分类于 Python随笔

今天这篇文章,聊一下python在web开发上的一些基础实现,阐述下自己理解中的WSGI、ASGI,以及拿uvicorn+FastAPI的组合举个ASGI应用的例子。

WSGI

python的web服务的诞生,其实追溯到一种机制,叫做WSGI,全称Web Server Gateway Interface。WSGI的提案来源于PEP-333,可以理解为一种python-web-server和python-web-app的接口通信标准。在这种场景下,python的web服务呈现以下的工作模式:

  • python-web-app,也就是web应用层,实现WSGI接口,用作web请求的handler
  • 用户向python-web-server发送web请求
  • python-web-server,又称作WSGI Server,解析请求数据,整理当前session的环境信息
  • python-web-server加载python-web-app,调用python-web-app实例的WSGI接口,处理请求
  • python-web-app处理完请求,返回结果给到python-web-server
  • python-web-server写回返回结果,给回用户

代码上是这样的表现,以官方提案的例子为例:

阅读全文 »
1…8910…21
ひかり.HDQ

ひかり.HDQ

talk is cheap, code is rich
203 日志
14 分类
423 标签
GitHub Mail CSDN Juejin Steam Bilibili
© 2019 – 2025 ひかり.HDQ
|