python+unittest+requests实现接口自动化

前言:

Requests简介html

Requests 是使用 Apache2 Licensed 许可证的 HTTP 库。用 Python 编写,真正的为人类着想。python

Python 标准库中的 urllib2 模块提供了你所须要的大多数 HTTP 功能,可是它的 API 有点落后了。它是为另外一个时代、另外一个互联网所建立的。它须要巨量的工做,甚至包括各类方法覆盖,来完成最简单的任务。apache

总之,你们建议你们用Requests吧。json

Requests的官方文档:http://cn.python-requests.org/zh_CN/latest/post

经过下面方法安装requests测试

pip install requests  url

实例实现步骤:

1.采用unittest把每一个接口写成一个个测试脚本
2.一个测试脚本中包含一个接口,可是能够包含多个测试用例(即每一个接口须要进行多种状况的验证,接口测试用例名称已test开头)
3.使用discover(),该方法会自动根据测试目录匹配查找测试用例文件,而且将查找到的测试组装到测试套件中,所以能够直接经过run()方法执行discover,大大简化了测试用例的查找和执行
4.利用HTMLTestRunner生成测试报告spa

文档结构:project项目文件下有如下三个文件code

  1. report存放测试结果
  2. test_case存放测试用例
  3. run_test_case.py执行测试用例文件

案例:

1.get接口测试用例源码htm

# 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)
相关文章
相关标签/搜索