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

news2024/9/20 16:03:07
环境说明:

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生成测试报告。

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

  2. DELETE:删除指定资源。

  3. 在接口测试中,一般来说,post创建数据,get获取创建成功后的所有数据和指定的数据,put可以对创建成功后的数据

  4. 进行修改,delete是指定的资源。

目录结构:

 
  1. ​现在我也找了很多测试的朋友,做了一个分享技术的交流群,共享了很多我们收集的技术文档和视频教程。

  2. 如果你不想再体验自学时找不到资源,没人解答问题,坚持几天便放弃的感受

  3. 可以加入我们一起交流。而且还有很多在自动化,性能,安全,测试开发等等方面有一定建树的技术大牛

  4. 分享他们的经验,还会分享很多直播讲座和技术沙龙

  5. 可以免费学习!划重点!开源的!!!

  6. qq群号:680748947【暗号:csdn11】

单个接口测试例子:

post(修改)

 
  1. import requests

  2. import json

  3. def get_token():

  4. url1 = "https://**********/Token/get"

  5. content = {'appId':'***','appSecret':'******'}

  6. web = requests.get(url=url1,params=content)

  7. print(web.url)

  8. print(web.text)

  9. ty = web.text

  10. a = json.loads(ty)

  11. b = a.get('Data')

  12. apptoken = b.get('Token')

  13. return apptoken

  14. if __name__ == '__main__':

  15. get_token()

get(查询)

 
  1. import requests

  2. import json

  3. def test_qualification_add():

  4. url = "http://xxx.xxx.xxx/audit/api/xxx/get" #测试的接口url

  5. headers = {"Content-Type":"application/json"}

  6. data = { #接口传送的参数

  7. "token": "abcdefg",

  8. "id": 1,

  9. "param": {

  10. "QuId":1

  11. }

  12. }

  13. r = requests.post(url = url,json = data,headers = headers) #发送请求

  14. #return r.json

  15. print (r.text) #获取响应报文

  16. print (r.status_code)

  17. if __name__=="__main__":

  18. test_qualification_add()

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

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

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

 
  1. import requests

  2. import json

  3. import unittest

  4. class MyTest(unittest.TestCase): #封装测试环境的初始化和还原的类

  5. def setUp(self): #放对数据可操作的代码,如对mysql、momgodb的初始化等,这里不对数据库进行操作!

  6. print("start test")

  7. pass

  8. def tearDown(self): #与setUp()相对

  9. print("end test")

  10. pass

  11. class test_xxx_get(MyTest): #把这个接口封装一个类,下面的方法是具体的测试用例

  12. '''接口名称:获取资质''' #这个描述接口名称

  13. def test_xxx_get(self):

  14. '''测试用例1:哈哈''' #这个描述接口用例名称

  15. self.url = "http://xxx.xxx.xxx/audit/api/xxx/get" #请求url

  16. self.headers = {"Content-Type":"application/json"}

  17. self.data = { #请求参数

  18. "token": "abcdefg",

  19. "id": 1,

  20. "param": {

  21. "QuId": 14

  22. }

  23. } #self.用在方法属性中,表示是该方法的属性,不会影响其他方法的属性。

  24. r = requests.post(url = self.url,json = self.data,headers = self.headers)

  25. #return r.json()

  26. print (self.r.text)

  27. print (self.r.status_code)

  28. self.assertIn("true",self.r.text) #断言判断接口返回是否符合要求,可以写多个断言!

  29. if __name__=="__main__":

  30. unittest.main()

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

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

