• 中通IM测试实践


    一、背景

    即时通信(Instant Message,简称IM)是一个终端服务,允许两人或多人使用网络即时地传递文字信息、图片、语音、视频和文件。

    IM测试的重点是围绕着消息展开具体测试活动的,本文也旨在分享中通自研IM系统中的“消息”测试的实践经验。

    二、测试分析介绍

    消息的质量目标包括:准确性、时效性、可靠性、多端一致性、安全性、兼容性,这几个维度都是做好IM质量保障的重点及难点。

    基于业务特性分析,我们梳理出IM测试点,大致如下:

    图片

    (IM测试分析)

    三、IM测试实践

    1.准确性保障

    那么,如何测试消息的准确性呢?我们要明确消息准确性的关键点。

    时间准确性:消息发送方发出时间,和消息接收方接收时间,差值要在500ms以内。

    顺序准确性:单聊、群聊,每个人接收到的消息的顺序都是一样的。

    内容准确性:消息发送方发出的内容,和消息接收方接收到的内容,要一模一样,长度不会被截断,字符也不会被转义等。

    类型准确性:例如发出去的消息类型是视频,那么接收到的消息类型也应该是视频,而不能解析为文件。二者的差异不仅在于类型标签不一样,还在于视频可以直接在IM聊天框中播放,而文件只能下载不能播放。

    状态准确性:发送方发出去,如果接收方未读,那么发送方查验的接收方已读未读状态不能是已读。

    我们构造以下3类场景来展开测试工作:在线场景,离线场景,历史消息场景。

    在线场景:收发消息的帐号都保持在线状态,消息发出后,在接收方客户端就能实时收到消息,此时验证消息的时间、顺序、内容、类型、状态,是否和发送方保持一致。

    离线场景:接收方不在线时,首先需要查询Redis,验证接收方消息正常被记录。然后还需要验证,当接收方登录后,能够查询到消息,且消息的五个准确性维度,都和发送方保持一致。

    历史消息场景:接收方清除客户端缓存,或者换设备登录,验证历史消息还能获取到。

    2.时效性保障

    消息时效性的性能指标主要是关注在高负载高并发场景下的消息收发时间。中通的架构师在架构设计之初,就已经确定了一个参考值,在10000 QPS下,消息收发在500ms以内。当然这个数据是足够支持集团几十万人正常使用IM的。

    3.可靠性保障

    IM可靠性,通过模拟各种异常场景,来检查IM客户端的表现是否符合预期。总的来讲有2个关注点,即:消息不丢,消息不重。我们通过构造以下场景来测试:

    (1)网络异常场景

    网络异常场景主要分弱网和断网。

    弱网场景:通过抓包工具的Throttle Settings,修改上下行速率、丢包率等参数,模拟弱网环境。

    断网场景:在使用过程中,通过断开网络,或者关闭防火墙等方式来模拟断网场景。

    (2)接口异常场景

    通过代理工具,模拟接口未返回、返回异常,或者返回字段类型与约定不一致(例如约定是数字类型,实际返回字符串类型),以及模拟接口返回报文超出边界值等场景。

    (3)服务器异常场景

    服务端服务不可用场景(例如kill单个微服务节点)和服务端资源即将耗尽或者已经耗尽场景(例如修改容器内存或CPU)。

    4.多端一致性保障

    多端一致性,主要指的是PC端和移动端,数据能够互通且准确、实时。

    我们通过构造以下场景来验证多端一致性:

    (1)多端推送场景

    例如多端同时在线情况下,多端要同时收到推送消息,且能查询到推送消息详情,两端接收到推送的时间,相差不能超过1秒。再例如一端在线,另一端离线的情况下,后台给两端推送的时间,也应该保持一致,区别在于离线的那端重新登录后,要能查到离线消息,且消息内容和在线端收到的保持一致。

    (2)多端消息漫游场景

    例如用户仅登录电脑端,收发消息后,然后又登录一台从来没有登录过的新的移动端设备,此时验证用户登录移动端后,能够拉取历史消息(由于考虑到成本和性能等方面 ,大部分系统可能会设置一个诸如最多只能拉取最近200条历史消息的阈值),消息的五个准确性维度都是需要验证的点。

    5.安全性保障

    IM相关的安全测试,主要包括敏感信息是否加密、必要参数是否后端也进行加密、接口是否存在越权请求、SQL注入、XSS攻击、是否能防止拦截篡改等等。其中最常见的是越权测试,例如不在聊天群内的用户,是否会接收到群聊里的消息,是否可以越权调用获取其他群聊的信息等。

    6.移动专项保障

    由于自研IM产品的重要载体是移动App,因此还涉及到移动专项测试,包括:兼容性测试、耗电量测试、流量测试、冷启动性能等。

    四、其他抓手

    充分利用中通测试团队的“探索性测试”虚拟组织,补充测试盲点,提升发现缺陷的效率,同时这也是提升产品体验的好途径。

    而种子用户群的建立,同样也是用户场景的重要补充。结合灰度发布,更是提高缺陷识别的效率,控制发布风险。

    由于篇幅原因,本文不详细介绍中通测试的“探索性测试”活动,后面会有相关类似的文章推出,敬请关注。

    五、总结及展望

    IM测试,看似简单,其实个中门道很深。通过两年的中通自研IM平台测试实践,我们总结出以下经验:

    1.充分的用例场景是质量保障的基石。

    2.接口自动化是回归测试的利器。

    产品还在小步快跑,试错迭代,我们的测试活动并没有停止,同样我们的测试场景和接口脚本还在不停地增长,未来还需要进一步深度探索IM测试。欢迎同行伙伴们一起交流经验。

    现在我邀请你进入我们的软件测试学习交流群:746506216】,备注“入群”, 大家可以一起探讨交流软件测试,共同学习软件测试技术、面试等软件测试方方面面,还会有免费直播课,收获更多测试技巧,我们一起进阶Python自动化测试/测试开发,走向高薪之路。

    喜欢软件测试的小伙伴们,如果我的博客对你有帮助、如果你喜欢我的博客内容,请 “点赞” “评论” “收藏” 一 键三连哦!

    软件测试工程师自学教程:

    这才是2022最精细的自动化测试自学教程,我把它刷了无数遍才上岸字节跳动,做到涨薪20K【值得自学软件测试的人刷】

    接口性能测试 — 软件测试人必会618实战场景分析

    软件测试工程师月薪2W以上薪资必学技能 — Python接口自动化框架封装.

    美团面试真题_高级测试25K岗位面试 — 软件测试人都应该看看

    测试开发之全面剖析自动化测试平台 — 软件测试人的必经之路

    软件测试必会_Jmeter大厂实战 — 仅6步可实现接口自动化测试

    Jmeter实战讲解案例 — 软件测试人必会

    在这里插入图片描述

    在这里插入图片描述

  • 相关阅读:
    需求工程方法的学习
    video_topic
    聊聊MySQL中的死锁
    conda安装pyhanlp遇到的问题及解决方法
    Android 按钮点击设置静音
    jdk线程池ThreadPoolExecutor优雅停止原理解析(自己动手实现线程池)(二)
    【21天Python进阶学习挑战赛】[day3]json标准库大总结
    【Web前端基础进阶学习】HTML详解(下篇)
    centos7 设置默认登陆root
    3.10-容器的操作
  • 原文地址:https://blog.csdn.net/m0_67695717/article/details/126424863