如何写接口自动化?

如何写接口自动化?这个问题,但凡涉足过自动化测试的人员都能娓娓道来。

Requests、urlib、jmeter、curl等等,不在话下。那么,如何获取接口的url、参数、响应等信息呢?!答案就更是随口而出:看接口文档、swagger/apifox等管理工具接口定义。

再不济,如果是web应用,通过浏览器看接口请求啊。的确如此,有“一万”种方法可以帮助我们获取到想要的接口信息。

可是,接口文档和接口定义/说明的有无,往往取决于开发人员的自觉性。

我们虽然能够要求,但也不能百分百确定一定能够获得。因此,通过浏览器等工具获取请求接口就成了我们常用的手段。

我们以访问“51testing”网站为例,简单说明浏览器获取接口请求的常见方式。

如下图1所示,为访问51testing网站首页时的浏览器面板截图。通过network>Fetch/XHR就能获得http请求的url、status、response等信息。

在我们编写自动化测试用例时,这是常用且熟知的获取接口请求信息的方法。

图1 访问51testing首页的浏览器network面板信息

但是,上述寻找接口路径/方法,是完全可行的吗?让我们以下图2为例。

图2为51testing客服对话窗口,当我们想模拟自动化测试,获取发送请求的接口信息时,却发现唯一一个通过Fetch/XHR获得的接口(https://chat2445.talk99.cn/chat/msg.dll?cmd=xx)请求体Payload和响应体Response中,没有任何与窗口对话中发送的内容(“测试”)有关的信息。

那么,这条信息,是如何发送出去的呢?!

图2 51testing客服对话窗口

继续对话,查看Fetch/XHR,仍无任何接口请求。直到……在WS条目中发现了真相。原来,是websocket啊;果然,是websocket啊!

图3 51testing客服对话窗口

websocket简介及使用

那么,什么是websocket呢?又为何要用websocket呢?

WebSocket 是一种在 Web 应用程序中提供双向通信的协议。

它允许在客户端和服务器之间创建持久性的连接,从而使得数据能够以低延迟和高效率进行双向传输。

一些常见应用场景包括:

  1. 即时通讯应用程序:像聊天应用、在线游戏等需要实时双向通信的应用场景中,WebSocket 能够提供更好的性能和用户体验;

  2. 实时数据更新:像股票市场、天气预报、实时地图等需要实时数据更新的应用中,WebSocket 可以用来推送实时数据给客户端,而不需要客户端不断地发起请求;

  3. 在线协作工具:像 Google Docs、Trello 等在线协作工具可以使用 WebSocket 来实现多用户实时编辑、更新等功能;

  4. 实时游戏:在线多人游戏需要实时的玩家位置、动作等信息同步,WebSocket 可以帮助实现这些功能。显而易见,客服对话窗属于第1种。

那么,websocket的url、请求内容和响应如何在浏览器中获取呢?!

如下图4所示,可以点击ws的链接,通过Request URL得到的url,再通过Messges获得发送的请求(All下拉列表选择“send”)和收到的响应(All下拉列表选择“receive”)。

图4 websocket的url、请求和响应等查看方式

如此,我们知道了,我们一些“看不见”的接口是如何发送请求的了。

但是问题又来了:知道了websocket的请求方式,如何使用自动化脚本方式模拟呢?

我们以python为例,使用websocket库,模拟websocket请求,发送聊天信息。代码样例如下所示:

1.import websocket

2.import json

3.

4.def on_message(ws, message):

5. print(f"Received message: {message}")

6.

7.def on_error(ws, error):

8. print(f"Error occurred: {error}")

9.

10.def on_close(ws):

11. print("Connection closed")

12.

13.def on_open(ws):

14. print("Connection established")

15. # 发送消息

16. message = {

17. "c": 20001818,

18. "u": "e6054702278504214c792f583376d5ab",

19. "v": "6817201c3614948f68de93ab151e53e5",

20. "role": 2,

21. "meeting": False,

22. "cId": 876105175,

23. "site": 0,

24. "g": 10063915,

25. "winId": "b6f2f684f577413abb2ab166433b060e",

26. "flag": False,

27. "robot": False,

28. "msg": "你好"

29. }

30. ws.send(json.dumps(message))

31.

32.if __name__ == "__main__":

33. websocket.enableTrace(True)

34. ws = websocket.WebSocketApp("wss://chat2445.talk99.cn/chat/room/20001818/876105175/b6f2f684f577413abb2ab166433b060e",

35. on_message=on_message,

36. on_error=on_error,

37. on_close=on_close)

38. ws.on_open = on_open

39. ws.run_forever()

至此,我们简单总结一下。浏览器开发者工具功能十分强大,除了我们熟知的http请求,还可以捕获websocket请求。

然后,我们可以通过得到的请求信息,使用Python或其他开发语言帮助我们完成相关的接口测试。由此,完成我们“看不见”的接口自动化测试。

最后: 下方这份完整的软件测试视频教程已经整理上传完成,需要的朋友们可以自行领取【保证100%免费】

​​​软件测试面试文档

我们学习必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有字节大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。

在这里插入图片描述

在这里插入图片描述

Logo

火山引擎开发者社区是火山引擎打造的AI技术生态平台,聚焦Agent与大模型开发,提供豆包系列模型(图像/视频/视觉)、智能分析与会话工具,并配套评测集、动手实验室及行业案例库。社区通过技术沙龙、挑战赛等活动促进开发者成长,新用户可领50万Tokens权益,助力构建智能应用。

更多推荐