runtest.py写法:

 
  1. import unittest

  2. import json

  3. import requests

  4. from HTMLTestRunner import HTMLTestRunner

  5. import time

  6. #加载测试文件 (有几多个接口就加载几多个,一个一个加进来)

  7. import test_creative_add

  8. import test_creative_get

  9. import test_qualification_add

  10. import test_qualification_get

  11. import test_qualification_reflesh

  12. #构造测试集

  13. suite = unittest.TestSuite() #实例化

  14. #TestSuite类的addTest()方法把不同测试类中的测试方法组装到测试套件中。

  15. #增加测试用例==》接口文件名.接口类(方法也就是这个接口的其他用例),要把每一个测试用例都增加进来!!!

  16. suite.addTest(test_creative_add.test_creative_add("test_creative_add")) #增加创意

  17. suite.addTest(test_creative_get.test_creative_get("test_creative_get")) #获取创意

  18. suite.addTest(test_qualification_add.test_qualification_add("test_qualification_add"))#增加资质

  19. suite.addTest(test_qualification_get.test_qualification_get("test_qualification_get"))#获取资质

  20. suite.addTest(test_qualification_reflesh.test_qualification_reflesh("test_qualification_reflesh"))#更新资质

  21. if __name__=="__main__":

  22. testunit = unittest.TestSuite()

  23. testunit.addTest(suite)

  24. #按照一定的格式获取当前的时间

  25. now = time.strftime("%Y-%m-%d %H_%M_%S")

  26. #定义报告存放路径

  27. filename = './' + now + 'test_result.html'

  28. fp = open(filename,"wb")

  29. #定义测试报告

  30. runner = HTMLTestRunner(stream = fp,

  31. title = "xxx接口测试报告",

  32. description = "测试用例执行情况:")

  33. #运行测试

  34. runner.run(testunit)

  35. 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写法:

 
  1. import unittest

  2. import json

  3. import requests

  4. from HTMLTestRunner import HTMLTestRunner

  5. import time

  6. #定义测试用例的目录为当前目录

  7. test_dir = './'

  8. discover = unittest.defaultTestLoader.discover(test_dir,pattern = 'test*.py')

  9. if __name__=="__main__":

  10. #按照一定的格式获取当前的时间

  11. now = time.strftime("%Y-%m-%d %H-%M-%S")

  12. #定义报告存放路径

  13. filename = './' + now + 'test_result.html'

  14. fp = open(filename,"wb")

  15. #定义测试报告

  16. runner = HTMLTestRunner(stream = fp,

  17. title = "xxx接口测试报告",

  18. description = "测试用例执行情况:")

  19. #运行测试

  20. runner.run(discover)

  21. fp.close() #关闭报告文件

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

runtest_mail.py

 
  1. import unittest

  2. import requests

  3. from HTMLTestRunner import HTMLTestRunner

  4. import time

  5. import os

  6. import smtplib

  7. from email.mime.text import MIMEText

  8. from email.header import Header

  9. #======定义发送邮件========

  10. def send_mail(file_new):

  11. f = open(file_new,'rb')

  12. mail_body = f.read()

  13. f.close()

  14. msg = MIMEText(mail_body,'html','utf-8')

  15. msg['Subject'] = Header('xxx接口自动化测试报告','utf-8')

  16. smtp = smtplib.SMTP()

  17. smtp.connect('smtp.sina.com')

  18. smtp.login('xxx@sina.com','xxx336..')

  19. smtp.sendmail('xxx@sina.com','10xxx6@qq.com',msg.as_string())

  20. smtp.quit()

  21. print('邮件已发出!注意查收。')

  22. #======查找测试目录,找到最新生成的测试报告======

  23. def new_report(test_report):

  24. lists = os.listdir(test_report)

  25. lists.sort(key=lambda fn:os.path.getmtime(test_report + '\\' + fn))

  26. file_new = os.path.join(test_report,lists[-1])

  27. print(file_new)

  28. return file_new

  29. if __name__ == "__main__":

  30. test_dir = "D:\\dsp_testpro\\test_case"

  31. test_report = "D:\\dsp_testpro\\test_report"

  32. discover = unittest.defaultTestLoader.discover(test_dir,

  33. pattern = 'test*.py')

  34. #按照一定的格式获取当前的时间

  35. now = time.strftime("%Y-%m-%d_%H-%M-%S-")

  36. #定义报告存放路径

  37. filename = test_report + "\\" + now + 'result.html'

  38. fp = open(filename,'wb')

  39. #定义测试报告

  40. runner = HTMLTestRunner(stream = fp,

  41. title = "xxx接口测试报告",

  42. description = "测试用例执行情况:")

  43. #运行测试

  44. runner.run(discover)

  45. fp.close() #关闭报告文件

  46. new_report = new_report(test_report)

  47. send_mail(new_report)

