百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

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

off999 2024-10-08 06:20 40 浏览 0 评论

python+request+unittest+HTMLTestRunner

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

requests的使用介绍: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 requests

import json

def get_token():

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

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

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

print(web.url)

print(web.text)

ty = web.text

a = json.loads(ty)

b = a.get('Data')

apptoken = b.get('Token')

return apptoken

if __name__ == '__main__':

get_token()

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19

get(查询)

import requests

import json

def test_qualification_add():

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

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

data = { #接口传送的参数

"token": "abcdefg",

"id": 1,

"param": {

"QuId":1

}

}

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

#return r.json

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

print (r.status_code)

if __name__=="__main__":

test_qualification_add()

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20

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

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

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

(一个接口地址一个类,每一个方法是一条测试用例)

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

import requests

import json

import unittest

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

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

print("start test")

pass

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

print("end test")

pass

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

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

def test_xxx_get(self):

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

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

self.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()

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31

unittest提供了全局的main()方法,使用它可以方便的将一个单元测试木块变成可以直接运行的测试脚本;

main()方法使用TestLoader类来搜索所有包含在该木块中以“test”命名开头的测试方法,并自动执行它;

执行方法的默认顺序是:根据ASCII码的顺序加载测试用例,数字与字母的顺序为:0-9,A-Z,a-z。所以以A开头的测试用例方法会优先执行,以a开头会后执行。

所以每一个接口类、测试用例要以test*命名,如下图:

(测试用例放在同一个文件夹:)

runtest.py写法:

import unittest

import json

import requests

from HTMLTestRunner import HTMLTestRunner

import time

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

import test_creative_add

import test_creative_get

import test_qualification_add

import test_qualification_get

import 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() #关闭文件对象把数据写进磁盘

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43

如果有几百条测试用例,在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 unittest

import json

import requests

from HTMLTestRunner import HTMLTestRunner

import 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() #关闭报告文件

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28

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

runtest_mail.py

import unittest

import requests

from HTMLTestRunner import HTMLTestRunner

import time

import os

import smtplib

from email.mime.text import MIMEText

from 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_new

if __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)

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55

邮件如下:

相关推荐

安全教育登录入口平台(安全教育登录入口平台官网)

122交通安全教育怎么登录:122交通网的注册方法是首先登录网址http://www.122.cn/,接着打开网页后,点击右上角的“个人登录”;其次进入邮箱注册,然后进入到注册页面,输入相关信息即可完...

大鱼吃小鱼经典版(大鱼吃小鱼经典版(经典版)官方版)

大鱼吃小鱼小鱼吃虾是于谦跟郭麒麟的《我的棒儿呢?》郭德纲说于思洋郭麒麟作诗的相声,最后郭麒麟做了一首,师傅躺在师母身上大鱼吃小鱼小鱼吃虾虾吃水水落石出师傅压师娘师娘压床床压地地动山摇。...

谷歌地球下载高清卫星地图(谷歌地球地图下载器)
  • 谷歌地球下载高清卫星地图(谷歌地球地图下载器)
  • 谷歌地球下载高清卫星地图(谷歌地球地图下载器)
  • 谷歌地球下载高清卫星地图(谷歌地球地图下载器)
  • 谷歌地球下载高清卫星地图(谷歌地球地图下载器)
哪个软件可以免费pdf转ppt(免费的pdf转ppt软件哪个好)
哪个软件可以免费pdf转ppt(免费的pdf转ppt软件哪个好)

要想将ppt免费转换为pdf的话,我们建议大家可以下一个那个wps,如果你是会员的话,可以注册为会员,这样的话,在wps里面的话,就可以免费将ppt呢转换为pdfpdf之后呢,我们就可以直接使用,不需要去直接不需要去另外保存,为什么格式转...

2026-02-04 09:03 off999

电信宽带测速官网入口(电信宽带测速官网入口app)

这个网站看看http://www.swok.cn/pcindex.jsp1.登录中国电信网上营业厅,宽带光纤,贴心服务,宽带测速2.下载第三方软件,如360等。进行在线测速进行宽带测速时,尽...

植物大战僵尸95版手机下载(植物大战僵尸95 版下载)

1可以在应用商店或者游戏平台上下载植物大战僵尸95版手机游戏。2下载教程:打开应用商店或者游戏平台,搜索“植物大战僵尸95版”,找到游戏后点击下载按钮,等待下载完成即可安装并开始游戏。3注意:确...

免费下载ppt成品的网站(ppt成品免费下载的网站有哪些)

1、Chuangkit(chuangkit.com)直达地址:chuangkit.com2、Woodo幻灯片(woodo.cn)直达链接:woodo.cn3、OfficePlus(officeplu...

2025世界杯赛程表(2025世界杯在哪个国家)

2022年卡塔尔世界杯赛程公布,全部比赛在卡塔尔境内8座球场举行,2022年,决赛阶段球队全部确定。揭幕战于当地时间11月20日19时进行,由东道主卡塔尔对阵厄瓜多尔,决赛于当地时间12月18日...

下载搜狐视频电视剧(搜狐电视剧下载安装)

搜狐视频APP下载好的视频想要导出到手机相册里方法如下1、打开手机搜狐视频软件,进入搜狐视频后我们点击右上角的“查找”,找到自已喜欢的视频。2、在“浏览器页面搜索”窗口中,输入要下载的视频的名称,然后...

pubg免费下载入口(pubg下载入口官方正版)
  • pubg免费下载入口(pubg下载入口官方正版)
  • pubg免费下载入口(pubg下载入口官方正版)
  • pubg免费下载入口(pubg下载入口官方正版)
  • pubg免费下载入口(pubg下载入口官方正版)
永久免费听歌网站(丫丫音乐网)

可以到《我爱音乐网》《好听音乐网》《一听音乐网》《YYMP3音乐网》还可以到《九天音乐网》永久免费听歌软件有酷狗音乐和天猫精灵,以前要跳舞经常要下载舞曲,我从QQ上找不到舞曲下载就从酷狗音乐上找,大多...

音乐格式转换mp3软件(音乐格式转换器免费版)

有两种方法:方法一在手机上操作:1、进入手机中的文件管理。2、在其中选择“音乐”,将显示出手机中的全部音乐。3、点击“全选”,选中所有音乐文件。4、点击屏幕右下方的省略号图标,在弹出菜单中选择“...

电子书txt下载(免费的最全的小说阅读器)

1.Z-library里面收录了近千万本电子书籍,需求量大。2.苦瓜书盘没有广告,不需要账号注册,使用起来非常简单,直接搜索预览下载即可。3.鸠摩搜书整体风格简洁清晰,书籍资源丰富。4.亚马逊图书书籍...

最好免费观看高清电影(播放免费的最好看的电影)

在目前的网上选择中,IMDb(互联网电影数据库)被认为是最全的电影网站之一。这个网站提供了各种类型的电影和电视节目的海量信息,包括剧情介绍、演员表、评价、评论等。其还提供了有关电影制作背后的详细信息,...

孤单枪手2简体中文版(孤单枪手2简体中文版官方下载)

要将《孤胆枪手2》游戏的征兵秘籍切换为中文,您可以按照以下步骤进行操作:首先,打开游戏设置选项,通常可以在游戏主菜单或游戏内部找到。然后,寻找语言选项或界面选项,点击进入。在语言选项中,选择中文作为游...

取消回复欢迎 发表评论: