1、概念说明

① unittest:python中自带的单元测试框架,封装了一些校验返回的结果方法和一些用例执行前的初始化操作

② TestCase:测试用例

③ TestSuite:测试套,即多个测试用例集合在一起

④ TestLoader:用来加载TestCase到TestSuite中的

⑤ TestRunner:执行测试用例的,测试的结果会保存到TestResult实例中,包括运行了多少测试用例,成功了多少,失败了多少等信息

2、unittest模块说明

1)unittest方法说明

① unittest.TestCase:TestCase类,所有测试用例类继承的基本类

② unittest.main():main()方法使用TestLoader类来搜索所有包含在该模块中以“test”命名开

头的测试方法,并自动执行他们。执行方法的默认顺序是:根据ASCII码的顺序加载测试

用例,数字与字母的顺序为:0-9,A-Z,a-z。

③ unittest.TestSuite():用来创建测试套件的。

④ unittest.TextTextRunner():通过该类下面的run()方法来运行suite所组装的测试用例,入参

为suite测试套件。

⑤ unittest.defaultTestLoader(): 通过该类下面的discover()方法可自动根具测试目录start_dir

匹配查找测试用例文件(test*.py),并将查找到的测试用例组装到测试套件,因此可以直

接通过run()方法执行discover。用法如下:

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

⑥ unittest.skip():可用装饰器屏蔽不想执行的用例

@unittest.skip(reason): skip(reason)装饰器:无条件跳过装饰的测试,并说明跳过测试的原因。

@unittest.skipIf(reason): skipIf(condition,reason)装饰器:条件为真时,跳过装饰的测试,并说明跳过测试的原因。

@unittest.skipUnless(reason): skipUnless(condition,reason)装饰器:条件为假时,跳过装饰的测试,并说明跳过测试的原因。

@unittest.expectedFailure(): expectedFailure()测试标记为失败。

2)TestCase类的方法说明

① setUp():用于测试用例执行前的初始化工作。

② tearDown():用于测试用例执行之后的善后工作。如关闭数据库连接,关闭浏览器。

③ assert*():断言,实际结果和预期结果是否相等

assertEqual(a,b,[msg='失败时打印的信息']):断言a,b是否相等,相等则用例通过。

assertNotEqual(a,b,[msg='失败时打印的信息']):断言a,b是否相等,不相等则试用例通过。

assertTrue(x,[msg='失败时打印的信息']):断言x是否True,是True则用例通过。

assertFalse(x,[msg='失败时打印的信息']):断言x是否False,是False则用例通过。

assertIs(a,b,[msg='失败时打印的信息']):断言a是否是b,是则用例通过。

assertNotIs(a,b,[msg='失败时打印的信息']):断言a是否是b,不是则用例通过。

assertIsNone(x,[msg='失败时打印的信息']):断言x是否None,是None则用例通过。

assertIsNotNone(x,[msg='失败时打印的信息']):断言x是否None,不是None则用例通过。

assertIn(a,b,[msg='失败时打印的信息']):断言a是否在b中,在b中则用例通过。

assertNotIn(a,b,[msg='失败时打印的信息']):断言a是否在b中,不在b中则用例通过。

assertIsInstance(a,b,[msg='失败时打印的信息']):断言a是b的一个实例,是则用例通过。

assertNotIsInstance(a,b,[msg='失败打印的信息']):断言a不是b的一个实例,不是则用例过。

3)TestSuite类的方法(组织用例时需要用到)

①addTest(): 将测试用例添加到测试套件中,如下

suite = unittest.TestSuite()

suite.addTest(test_baidu.BaiduTest('test_baidu'))

4)TextTextRunner的方法(组织用例时需要用到)

①run(): 运行测试套件的测试用例,入参为suite测试套件,如下

runner = unittest.TextTestRunner()

runner.run(suite)

3、unitest简单使用