邮件如下:

 

 

总结:

感谢每一个认真阅读我文章的人!!!

作为一位过来人也是希望大家少走一些弯路,如果你不想再体验一次学习时找不到资料,没人解答问题,坚持几天便放弃的感受的话,在这里我给大家分享一些自动化测试的学习资源,希望能给你前进的路上带来帮助。

  1. 文档获取方式:

  2. 加入我的软件测试交流群:680748947免费获取~(同行大佬一起学术交流,每晚都有大佬直播分享技术知识点)

这份文档,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!

以上均可以分享,只需要你搜索vx公众号:程序员雨果,即可免费领取

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1537094.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

java目标和(力扣Leetcode106)

目标和 力扣原题 问题描述 给定一个正整数数组 nums 和一个整数 target,向数组中的每个整数前添加 ‘’ 或 ‘-’,然后串联起所有整数,可以构造一个表达式。返回可以通过上述方法构造的、运算结果等于 target 的不同表达式的数目。 示例 …

Linux:执行命令的命令eval与Bash解析命令的方式

相关阅读 Linuxhttps://blog.csdn.net/weixin_45791458/category_12234591.html?spm1001.2014.3001.5482 eval命令用于接收参数,并将这些参数作为一行命令执行,这也许会使人困惑,为什么我不能直接执行命令而需要使用eval命令间接执行呢&…

海内外媒体发稿助力中国品牌扬帆“出海”

在“走出去”国家战略的指引下,借着加入世贸的东风,越来越多中国企业扬帆出海,在学习中融入,在融入中超越,在波折中发展,在发展中共赢。《财富》500强企业排行榜上&#…

网工内推 | 数通工程师,IE认证优先,五险一金,绩效奖

01 星网信通 招聘岗位:数通产品经理 职责描述: 1、售前技术支持:技术交流、产品选型报价、方案制作等工作; 2、招投标支持:项目招标参数撰写、标书质疑、应标文件技术部分撰写及资质文件归纳准备、现场讲标及技术澄清…

鸿蒙开发案例:【图像加载缓存库ImageKnife】

专门为OpenHarmony打造的一款图像加载缓存库,致力于更高效、更轻便、更简单。 简介 OpenHarmony的自研版本: 支持内存缓存,使用LRUCache算法,对图片数据进行内存缓存。支持磁盘缓存,对于下载图片会保存一份至磁盘当…

第十四届蓝桥杯JavaB组省赛真题 - 阶乘求和

/ 10^9考虑前九位,% 10^9保留后9位 解题思路: 求获取结果的后九位数字,需要对10^9取余,因为202320232023这个数字的阶乘太大,必须要减少计算量,因为当一个整数乘以10^9后对其取余,那么结果都为0。 所以我…

掌握C语言结构体,开启编程新世界

✨✨欢迎👍👍点赞☕️☕️收藏✍✍评论 个人主页:秋邱博客 所属栏目:C语言 (感谢您的光临,您的光临蓬荜生辉) 前言 前面我们也涉及到了结构体的讲解,但是只是粗略的讲了一下。 接下…

网络编程:包头分析

一、以太网头 以太网中封装了源mac地址以及目的mac地址,还有ip类型,以太网又称为mac头 0X0800 只接收发往本机的mac的ipv4类型的数据帧 0X0806 只接收发往本机的ARP类型的数据帧 0x8035 只接受发往本机的RARP类型的数据帧 0X0003 接收发往本机的MAC所…

田路分离数据的

