news 2026/4/18 13:07:16

接口自动化测试思路和实战:编写线性测试脚本实战

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
接口自动化测试思路和实战:编写线性测试脚本实战

🍅点击文末小卡片,免费获取软件测试全套资料,资料在手,涨薪更快

接口自动化测试框架目的

测试工程师应用自动化测试框架的目的:增强测试脚本的可维护性、易用性(降低公司自动化培训成本,让公司的测试工程师都可以开展自动化测试)。

自动化测试框架根据思想理念和深度不同,渐进式的分为以下几种:

线性脚本框架

模块化思想==>模块化测试脚本框架

库思想==>测试库框架。

数据驱动思想==>数据驱动测试框架

关键字驱动思想==>关键字驱动或表驱动的测试框架

上述思想融合完成企业实际自动化==>混合测试自动化框架

编写线性测试脚本实战

接口用例excel;

步骤1、新建项目名API_TEST_FRAME,在项目的下面新建不同层级;如下图

步骤2、根据接口文档的层级,在项目中的testcase层下新建层级;如下图

步骤3、在begin_dev下新建test_get_access_token_api.py文件,并编写代码

编写代码:

# encoding: utf-8 # @author: Jeffrey # @file: test_get_access_token_api.py # @time: 2022/7/24 18:08 # @desc: 导入模块顺序:内置模块、第三方模块、自定义模块 import unittest import requests import jsonpath class TestGetAccessTokenApi(unittest.TestCase): def setUp(self) -> None: self.session = requests.session() def tearDown(self) -> None: self.session.close() def test_case_01(self): '''[api_case_01] 测试获取access_token能否正常调用''' url_params = {"grant_type":"client_credential", "appid":"wxf14419077f707856", "secret":"92a113bd4b5ffdc72144740dc7123c99"} response = self.session.get(url="https://api.weixin.qq.com/cgi-bin/token", params = url_params) # 获取响应json中的access_token的值 actual_result = jsonpath.jsonpath(response.json(), "$.access_token") print(actual_result) self.assertTrue(actual_result, "api_case_01 执行失败") #非空,非0 都返回True为真 def test_case_02(self): '''[api_case_02] 测试获取access_token接口在appid错误时,能否正常处理错误''' url_params = {"grant_type":"client_credential", "appid":"wxf14419077f707", "secret":"92a113bd4b5ffdc72144740dc7123c99"} response = self.session.get(url="https://api.weixin.qq.com/cgi-bin/token", params = url_params) # 获取响应json中的errcode的值,因为jsonpath返回的是列表,故加上下标0 actual_result = jsonpath.jsonpath(response.json(), "$.errcode")[0] print(actual_result) self.assertEqual(actual_result,40013, "api_case_02 执行失败") if __name__ == '__main__': unittest.main(verbosity=2)

执行查看结果:

步骤4、按照开发文档中的用户标签管理,新建test_create_user_tag_api.py文件

编写代码:

# encoding: utf-8 # @author: Jeffrey # @file: test_create_user_tag_api.py # @time: 2022/7/24 19:02 # @desc: import unittest import requests import jsonpath import json class TestCreateUserTagApi(unittest.TestCase): def setUp(self) -> None: self.session = requests.session() def tearDown(self) -> None: self.session.close() def test_case_01(self): '''[api_case_03] 测试正常进行创建标签接口调用''' url_params = {"grant_type":"client_credential", "appid":"wxf14419077f707856", "secret":"92a113bd4b5ffdc72144740dc7123c99"} response = self.session.get(url="https://api.weixin.qq.com/cgi-bin/token", params = url_params) # 获取响应json中的access_token的值 token_value = jsonpath.jsonpath(response.json(), "$.access_token")[0] tag_url_params = {"access_token":token_value} tag_boby = { "tag": { "name":"深圳人2" } } # 解决中文乱码问题;模拟post请求时,携带json 数据包含中文发送给服务器会转码 # 方式一:json.dumps() tag_str = json.dumps(tag_boby, ensure_ascii=False) response = self.session.post(url="https://api.weixin.qq.com/cgi-bin/tags/create", params = tag_url_params, data=tag_str.encode('utf-8')) print(response.json()) # # 方式二:修改requests中的models.py中的源码,修改完后 # response = self.session.post(url="https://api.weixin.qq.com/cgi-bin/tags/create", # params=tag_url_params, # json=tag_boby) # print(response.json()) # 获取响应json的tag的name值,因为jsonpath返回的是列表,故加上下标0 actual_result = jsonpath.jsonpath(response.json(), "$.tag.name")[0] self.assertEqual(actual_result,"深圳人2", "api_case_03 执行失败") if __name__ == '__main__': unittest.main(verbosity=2)
Requests模拟post请求时,如何处理携带json 数据包含中文发送给服务器会转码的问题?
方式一:如下图

