软件测试 / 测试开发丨 RPC 接口测试技术 -Tcp 协议的接口测试
获取更多相关知识
首先明确 Tcp 的概念,针对 Tcp 协议进行接口测试,是指基于 Tcp 协议的上层协议比如 Http ,串口,网口, Socket 等。这些协议与 Http 测试方法类似(具体查看接口自动化测试章节),但在测试过程中需要做些调整。
Socket
Socket 又称套接字,进程可通过套接字进行网络通信,使多个设备具有交互能力。Socket 适合对传输速度和安全性有严格要求的应用,比如手机内核与外界进行测试数据的传输。支持 Socket 设备不止计算机,还会有移动端,如果测试 Socket 协议,需要有收发 Socket 数据的能力或代理 Socket 的能力。
下图展示了正常的 Socket 通信流程:
如果测试 Socket 协议,需要做以下改造,即利用 Socket 代理,进行 Socket 数据的接收:
需要特别注意,需要应用可更改 Socket 地址,才可使用代理。以 Python 的 Socket 为例,下面是一个简单的 Socket 客户端和服务端:
客户端可与服务端进行交流,但 Socket 地址不可更改,即上述客户端代码的 127.0.0.1
和 12345
端口不能通过配置文件进行更改。如果不能更改这两者,就堵死了通向代理的道路:
如何进行修改?以客户端代码为例,可通过配置文件来配置 host 和 port :
config.yaml 的内容如下:
上述更改,可使应用走 Socket 代理。测试人员还需一款合适的代理工具,推荐 mitmproxy 或自写 Socket 代理。mitmproxy 使用请参考:
mitmproxy 官网:www.mitmproxy.org/
其他协议
其它协议,比如串口、网口、visa 等,与 Socket 的测试模式类似,用相同的图即可简述:
其它协议较 Sokcet 更冷门,无合适的代理工具。需要测试人员自己写代理,比如串口协议, Python 虽然支持 Pyserial 进行收发串口,但无代理。此时需要测试人员自行编写串口代理工具。这个过程需要开启两个监听服务,如下图,监听服务 A 监听端口 123 ,如果有数据进来,会透传(或做数据更改,实现 mock)给端口 456,监听服务 B 同理:
使用两个监听服务,可编写任意协议,但注意缺点,数据的传输时间会增加,如果过分注重性能,此方案慎用。下面是参考代码,其中只保留了关键逻辑:
再次强调,需要让应用支持端口修改,才能使用代理工具,这部分需要与开发交流,提修改需求。
版权声明: 本文为 InfoQ 作者【测试人】的原创文章。
原文链接:【http://xie.infoq.cn/article/6ae6ca888c61e51eb141fcb6a】。文章转载请联系作者。
评论