news 2026/6/23 14:34:02

接口自动化测试中解决接口间数据依赖

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
接口自动化测试中解决接口间数据依赖

在实际的测试工作中,在做接口自动化测试时往往会遇到接口间数据依赖问题,即API_03的请求参数来源于API_02的响应数据,API_02的请求参数又来源于API_01的响应数据。

因此通过自动化方式测试API_03接口时,需要预先请求API_02接口,获取到API_03的请求参数,而获取API_02的响应又需要预先对API_01发起请求,从响应中提取API_02的请求参数。

而下面的自动化框架设计便解决了这一问题:

用于数据驱动的Excel表格设计

框架代码实现逻辑

当测试 id 为 shop-03 的接口时,首先判断【是否运行】。如果为 ‘yes’ 则判断该接口请求类型, ‘POST’ OR ‘GET’ 走不同的逻辑分支。

POST请求的话判断是否有【case依赖】,【case依赖】为空则无依赖,不为空则获取依赖的case id。

上述表格中,shop-03的case依赖为shop-02,获取到依赖的id后,代码逻辑主动去判断shop-02接口的相关字段参数(【是否运行】/【请求类型】/【case依赖】),如果shop-02也存在依赖接口shop-01,则代码继续判断shop-01接口对应字段参数。

shop-01接口【case依赖】字段为空时,获取【请求数据】根据请求数据这个字段获取单独存储在字典中的完整的请求参数,发起请求,获得shop-01的响应后根据shop-01对应的【被依赖接口的返回数据】提取下游接口。

即shop-02的所需要的依赖参数,存入一个依赖参数列表中,shop-02接口把获取到的参数代入到请求参数中进行请求,获取到shop-02的响应后同样根据【被依赖接口的返回数据】提取下游接口shop-03所需要的依赖参数,存入依赖参数列表,shop-03接口从列表中获取这个参数代入请求参数,进入请求,获取响应,根据【实际结果取值字段】获取要断言的字段,并对比预期结果完成该接口的测试。

# 主逻辑模块部分代码示例 '''判断是否有case依赖,如果有case依赖则执行depend_data.py中的depend_response_data(self,caseid)方法,该方法返回该接口发起请求的依赖参数''' elif method == 'Post': if depend_caseid: params_data_list = self.depend_result.depend_response_data(depend_caseid) log_info('main_logic.requests_api::根据依赖的caseid={},' '调用depend_data.depend_response_data获取到的依赖数据为:{}'.format(depend_caseid, params_data_list)) for j in range(len(depend_key_list)): params[depend_key_list[j]] = params_data_list[j][0] header = rquests_headers() log_info('main_logic.requests_api::执行的用例{}请求url为:{},入参为:{},请求头为:{}'.format(caseid,url,params,header)) response = self.post_requests(url, params, header) # print(response) self.results_list.append(response) else: header = rquests_headers() response =self.post_requests(url, params, header) # print(response) self.results_list.append(response)
#数据依赖模块部分代码示例 '''通过excel表中【case依赖】字段一层层向上游接口请求,结果储存在一个结果列表中供下游接口调用,最后返回测试接口所需要的依赖数据''' def depend_response_data(self,caseid): depend_caseid_t = self.excel_case_data.get_depend_caseid(caseid) depend_caseid_list = [] #如果case依赖字段不为空 if depend_caseid_t: #获取接口串联依赖caseid列表 while depend_caseid_t: depend_caseid_list.append(depend_caseid_t) depend_caseid_t = self.excel_case_data.get_depend_caseid(depend_caseid_t) depend_caseid_list.reverse() depend_caseid_list.append(caseid) march_result_list = [] num_caseid = len(depend_caseid_list) #迭代获取列表中的caseid for i in range(num_caseid): depend_caseid_s = self.excel_case_data.get_depend_caseid(depend_caseid_list[i]) depend_key_list = self.excel_case_data.get_depend_key(depend_caseid_list[i]).split(",") params_key = self.excel_case_data.get_request_key(depend_caseid_list[i]) params = self.requests_data[params_key] url = self.excel_case_data.get_url(depend_caseid_list[i]) #判断该caseid的测试用例中case依赖是否为空 if depend_caseid_s: #获取上一个依赖接口返回的依赖参数 params_data_list = march_result_list[i-1] #根据该caseid数据依赖字段构造该接口的传参 for k in range(len(depend_key_list)): params[depend_key_list[k]] = params_data_list[k][0] #对该接口发起请求 header = rquests_headers() result = post_requests(url, params, header) getdata = GetExcelDate() is_depend_response = getdata.get_depend_response(depend_caseid_list[i]) #判断该接口是否需要为下一接口返回依赖参数 if is_depend_response: depend_response_list = is_depend_response.split(",") results = result matchlist = depend_response_list matchparams = match_params(results, matchlist) march_result_list.append(matchparams) else: print("caseid={}不需要返回被依赖的字段".format(depend_caseid_list[i])) #当该caseid测试用例中case依赖为空时直接请求该接口,返回匹配到的下一关联接口的请求参数 else: result = self.depend_response(depend_caseid_list[i]) getdata = GetExcelDate() is_depend_response = getdata.get_depend_response(depend_caseid_list[i]) if is_depend_response: depend_response_list = is_depend_response.split(",") results = result matchlist = depend_response_list matchparams = match_params(results, matchlist) march_result_list.append(matchparams) else: print("caseid={}不需要返回被依赖的字段".format(depend_caseid_list[i])) return matchparams