# coding=utf-8
import unittest #创建测试类,继承unittest.TestCase
class TestMethod(unittest.TestCase): # 类方法:整个测试中只会执行一次,类方法需要一个注解@classmethod,且方法名称需要固定为setUpClass、tearDownClass
@classmethod
def setUpClass(cls):
print '类执行之前的方法' @classmethod
def tearDownClass(cls):
print '类执行之后的方法' # 每次方法之前执行
def setUp(self):
print 'test-->setUp'
# 每次方法之后执行
def tearDown(self):
print 'test-->tearDown' # 注意所有的case都要以test开头,如果不以test开头,那么你的case无法执行
def test_01(self):
print 'test-->testCase-1' def test_02(self):
print 'test-->testCase-2' # 执行
if __name__ == '__main__':
unittest.main()

执行结果如下

4、unittest和request重构封装

1)定义两个接口,分别为get、post

# get接口数据处理
def dadaHandle_get(request):
if request.method == 'GET':
results = {}
username = request.GET.get('username')
mobile = request.GET.get('mobile')
data = request.GET.get('data')
results['user'] = username
results['mobileNum'] = mobile
results['data']= data
results =json.dumps(results)
return HttpResponse(results,content_type='application/json;charset=utf-8')
else:
return render_to_response('login.html') # post接口数据处理
def dadaHandle_post(request):
if request.method == 'POST':
results = {}
username = request.POST.get('username')
password = request.POST.get('password')
results['user'] = username
results['pwd'] = password
results =json.dumps(results)
return HttpResponse(results,content_type='application/json;charset=utf-8')
else:
return render_to_response('login.html')

2)requests封装方法处理get、post请求

# coding=utf-8
import requests
import json class SendMain: # 发送post请求
def send_post(self,url, data):
res = requests.post(url=url, data=data).json()
# 返回结果格式化
return json.dumps(res, indent=2, sort_keys=True) # 发送get请求
def send_get(self,url, data):
res = requests.get(url, data).json()
# 返回结果格式化
return json.dumps(res, indent=2, sort_keys=True)
# 既能发get又能发post请求
def send_main(self,url, method, data=None):
res = None
if method == 'GET':
res = self.send_get(url, data)
else:
res = self.send_post(url, data)
return res

3)unittest结合requests处理get、post

# coding=utf-8
import unittest
from base.requestsDemo import SendMain #创建测试类,继承unittest.TestCase
class TestMethod(unittest.TestCase): # 每次方法之前执行
def setUp(self):
self.run = SendMain() # 注意所有的case都要以test开头,如果不以test开头,那么你的case无法执行
def test_01(self):
postData = {'username': 'wangling', 'password': ''}
postUrl = 'http://127.0.0.1:8000/postDataHandle/'
res = self.run.send_main(postUrl,'POST',postData)
print res def test_02(self):
getData = {'username': 'wl', 'mobile': '', 'data': 'haha'}
getUrl = 'http://127.0.0.1:8000/getDataHandle'
res = self.run.send_main(getUrl,'GET',getData)
print res # 执行
if __name__ == '__main__':
unittest.main()

7-unittest和requests重构、封装处理get/post请求的更多相关文章

  1. 对比3种接口测试的工具:jmeter+ant;postman;python的requests+unittest或requests+excel

    这篇随笔主要是对比下笔者接触过的3种接口测试工具,从实际使用的角度来分析下3种工具各自的特点 分别为:jmeter.postman.python的requests+unittest或requests+ ...

  2. python requests函数封装方法

    python  requests函数封装方法 上代码 import requests import json """ 封装request请求, 1.post:my_pos ...

  3. 使用dispatch_group实现并封装分组并发网络请求

    在实际开发中我们通常会遇到这样一种需求:某个页面加载时通过网络请求获得相应的数据,再做某些操作.有时候加载的内容需要通过好几个请求的数据组合而成,比如有两个请求A和B,我们通常为了省事,会将B请求放在 ...

  4. python 爬虫 基于requests模块发起ajax的post请求

    基于requests模块发起ajax的post请求 需求:爬取肯德基餐厅查询http://www.kfc.com.cn/kfccda/index.aspx中指定某个城市地点的餐厅数据 点击肯德基餐厅查 ...

  5. python 爬虫 基于requests模块发起ajax的get请求

    基于requests模块发起ajax的get请求 需求:爬取豆瓣电影分类排行榜 https://movie.douban.com/中的电影详情数据 用抓包工具捉取 使用ajax加载页面的请求 鼠标往下 ...

  6. python+requests实现接口测试 - get与post请求使用(转载)

    转自:http://www.cnblogs.com/nizhihong/p/6567928.html 简介:Requests 是用Python语言编写,基于 urllib,采用 Apache2 Lic ...

  7. python+requests实现接口测试 - get与post请求使用

    简介:Requests 是用Python语言编写,基于 urllib,采用 Apache2 Licensed 开源协议的 HTTP 库.它比 urllib 更加方便,可以节约我们大量的工作,完全满足 ...

  8. android基于开源网络框架asychhttpclient,二次封装为通用网络请求组件

    网络请求是全部App都不可缺少的功能,假设每次开发都重写一次网络请求或者将曾经的代码拷贝到新的App中,不是非常合理,出于此目的,我希望将整个网络请求框架独立出来,与业务逻辑分隔开,这样就能够避免每次 ...

  9. 使用Typescript重构axios(二十二)——请求取消功能:收尾

    0. 系列文章 1.使用Typescript重构axios(一)--写在最前面 2.使用Typescript重构axios(二)--项目起手,跑通流程 3.使用Typescript重构axios(三) ...

随机推荐

  1. c# 通过URl 获取返回的json格式数据

    方法一 http://blog.csdn.net/angle_greensky110/article/details/52209497 protected string GetJson(string ...

  2. CSS的优先级和继承问题

    CSS的优先级和继承问题 ★CSS的冲突,即优先级 CSS本身的设置可以同时应用多个样式在同一个元素,此时样式之间可能出现冲突而达不到用户所想要的效果. ★解决CSS冲突的优先级规则: ● CSS层叠 ...

  3. 微信小程序记账本进度四

    //index.wxml <view class="container"> <form catchsubmit="formSubmit" &g ...

  4. 一文看懂大数据的技术生态Hadoop, hive,spark都有了[转]

    大数据本身是个很宽泛的概念,Hadoop生态圈(或者泛生态圈)基本上都是为了处理超过单机尺度的数据处理而诞生的.你可以把它比作一个厨房所以需要的各种工具.锅碗瓢盆,各有各的用处,互相之间又有重合.你可 ...

  5. python-django(框架结构)

    项目架构: 最外层myshop目录:项目的容器,没有实质性的作用 .idea:项目的配置信息.这个文件夹是自动生成,版本控制信息等,包括历史记录.无用 manage.py:(管理项目)一个实用的命令行 ...

  6. 生成器函数yield

    先看一个栗子: # -*- coding:UTF-8 -*- __autor__ = 'zhouli' __date__ = '2018/12/6 21:08' # 生成器函数,函数里只要有yield ...

  7. 12条MySQL优化技巧

    应用程序慢,原因多多,可能是网络的原因.可能是系统架构的原因,还有可能是数据库的原因. 有人会说性能调优是数据库管理员(DBA)的事,然而性能调优跟程序员们也有莫大的关系. 程序中嵌入的一行行的SQL ...

  8. Oracle 12导出、导入数据

    Precondition: complete the work described in Oracle 12 创建新的数据库实例.用户 1. export data under user " ...

  9. IDEA debugger模式下启动慢

    很可能是因为代码里面有端点造成的. 点击如下图的重叠红点,找到对应端点点掉就可以了.

  10. 快速解决PL/SQL Developer过期问题(无需注册码等复杂操作)

    第一步:在开始菜单中输入 :regedit  的指令,点击回车,进入注册表编辑器界面 第二步:在注册表里按HKEY_CURRENT_USER\Software\Allround Automations ...