当前位置: 首页 > news >正文

python+requests 接口自动化测试实战

首先介绍一下python的requests模块:

requests的使用介绍:requests快速入门

Python结合requests库实现接口自动化测试

环境说明:

1.WIN 7, 64位
2.Python3.4.3 (pip-8.1.2)
3.Requests —>pip install requests
4.Unittest —>unittest 框架是python自带的单元测试框架,python2.1及其以后的版本已将unittest作为一个标准块放入python开发包中,所以unittest不用单独安装。
5.测试报告利用HTMLTestRunner生成。

测试思路:

1、先把每个http接口一个一个写脚本测试。(提交的json串直接放在data字典中,这里没有用到excel等写测试用例,测试用例直接用脚本实现。)
2、写完所有接口的测试脚本后,由于一个接口有好几个测试用例,所有要把同一个接口的py脚本封装成方法,每一个接口封装成一个接口类。
3、用testsuite直接调用这些接口类,构造测试集;或利用unittest自动识别测试用例,TestLoader类中提供的discover()方法。
(命名规则:接口名称要以test_XXX开头)
就好把所有的接口测试用例连起来构建自动化测试了。
4、最后利用HTMLTestRunner生成测试报告。

PUT:上传指定的URL,一般是修改,可以理解为数据库中的update。

DELETE:删除指定资源。

在接口测试中,一般来说,post创建数据,get获取创建成功后的所有数据和指定的数据,put可以对创建成功后的数据 进行修改,delete是指定的资源。

目录结构:

单个接口测试例子:

post(修改)

import requestsimport jsondef get_token():url1 = "https://**********/Token/get"content = {'appId':'***','appSecret':'******'}web = requests.get(url=url1,params=content)print(web.url)print(web.text)ty = web.texta = json.loads(ty)b = a.get('Data')apptoken = b.get('Token')return apptokenif __name__ == '__main__':get_token()复制代码

get(查询)

import requestsimport jsondef test_qualification_add():url = "http://xxx.xxx.xxx/audit/api/xxx/get" #测试的接口urlheaders = {"Content-Type":"application/json"}data = { #接口传送的参数"token": "abcdefg","id": 1,"param": {"QuId":1}}r = requests.post(url = url,json = data,headers = headers) #发送请求#return r.jsonprint (r.text) #获取响应报文print (r.status_code)if __name__=="__main__":test_qualification_add()复制代码

其中requests.post和requests.request两种写法,都可以实现请求。

在进行接口测试的过程中对传入的参数进行边界值测试、错误推导测试、等价类测试等测试方法进行测试。那么一个接口就要设很多测试用例。

【点击打开下方小卡片无偿领取200G软件测试全套资料】【软件测试全套资料】包括:(软件测试理论教程、App测试教程、接口测试教程、Linux教程、MySQL教程、Python编程基础教程、APP自动化教程、项目实战、Web自动化教程、接口自动化教程、测试框架技术教程、持续集成教程、自动化测试开发教程、测试用例、性能测试教程、安全测试教程、高频面试题、简历模板合集)

​编辑【网盘资源】200G功能测试+自动化教程, 简历模版,高频面试真题【无偿分享】10 赞同 · 10 评论文章

下面是封装为接口类的例子:

(一个接口地址一个类,每一个方法是一条测试用例)
(setUp()、tearDown()方法会分别作用于每个测试用例的开始和结束,如果每个类中的setUp()、tearDown(),所做的事情一样,那么可以封装一个自己的测试类,如代码:)\

