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

1350 篇文章 11 订阅
38 篇文章 1 订阅
本文介绍了如何使用Python的requests库进行接口自动化测试,包括GET和POST请求的实现,以及如何编写测试脚本和封装测试类。通过unittest框架和HTMLTestRunner生成测试报告。此外,还讨论了PUT和DELETE操作,并展示了测试用例的组织结构和自动化测试脚本的执行方式。
摘要由CSDN通过智能技术生成

整理了一些软件测试方面的资料、面试资料(接口自动化web自动化、app自动化、性能安全、测试开发等),有需要的小伙伴可以文末加入我的学习交流qun,无套路自行领取~ 

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()
复制代码

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() 
复制代码

  

其中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()
复制代码

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

如果有几百条测试用例,在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() #关闭报告文件
复制代码

 

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

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)
复制代码

 邮件如下:

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

 

这些资料,对于从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!凡事要趁早,特别是技术行业,一定要提升技术功底。希望对大家有所帮助……如果你不想再体验一次自学时找不到资料,没人解答问题,坚持几天便放弃的感受的话,可以加入下方我们的测试交流群大家一起讨论交流学习。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值