首先明确 Tcp 的概念,针对 Tcp 协定进行接口测试,是指基于 Tcp 协定的下层协定比方 Http ,串口,网口, Socket 等。这些协定与 Http 测试方法相似(具体查看接口自动化测试章节),但在测试过程中须要做些调整。

Socket

Socket 又称套接字,过程可通过套接字进行网络通信,使多个设施具备交互能力。Socket 适宜对传输速度和安全性有严格要求的利用,比方手机内核与外界进行测试数据的传输。反对 Socket 设施不止计算机,还会有挪动端,如果测试 Socket 协定,须要有收发 Socket 数据的能力或代理 Socket 的能力。
下图展现了失常的 Socket 通信流程:

如果测试 Socket 协定,须要做以下革新,即利用 Socket 代理,进行 Socket 数据的接管:

须要特地留神,须要利用可更改 Socket 地址,才可应用代理。以 Python 的 Socket 为例,上面是一个简略的 Socket 客户端和服务端:

# 客户端import socket               # 导入 socket 模块s = socket.socket()         # 创立 socket 对象host = '127.0.0.1'          # 获取本地主机名port = 12345                # 设置端口号s.connect((host, port))print(s.recv(1024).decode())s.close()
# 服务端import socket               # 导入 socket 模块s = socket.socket()         # 创立 socket 对象host = '127.0.0.1'          # 获取本地主机名port = 12345                # 设置端口s.bind((host, port))        # 绑定端口s.listen(5)                 # 期待客户端连贯while True:    c,addr = s.accept()     # 建设客户端连贯    print(addr)    c.send('收到信息'.encode())    c.close()                # 敞开连贯

客户端可与服务端进行交换,但 Socket 地址不可更改,即上述客户端代码的 127.0.0.1 和 12345 端口不能通过配置文件进行更改。如果不能更改这两者,就堵死了通向代理的路线:

如何进行批改?以客户端代码为例,可通过配置文件来配置 host 和 port :

import socketimport yaml# 通过配置文件,进行 host 和 port 配置with open("config.yaml","r", encoding="utf-8") as f:    data = yaml.safe_load(f)host = data.get("host")port = data.get("port")s = socket.socket()s.connect((host, port))print(s.recv(1024).decode())s.close()

config.yaml 的内容如下:

host: "127.0.0.1"port: 12345

上述更改,可使利用走 Socket 代理。测试人员还需一款适合的代理工具,举荐 mitmproxy 或自写 Socket 代理。mitmproxy 应用请参考:
mitmproxy 官网:https://www.mitmproxy.org/

其余协定

其它协定,比方串口、网口、visa 等,与 Socket 的测试模式相似,用雷同的图即可简述:

其它协定较 Sokcet 更冷门,无适合的代理工具。须要测试人员本人写代理,比方串口协定, Python 尽管反对 Pyserial 进行收发串口,但无代理。此时须要测试人员自行编写串口代理工具。这个过程须要开启两个监听服务,如下图,监听服务 A 监听端口 123 ,如果有数据进来,会透传(或做数据更改,实现 mock)给端口 456,监听服务 B 同理:

应用两个监听服务,可编写任意协定,但留神毛病,数据的传输工夫会减少,如果过分重视性能,此计划慎用。上面是参考代码,其中只保留了要害逻辑:

def forward(self):    """    开启监听    :return:    """    while True:        # 从虚构串口接管到申请        virtual_req = self.virtual_ser.recv()        if b'' == virtual_req:            continue        if self.is_call_back:            # 返回空值,让 mock_server 决定返回内容            real_result = b""        else:            # 期待实在设施呈现            if self.real_ser is None :               # 代码省略            # 将申请转发到实在串口            real_result = self.real_ser.write_by_bytes(virtual_req)        # 获取 mock 的后果,在此能够退出 mock 操作        mock_result = self.mock_server.mock(virtual_req, real_result)        # 将 mock 后果写入虚构串口        self.virtual_ser.send(mock_result)

再次强调,须要让利用反对端口批改,能力应用代理工具,这部分须要与开发交换,提批改需要。