import requestsimport jsonimport unittestclass MyTest(unittest.TestCase): #封装测试环境的初始化和还原的类def setUp(self): #放对数据可操作的代码,如对mysql、momgodb的初始化等,这里不对数据库进行操作!print("start test")passdef tearDown(self): #与setUp()相对print("end test")passclass test_xxx_get(MyTest): #把这个接口封装一个类,下面的方法是具体的测试用例'''接口名称:获取资质''' #这个描述接口名称def test_xxx_get(self):'''测试用例1:哈哈''' #这个描述接口用例名称self.url = "http://xxx.xxx.xxx/audit/api/xxx/get" #请求urlself.headers = {"Content-Type":"application/json"}self.data = { #请求参数"token": "abcdefg","id": 1,"param": {"QuId": 14}} #self.用在方法属性中,表示是该方法的属性,不会影响其他方法的属性。r = requests.post(url = self.url,json = self.data,headers = self.headers)#return r.json()print (self.r.text)print (self.r.status_code)self.assertIn("true",self.r.text) #断言判断接口返回是否符合要求,可以写多个断言!if __name__=="__main__":unittest.main()复制代码

 unittest提供了全局的main()方法,使用它可以方便的将一个单元测试木块变成可以直接运行的测试脚本;
main()方法使用TestLoader类来搜索所有包含在该木块中以“test”命名开头的测试方法,并自动执行它;\

执行方法的默认顺序是:根据ASCII码的顺序加载测试用例,数字与字母的顺序为:0-9,A-Z,a-z。所以以A开头的测试用例方法会优先执行,以a开头会后执行。
所以每一个接口类、测试用例要以test*命名,如下图:
(测试用例放在同一个文件夹:)
\

runtest.py写法:

import unittestimport jsonimport requestsfrom HTMLTestRunner import HTMLTestRunnerimport time#加载测试文件 (有几多个接口就加载几多个,一个一个加进来)import test_creative_addimport test_creative_getimport test_qualification_addimport test_qualification_getimport test_qualification_reflesh#构造测试集suite = unittest.TestSuite() #实例化#TestSuite类的addTest()方法把不同测试类中的测试方法组装到测试套件中。#增加测试用例==》接口文件名.接口类(方法也就是这个接口的其他用例),要把每一个测试用例都增加进来!!!suite.addTest(test_creative_add.test_creative_add("test_creative_add")) #增加创意suite.addTest(test_creative_get.test_creative_get("test_creative_get")) #获取创意suite.addTest(test_qualification_add.test_qualification_add("test_qualification_add"))#增加资质suite.addTest(test_qualification_get.test_qualification_get("test_qualification_get"))#获取资质suite.addTest(test_qualification_reflesh.test_qualification_reflesh("test_qualification_reflesh"))#更新资质if __name__=="__main__":testunit = unittest.TestSuite()testunit.addTest(suite)#按照一定的格式获取当前的时间now = time.strftime("%Y-%m-%d %H_%M_%S")#定义报告存放路径filename = './' + now + 'test_result.html'fp = open(filename,"wb")#定义测试报告runner = HTMLTestRunner(stream = fp,title = "xxx接口测试报告",description = "测试用例执行情况:")#运行测试runner.run(testunit)fp.close() #关闭文件对象把数据写进磁盘复制代码

如果有几百条测试用例,在runtest脚本中一个个增加测试用例,那么就很麻烦啦,其实用discover()一步就搞掂了。
discover函数介绍:
discover(start_dir,pattern=’test*.py’,top_level_dir=None)

找到指定目录下所有测试模块,并可递归查到子目录下的测试木块,只有匹配到的文件名才会被加载。如果启动的不是顶层目录,那么顶层目录必然单独指定。
start_dir:要测试的木块名或测试用例的目录。
pattent=‘test .py’:表示用例文件名的匹配原则。此处匹配文件名一test开头的所有.py类型文件, 表示任意多个字符。
top_level_dir=None :测试木块的顶层目录,如果没有顶层目录,默认为None。
这里测试用例都放在同一个目录,都以test*.py的形式!!(如上图)\

runtest2.py写法:

import unittestimport jsonimport requestsfrom HTMLTestRunner import HTMLTestRunnerimport time#定义测试用例的目录为当前目录test_dir = './'discover = unittest.defaultTestLoader.discover(test_dir,pattern = 'test*.py')if __name__=="__main__":#按照一定的格式获取当前的时间now = time.strftime("%Y-%m-%d %H-%M-%S")#定义报告存放路径filename = './' + now + 'test_result.html'fp = open(filename,"wb")#定义测试报告runner = HTMLTestRunner(stream = fp,title = "xxx接口测试报告",description = "测试用例执行情况:")#运行测试runner.run(discover)fp.close() #关闭报告文件复制代码