方式二:如下图

执行结果

继续新建test_update_user_tag_api.py文件和test_delete_user_tag_api.py文件;自己拓展

步骤5、把用例整合一起执行,在runner文件下的run_api_tests.py中编写代码:

编写代码:

# encoding: utf-8 # @author: Jeffrey # @file: run_api_tests.py # @time: 2022/7/24 17:52 # @desc: import os import unittest # 获取当前路径 current_path = os.path.dirname(os.path.abspath(__file__)) # 测试用例路径 case_path = os.path.join(current_path, '../testcases') discover_obj = unittest.defaultTestLoader.discover(start_dir=case_path, pattern='test*.py') all_case_suite = unittest.TestSuite() # 把discover对象发现的用例加载到测试套件中 all_case_suite.addTest(discover_obj) unittest.main(defaultTest="all_case_suite", verbosity=2)

查看执行结果:

步骤6、生成测试报告,把HTMLTestReportCN.py文件放到common文件夹中并在run_api_tests.py文件中调整代码;

编写代码:

# encoding: utf-8 # @author: Jeffrey # @file: run_api_tests.py # @time: 2022/7/24 17:52 # @desc: import os import unittest from common import HTMLTestReportCN # 获取当前路径 current_path = os.path.dirname(os.path.abspath(__file__)) # 测试用例路径 case_path = os.path.join(current_path, '../testcases') discover_obj = unittest.defaultTestLoader.discover(start_dir=case_path, pattern='test*.py') all_case_suite = unittest.TestSuite() # 把discover对象发现的用例加载到测试套件中 all_case_suite.addTest(discover_obj) # unittest.main(defaultTest="all_case_suite", verbosity=2) report_path = os.path.join(current_path, '../reports/result.html') html_file_obj = open(report_path, 'wb') html_runner = HTMLTestReportCN.HTMLTestRunner(stream=html_file_obj, title='接口接口自动化测试', tester='YOU', description='学习接口框架') html_runner.run(all_case_suite)

执行后查看报告:

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于做【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!凡事要趁早,特别是技术行业,一定要提升技术功底。

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

一文读懂多模态大模型(MM-LLMs)的核心架构与组件

文章介绍了多模态大模型(MM-LLMs)的概念和架构。这类模型能处理文本、图像、声音等多种数据,其核心组件包括:模态编码器(转换输入数据为特征)、输入投影器(统一模态到共享空间)、语言模型(核心处理)、输出投影器(转换输出)和模态生成器(生成最终内容)。这…

作者头像 李华
网站建设 2026/4/18 8:09:54

如何用3个核心步骤实现3DS无线文件高效传输?

如何用3个核心步骤实现3DS无线文件高效传输? 【免费下载链接】3DS-FBI-Link Mac app to graphically push CIAs to FBI. Extra features over servefiles and Boop. 项目地址: https://gitcode.com/gh_mirrors/3d/3DS-FBI-Link 一、传统传输模式的技术瓶颈分…

作者头像 李华
网站建设 2026/4/18 8:38:49

开源中文字体的突围之路:霞鹜文楷如何重塑现代排版体验

开源中文字体的突围之路:霞鹜文楷如何重塑现代排版体验 【免费下载链接】LxgwWenKai LxgwWenKai: 这是一个开源的中文字体项目,提供了多种版本的字体文件,适用于不同的使用场景,包括屏幕阅读、轻便版、GB规范字形和TC旧字形版。 …

作者头像 李华
网站建设 2026/4/16 14:07:48

一文读懂统一多模态大模型:从编码到应用的全面指南

本文综述了统一多模态基础模型(UFM)的研究进展,分析了从"专才"到"通才"的必要性,详细探讨了编码、解码、建模等技术路线及训练方法,指出UFM能打破单模态局限,实现理解与生成的统一,为迈向AGI奠定基…

作者头像 李华
网站建设 2026/4/18 8:31:11

阿里Java面试被问:RocketMQ事务消息的二阶段提交实现

一、事务消息核心原理 1.1 事务消息解决的问题 在分布式系统中,保证本地事务与消息发送的原子性。 1.2 二阶段提交流程 java 复制 下载 // 事务消息的完整流程 ┌─────────────────┐ 1.发送半消息 ┌────────────────…

作者头像 李华