2019 年,全球领先的文化娱乐产业集团完美世界拿下了 “一定是东半球最贵的” 顶级域名 www.88.com。2020年8月8号,历时一年研发,88 完美邮箱与大家正式见面。立足产品角度,这是完美世界正式进军邮箱赛道的起点。对于 88 邮箱团队来说,此举迈出了从 0 到 1 的第一步。

不同于 QQ 邮箱和网易邮箱,88 完美邮箱主打商务与协同办公,提供团队邮件快速创建(日报、周报、月报、任务和审批)、团队通讯录、团队邮件组管理、88 便签、对接飞书会议、在线文档,以及免费开放 5GB 容量网盘等高效协同的功能。

对于完美世界来说,邮箱业务的诞生与快速发展催生出一个全新的团队,从 0 到 1 组建团队,需要建立新的研发流程和规范。在这一过程中,测试如何发挥更大的价值是一个重要的课题,而测试实现左移和右移是关键目标和突破方向。

测试左移和测试右移模型

对软件产品而言,传统的质量模式通过测试左移和测试右移被赋予更多的内涵,也承担起更多的职责。

测试左移如何落地?

测试任务跟踪

测试任务跟踪,不仅仅只是跟踪测试本身的工作,还需要介入到需求、技术方案、编码的全过程。只有前序每一步都跟踪到位,才能尽量避免测试过程中的不可控因素,从而保证产品质量。

测试同学的任务其实是不好度量和跟踪的,但是 MeterSphere 开源持续测试平台为我们解决了这个痛点。测试计划、测试用例、执行情况等都可以在 MeterSphere 平台上直观地看到,做到了 “让数据为质量说话”。

建立代码分支管理规范

开发同学在编码过程中,经常会因为环境不够用、或者代码被覆盖等问题而烦恼。对于敏捷开发模式的团队,需求多、分支多是常态,怎样让开发测试有序地协同工作,规范分支管理流程是必要的。

Sonar 代码质量检测

Sonar 是可视化的代码质量检查平台,支持的语言包括 PHP、Java、Python、C# 等,包含项目、问题、代码规则、质量配置、质量阀和配置五个模块。

以下是项目执行情况的概览,每个项目名称代表一个项目,项目检查的结果简单呈现在项目首页概览中,包含 Bug 数量、漏洞数量、不规范、单元覆盖率、代码重复度等维度。

我们通常会将 Sonar 发现的问题以 Bug 的方式提交给开发团队,要求致命、严重级别的 Bug 必需修改,并跟踪解决进度。在实际的运用过程中,也会根据项目实际情况调整质量阀门,以避免误报等情况出现。

持续测试:基于 Metersphere 平台实现接口自动化

接口测试提前接入,通过 YApi 管理接口文档,开发同学在需求评审后即进入技术设计与接口设计阶段,测试同学则根据接口文档进行 Mock 测试。

基于 MeterSphere 开源持续测试平台,我们实现了测试工作的自动化。提测后自动化测试接口通过率,提前发现问题,有效提升测试效率。

MeterSphere 持续测试平台采用开源可扩展框架,实现了测试跟踪、接口自动化、性能自动化的全覆盖,特别适合创业团队。从测试团队的角度看,MeterSphere 平台既能切实地提升产品质量和测试效率,又解决了自研自动化框架人力不足的痛点。

同时,MeterSphere 支持与 Jenkins 的集成,每次有新的代码提交后,平台自动触发环境部署和接口自动化 Job 执行,并发送邮件通知,实现了主流程功能的回归测试,提升测试效率。

测试右移如何落地?

灰度发布

使用灰度发布方式,新版本上线后先更新部分服务器,测试人员先进行验收通过后,再全量发布。这样一来,尽可能地避免了测试和正式环境配置不一致、数据库更新不及时等不确定因素引起的问题。

服务监控

对于测试人员来说,服务上线后仍然需要关注服务的运行情况,以便在出现系统问题时能够快速做出反应,将影响降至最低。在这一环节,我们引入了 Zabbix 系统检测工具,实时监控系统硬件资源使用情况。同时设置报警通知,将异常情况第一时间通知给相关负责人。

Zabbix 通过调用 ODBC 来获取数据库的数据,以及数据库状态等信息;通过 IPMI Agent 监控硬件设备,例如 Dell 或者 HP 服务器的主板温度、CPU 电压、盖子是不是被打开等;通过 JMX Agent 监控 Java JVM,例如 Tomcat;通过追踪模拟鼠标在 Web 网站上的点击操作,来检查 Web 网站的功能和响应时间。

用户反馈

“用户就是上帝”。任何产品的成功与否,都取决于用户。为此,我们建立了完善的用户反馈处理机制:对于用户反馈的问题,第一时间进行修复上线;针对用户提出的建议,结合实际情况对产品进行打磨和优化。

专项测试

安全

保证邮箱数据安全性,是产品研发的一个重要环节。数据面临的安全威胁来自于多个方面,如何有效地保护数据的保密性、完整性、可用性和真实性,邮箱团队一直在不断地升级和优化。这部分的工作主要涉及系统安全加固、数据库加密、全链路传输加密、反作弊策略、反黑策略、反入侵策略、安全管理、反商业泄密等。

性能

接口层面

根据用户量预期,制定系统性能要求,再构造数据借助 JMeter 对系统进行持续压测,测试系统的极限处理能力,以及最佳处理能力。

同时,将部分主要流程性脚本通过 MeterSphere 开源持续测试平台建立自动化性能测试任务,每次版本升级后自动执行稳定性测试,大大提升了测试效率,也能在早期发现问题并解决问题,进一步提升产品质量。

Web 页面

从资源加载时间、页面渲染、接口调用逻辑多方面分析 Web 页面性能。这这方面,通过 www.webpagetest.org 工具,测试首页资源加载、接口响应时长、页面渲染时间等数据记录页面性能。

从不限于以下不同维度的测试数据分析页面性能,并给出合理的改进措施:

MeterSphere 使用体会

对于创业者来说,时间少任务重是常态,反复地手工测试让人精疲力竭,要着手去写自动化代码,又需要投入大量的人力,让人应接不暇。我们团队引入 MeterSphere 工具之后产生了非常好的效果。

现在来总结一下 MeterSphere 持续测试平台的优点:

MeterSphere 项目还在持续不断优化和改进,如果能增加以下些功能就更好啦:

对于测试团队来说,保证产品质量,测试左移和测试右移都是非常重要的突破方向。我们也将在此基础上不断地完善和优化,全方位提升研发测试效能。

注:本文作者为 88 完美邮箱测试主管李雪兰。


↙↙↙阅读原文可查看相关链接,并与作者交流