整合自动化测试发送测试报告:

runtest_mail.py

import unittestimport requestsfrom HTMLTestRunner import HTMLTestRunnerimport timeimport osimport smtplibfrom email.mime.text import MIMETextfrom email.header import Header#======定义发送邮件========def send_mail(file_new):f = open(file_new,'rb')mail_body = f.read()f.close()msg = MIMEText(mail_body,'html','utf-8')msg['Subject'] = Header('xxx接口自动化测试报告','utf-8')smtp = smtplib.SMTP()smtp.connect('smtp.sina.com')smtp.login('xxx@sina.com','xxx336..')smtp.sendmail('xxx@sina.com','10xxx6@qq.com',msg.as_string())smtp.quit()print('邮件已发出!注意查收。')#======查找测试目录,找到最新生成的测试报告======def new_report(test_report):lists = os.listdir(test_report)lists.sort(key=lambda fn:os.path.getmtime(test_report + '\' + fn))file_new = os.path.join(test_report,lists[-1])print(file_new)return file_newif __name__ == "__main__":test_dir = "D:\dsp_testpro\test_case"test_report = "D:\dsp_testpro\test_report"discover = unittest.defaultTestLoader.discover(test_dir,pattern = 'test*.py')#按照一定的格式获取当前的时间now = time.strftime("%Y-%m-%d_%H-%M-%S-")#定义报告存放路径filename = test_report + "\" + now + 'result.html'fp = open(filename,'wb')#定义测试报告runner = HTMLTestRunner(stream = fp,title = "xxx接口测试报告",description = "测试用例执行情况:")#运行测试runner.run(discover)fp.close() #关闭报告文件new_report = new_report(test_report)send_mail(new_report)复制代码

绵薄之力

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


软件测试面试资料

被百万人刷爆的软件测试题库!!!谁用谁知道!!!卷起来!

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

http://www.dtcms.com/a/279156.html

相关文章:

  • 支付宝小程序代运营:专业助力提升运营效能
  • AI Agent和Agentic AI
  • 驱动开发系列60- Vulkan 驱动实现-SPIRV到HW指令的实现过程(1)
  • 【Bluedroid】蓝牙协议栈enable流程深度解析
  • Redis ①⑥-缓存
  • org.casic.javafx.control.PaginationPicker用法
  • 【Docker基础】Dockerfile指令速览:健康检查与启动指令详解
  • Apache部署
  • ThinkPHP 8 在 Apache 下启用伪静态
  • 深入解析Hadoop YARN架构设计:从原理到实践
  • 音视频:语音转换文字功能实现
  • 阿尔卡特ACT 250 ATP 150 AND ATP 400 分子泵控制器TURBOMOLECULAR PUMP CONTROLLER ALCATEL
  • 微型导轨在3D打印设备中如何稳定运行?
  • Java:继承和多态(必会知识点整理)
  • 常用的RAG类型介绍
  • # MySQL索引失效场景和解决方案详解
  • 如何解决pip安装报错ModuleNotFoundError: No module named ‘sqlite3’问题
  • SpringBoot微服组件
  • 毫米波雷达在转弯时将静止目标识别为运动目标的原因
  • JavaSE-8-多态
  • python 双下划线开头函数
  • 【字节跳动】数据挖掘面试题0017:推荐算法:双塔模型,怎么把内容精准地推送给用户
  • ATE - Force模式和Meas模式
  • AI Agent vs SaaS:企业服务产品正迈向“智能中枢”阶段
  • Linux中使用云仓库上传镜像和私库制作Registry
  • 算法-练习题
  • 【牛客刷题】小红的数字删除
  • 可达性统计(拓扑排序模板,bitset)
  • 【算法】贪心算法:最大数C++
  • Linux 音频的基石: ALSA