前言:
Requests简介
Requests 是使用Apache2 Licensed 许可证的 HTTP 库。用 Python 编写,真正的为人类着想。
Python 标准库中的 urllib2 模块提供了你所需要的大多数 HTTP 功能,但是它的 API 有点落后了。它是为另一个时代、另一个互联网所创建的。它需要巨量的工作,甚至包括各种方法覆盖,来完成最简单的任务。
总之,大家建议大家用Requests吧。
Requests的官方文档:http://cn.python-requests.org/zh_CN/latest/
通过下面方法安装requests
pip install requests
实例实现步骤:
1.采用unittest把每个接口写成一个个测试脚本
2.一个测试脚本中包含一个接口,但是可以包含多个测试用例(即每个接口需要进行多种情况的验证,接口测试用例名称已test开头)
3.使用discover(),该方法会自动根据测试目录匹配查找测试用例文件,并且将查找到的测试组装到测试套件中,因此可以直接通过run()方法执行discover,大大简化了测试用例的查找和执行
4.利用HTMLTestRunner生成测试报告
文档结构:project项目文件下有以下三个文件
1.report存放测试结果
2.test_case存放测试用例
3.run_test_case.py执行测试用例文件
案例:
1.get接口测试用例源码
# coding:utf-8 import requests import unittest class get_request(unittest.TestCase): def setUp(self): self.get_url = 'https://www.baidu.com/' def test_post_01(self): url=self.get_url r = requests.get(url) print r.text def tearDown(self): pass if __name__ == "__main__": unittest.main()
2.post接口测试用例源码
# coding:utf-8 import requests import json import unittest class post_request(unittest.TestCase): def setUp(self): self.post_url = '..........' #根据实际接口,自己填写 self.header = {'.......'} #根据实际内容,自己填写 def test_post_01(self): """正常数据""" url=self.post_url header = self.header data = {""}#根据实际内容,自己填写 #将data序列化为json格式数据,传递给data参数 r = requests.post(url, data=json.dumps(data), headers=header) print r.text def test_post_02(self): """异常数据""" url=self.post_url header = self.header data = {""}#根据实际内容,自己填写 r = requests.post(url, data=json.dumps(data), headers=header) print r.text def tearDown(self): pass if __name__ == "__main__": unittest.main()
3.执行测试用例源码
# coding=utf-8 import unittest import HTMLTestRunner import time # 相对路径 test_dir ='./test_case' test_dir1 ='./report' discover = unittest.defaultTestLoader.discover(test_dir, pattern='test*.py') # 定义带有当前测试时间的报告,防止前一次报告被覆盖 now = time.strftime("%Y-%m-%d %H_%M_%S") filename = test_dir1 + '/' + now + 'result.html' # 二进制打开,准备写入文件 fp = file(filename, 'wb') # 定义测试报告 runner = HTMLTestRunner.HTMLTestRunner(stream=fp, title=u'测试报告', description=u'用例执行情况') runner.run(discover)
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍python+requests接口自动化框架的实现,包括了python+requests接口自动化框架的实现的使用技巧和注意事项,需要的朋友参考一下 为什么要做接口自动化框架 1、业务与配置的分离 2、数据与程序的分离;数据的变更不影响程序 3、有日志功能,实现无人值守 4、自动发送测试报告 5、不懂编程的测试人员也可以进行测试 正常接口测试的流程是什么? 确定接口测试使用的工具--
本文向大家介绍python+requests+unittest API接口测试实例(详解),包括了python+requests+unittest API接口测试实例(详解)的使用技巧和注意事项,需要的朋友参考一下 我在网上查找了下接口测试相关的资料,大都重点是以数据驱动的形式,将用例维护在文本或表格中,而没有说明怎么样去生成想要的用例, 问题: 测试接口时,比如参数a,b,c,我要先测a参数,有
本文向大家介绍python unittest实现api自动化测试,包括了python unittest实现api自动化测试的使用技巧和注意事项,需要的朋友参考一下 项目测试对于一个项目的重要性,大家应该都知道吧,写python的朋友,应该都写过自动化测试脚本。 最近正好负责公司项目中的api测试,下面写了一个简单的例子,对API 测试进行梳理。 首先,编写restful api接口文件 testp
本文向大家介绍Python接口自动化测试的实现,包括了Python接口自动化测试的实现的使用技巧和注意事项,需要的朋友参考一下 1)环境准备: 接口测试的方式有很多,比如可以用工具(jmeter,postman)之类,也可以自己写代码进行接口测试,工具的使用相对来说都比较简单,重点是要搞清楚项目接口的协议是什么,然后有针对性的进行选择,甚至当工具不太适合项目时需要自己进行开发。 在我们项目
本文向大家介绍python接口自动化框架实战,包括了python接口自动化框架实战的使用技巧和注意事项,需要的朋友参考一下 python接口测试的原理,就不解释了,百度一大堆。 先看目录,可能这个框架比较简单,但是麻雀虽小五脏俱全。 各个文件夹下的文件如下: 一.理清思路 我这个自动化框架要实现什么 1.从excel里面提取测试用例 2.测试报告的输出,并
本文向大家介绍python实现文件分片上传的接口自动化,包括了python实现文件分片上传的接口自动化的使用技巧和注意事项,需要的朋友参考一下 背景和目的: 利用python request 编写脚本测试公司系统的文件上传接口。前端读取文件的大小然后文件分片传给后端,后端将每一片数据重新组合成文件。大概的过程是:前端将整个文件的md5、size(大小)、name(文件名)、ext(文件后缀)、to