最后作为一位过来人也是希望大家少走一些弯路,在这里我给大家分享一些软件测试的学习资料和我花了3个月整理的软件测试自学全栈,这些资料希望能给你前进的路上带来帮助。

视频文档获取方式:
这份文档和视频资料,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!以上均可以分享,点下方小卡片即可自行领取。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/23 16:54:13

美国国务院恢复 Times New Roman 字体

如果你写过本硕论文,或有在政府机关的工作经历,或你的公司对标准化有很强的管理流程。那你一定对Times New Roman 字体不陌生,它被认为是最佳的英文字体。 Times New Roman是一款诞生于1932年的过渡型衬线字体,由Monotype公司为英…

作者头像 李华
网站建设 2026/6/23 12:35:53

ionet 25.2 发布

核心是一个由Java编写的、宣称能达到纳秒级延迟的分布式网络编程框架。 📝 框架核心特点与技术架构 特性维度具体说明核心目标构建高性能、稳定、易用的分布式网络通信服务器。技术基础基于 Aeron(高性能消息传输库) SBE(简单二…

作者头像 李华
网站建设 2026/6/23 8:02:24

谁还不知道!2025年这4款免费AI写歌工具

有没有和我一样喜欢用ai生图的人,现在ai已经发展到可以一键生歌了。这4款免费AI写歌工具,直接打开了音乐创作的新世界!不用懂任何音乐知识,输入文字就能生成完整歌曲!�� 蘑兔AI - 中文创作党首选…

作者头像 李华
网站建设 2026/6/23 11:43:44

OpenNJet v3.3.1.3

OpenNJet v3.3.1.3 是一个最新的修复版本,于今日(2025年12月15日)发布。这个版本主要专注于修复已知问题,提升稳定性。 版本更新内容 根据发布信息,此版本主要修复了以下三个问题: 动态Lua进程卡死&#x…

作者头像 李华
网站建设 2026/6/23 14:54:30

续约上港!张琳芃 400 万冲第 12 冠

当转会传闻在球迷社群中发酵时,张琳芃的续约决定已悄然落地。一年合约,年薪锁定在400万区间,比传闻中申花的报价还略高一线。这不是一次简单的续约,而是这位手握11枚中超冠军戒指的老将,对职业生涯终章的精心布局。申花…

作者头像 李华