因为农机大部分时间是在田地工作,所以大多数农机轨迹样本存在数据分布不平衡的问题,既田地数据多,道路数据少。因为用于分类的大多数机器学习算法都是围绕每个类别的样本数量均相等的假设来设计的。这导致模型的预测性能较差,特别…

Angular进阶之八: Angular Animation在项目中的实践经验

使用 Angular 进行项目开发的程序员应该都很熟悉 Angular Animation。这是一个 Angular 原生的动画库,它可以替代或者辅助完成原本需要使用 css 的动画功能。 Angular 在国内的运用是很有限的,可借鉴的文档并不很丰富。尤其对于 Angular 动画模块的应用…

[数据结构]堆

一、堆是什么? 堆是一种完全二叉树 完全二叉树的定义:完全二叉树的形式是指除了最后一层之外,其他所有层的结点都是满的,而最后一层的所有结点都靠左边。​​​​​​,从左到右连续。 教材上定义如下: 若设二叉树的…

纹波和噪声有啥区别(一)

首先要知道的是他们都是在电源输出中出现的信号波动,但两者存在明显的区别。 一,纹波的产生 电源纹波是指电源输出时,叠加在稳定的直流电源上的交流成分。 这种波动主要是由于电源自身的开关、PWM 调节等因素引起的,其频率一般…

Javaweb的学习21_CSS_属性

CSS的属性 (常用)属性: 1. 字体、文本 font-size:字体大小 color:文本颜色 text-align:文本的对齐方式 line-height:行高 2. 背景 background:是个复合属性 3. 边框 border:设置边框&#xff0c…

1升级powershell后才能安装WSL2--最后安装linux--Ubuntu 22.04.3 LTS

视频 https://www.bilibili.com/video/BV1uH4y1W7UX查看电脑本版 步骤1:使用 Winget 方式安装 PowerShell 查看是否能更新PowerShell– winget search Microsoft.PowerShell查看结果为 名称 ID 版本 源 ----------------------------…

HTML小游戏27 - Chuck Chicken 魔法蛋网页游戏(附完整源码)

💂 网站推荐:【神级源码资源网】【摸鱼小游戏】 【工具大全】🤟 基于Web端打造的:👉【轻量化工具创作平台】💅 想寻找共同学习交流、摸鱼划水的小伙伴,请点击【学习交流群】 本节教程我会带大家使用 HTML 、…

【Kafka系列】Kafka事务一般在什么场景下使用呢

面试官:听说你精通Kafka,那我就考考你吧 面试官:不用慌尽管说,错了也没关系😊。。。 以【面试官面试】的形式来分享技术,本期是《Kafka系列》,感兴趣就关注我吧❤️ 面试官:生产者重…

G1和ZGC垃圾回收器学习

前言 ​ 随着JDK17的占有率不断升高和SpringBoot3最低支持JDk17,JDK17很大概率会成为大家后续升级的一个选择,而JDK17上最重要的垃圾回收器G1和ZGC,也就显得格外重要。大家提前了解或者学习一下肯定是有用的。 ​ 本篇文章也默认大家了解一…

【linux】进程地址空间(进程三)

目录 快速了解:引入最基本的理解:细节:如何理解地址空间:a.什么是划分区域:b.地址空间的理解: 为什么要有进程空间?进一步理解页表与写时拷贝: 快速了解: 先来看这样一段…

docker入门(九)—— docker网络详细介绍

docker 网络 准备工作&#xff1a;清空所有镜像和容器 docker rm -f $(docker ps -aq) docker rmi -f $(docker images -aq)docker0 网络 查看本地网络 ip addr[rootiZbp15293q8kgzhur7n6kvZ /]# ip addr# 本地回环网络 1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc…

jmeter接口导入方式

curl直接导入 1、操作页面后&#xff0c;F12查看接口&#xff0c;右击接口-copy-copy as cURL 2、jmeter 工具-import from cURL&#xff0c;粘贴上面复制的curl 根据接口文档导入 1、接口文档示例如下&#xff1a; Path&#xff1a; /api/jobs/xps/exec Method&#xf…