目录
前言
WebSocket介绍
HTTP与WebSocket的区别
二者关系
WebSocket测试方法
使用Postman
使用Jmeter
使用Python
结语
随着Web应用的日益普及,WebSocketSEO靠我作为一种全双工通信协议,在移动端、游戏、视频会议等方面得到广泛应用。
而对于需要实时通信的Web应用来说,WebSocket接口测试是非常重要的一环。然而,许多测试人员在进行WebSocket接口测试时SEO靠我,可能会遇到很多困惑和挑战。这些问题包括如何模拟WebSocket消息、如何进行连接和断开操作以及如何验证返回结果等。
今天,我将分享一些关于WebSocket接口测试的心得和技巧,帮助大家更好地掌握这SEO靠我个技能,无论你是初学者还是有经验的测试人员,相信这篇文章都会给你带来不少启发。
WebSocket 是一种基于在单个 TCP 连接上进行全双工通信的协议,是从HTML5开始提供的一SEO靠我种浏览器与服务器之间进行全双工通讯的网络技术,解决了HTTP协议不适用于实时通信的缺点,相较于 HTTP 协议,WebSocket 协议实现了持久化网络通信,可以实现客户端和服务端的长连接,能够进行双SEO靠我向实时通信,协议名为"ws"。
使用在线工具
在线工具有很多,自行百度吧!个人习惯用这个工具SEO靠我
Postman支持测试WebSocket协议的接口,此文章发布时还处于公测阶段,需要登录后才能使用,入口如下图所示
操作跟测试HTTP请求类似,不过多介绍啦!如下图所示
使用Jmeter既可以单独测接口,也可以进行性能测试,但测试WebSocket协议需要安装插件,下载插件后放到Jmeter安装路径中的lib/ext目录下,重启Jmeter后在【选项】菜单中会出现【PSEO靠我lugins Manager】,然后在可用插件Tab页搜索WebSocket,进行安装即可,如下图所示
安装后新建【线程组】,在添加【取样器】中会出现6项WebSocket的组件
WebSocket ClSEO靠我ose:用于关闭WebSocket连接WebSocket Open Connection:只建立WebSocket连接,不发送数据WebSocket Ping/Pong:用于心跳检测,为了保持长连接,SEO靠我防止客户端被服务端判定为不活跃而被断开WebSocket Single Read Sampler:用于接收一个(文本或二进制)数据WebSocket Single Write Sampler:用于发送SEO靠我一个(文本或二进制)数据WebSocket request-response Sampler:用于执行基本的请求和响应交换,既能发送数据又可以接收数据若有使用过Jmeter就肯定能明白这些组件的使用方SEO靠我法,以WebSocket request-response Sampler为例,页面信息介绍如下图所示
首先需要安装websocket-client
pip install websockSEO靠我et-client对于只是测试WebSocket接口发送接收消息是否正常,不需要长时间连接,可以使用下面的短连接方法,在请求结束后会主动断开连接
from websocket import createSEO靠我_connectionuser1 = create_connection("ws://localhost:6688/1") # 用户1打开连接 user2 = create_conneSEO靠我ction("ws://localhost:6688/2") # 用户2打开连接print("获取响应状态码:", user1.getstatus()) # 正常应返回101 prinSEO靠我t("获取响应头:", user2.getheaders())user1.send("你好呀!") # 用户1向服务端发送消息res1 = user1.recv() # 查看服务端推送的消息 SEO靠我 res2 = user2.recv()if res1 == res2:print("服务端消息推送成功!\n") else:print("消息获取异常!\n")print("查SEO靠我看用户1收到的消息:",res1,"\n查看用户2收到的消息:",res2)若是要对WebSocket接口做持续监听工作,需要长连接,但不需要传参,只是监听消息,使用WebSocketApp类就更合适SEO靠我啦!方法如下
import websocketdef on_open(ws): # 定义用来处理打开连接的方法print("打开连接")def on_message(ws, message): # 定义SEO靠我用来监听服务器返回消息的方法print("监听到服务器返回的消息,:\n", message)def on_error(ws, error): # 定义用来处理错误的方法print("连接出现异常:\SEO靠我n", error)def on_close(ws): # 定义用来处理断开连接的方法print("关闭连接")if __name__ == "__main__":websocket.enableTrSEO靠我ace(True) # 可选择开启跟踪,在控制台可以看到详细的信息ws = websocket.WebSocketApp("ws://localhost:6688",on_open=on_open,oSEO靠我n_message=on_message,on_error=on_error,on_close=on_close)ws.run_forever() # 调用run_forever方法,保持长连接还可以SEO靠我使用Pytest对WebSocket接口实现自动化测试,示例如下
import pytest from websocket import create_connectionclass TSEO靠我estDyd():url = "ws://localhost:6688"@classmethoddef setup_class(cls):cls.ws = create_connection(cls.SEO靠我url) # 建立连接cls.ws.settimeout(5) # 设置超时时间def test_connect(self):# 通过状态码判断连接是否正常assert self.ws.getstatSEO靠我us() == 101def test_send(self):params = "你好呀!" # 定义传参self.ws.send(params) # 发送请求result = self.ws.recSEO靠我v() # 获取响应结果print("收到来自服务端的消息:", result) # 打印响应结果# 因为该测试项目传参会显示在响应中,所以通过判断传参是否在响应结果中进行断言assert paramSEO靠我s in resultif __name__ == __main__:pytest.main(["-vs"])传参可以使用@pytest.mark.parametrize()装饰器,示例如下
imporSEO靠我t pytest from websocket import create_connectionclass TestDyd():data = [("/user/2", "今天开直播卖鱼SEO靠我!!!!"),("/user/3", "鱼可以买来放生吗?"),("/user/4", "那条翻白肚的鱼有死亡证明吗?"),("/user/5", "你的鱼会唱歌吗?"),("/user/6", "你SEO靠我的鱼上大学了吗?"),("/user/7", "你的鱼买回来需要隔离吗?")]@pytest.mark.parametrize("user, word", data)def test_send(selSEO靠我f, user, word):ws = create_connection("ws://localhost:6688"+user)params = word ws.send(params) # 发送请SEO靠我求result = ws.recv() # 获取响应结果print("来自服务端的消息:", result)assert params in result # 断言先简单介绍这些吧,关于Python脚SEO靠我本,可以参考官方文档,里面有示例和常见问题解决方法
这篇贴子到这里就结束了,最后,希望看这篇帖子的朋友能够有所收获。
如果你觉得文章还不错,请大家 点赞、分享、留言下,因为这将是我持续输出更多优质文章的SEO靠我最强动力!
网站备案号:浙ICP备17034767号-2