unittest和pytest

1、用例编写规则
#unittest
1)测试文件必须import unittest
2)测试类必须继承unittest.TestCase
3)策四方法必须以test开头
#pytest:python的第三方测试框架,基于unittest的扩展框架
1)测试文件名必须以test_开头或_test结尾
2)测试类命名必须以Test开头
3)测试方法必须以test开头

2、用例的前置和后置

#unittest
1)setUp/tearDown:在每个用例之前/之后均执行一次
  #打开浏览器,加载网页/关闭网页
2)setUpClass/tearDownClass:每个类运行之前/之后执行一次
  #数据库连接,创建日志对象/关闭数据库连接,销毁日志对象
3)setUpMoudle/tearDownMoudle:在每个模块执行之前/之后执行一次

#pytest
(方法级)
setUp_method/tearDown_method 
setUp/tearDown
#上下两行作用一样,上优先级高

(函数级)
setUp_function/tearDown_function. 函数之前和之后
(类级)
setUp_class/tearDown_class. 类之前和之后
(模块)
setUp_moudle/tearDown_moudle

还可以在函数前+@pytest.fixture()

3、断言
unittest:assertTure、ssertEqual、assertIn等等
 assertTure/assertFalse:做是非判断
 ssertEqual:判断预期结果
 assertRaises():来判断预期的异常是否有被抛出
pytest:assert

4、报告
unittest:htmltestrunner
pytest:插件

5、失败重跑
unittest:无
pytest:pytest-retrunfailures插件 

6、数据驱动
unittest:ddt
pytest:pytest.mark.parametrize装饰器

7、用例的分类执行
unittest:默认执行所有,可提供testsuit来执行部分用例,活着-k参数
pytest:@pytest.mark



'''
'FunctionTestCase':函数测试用例,即给一个函数作为参数,返回一个testcase实例,可选参数有set-up,tear-down方法
'TestCase':所有测试用例的基本类,给一个测试方法的名字,返回一个测试用例实例
'TestLoader':测试用例加载器,其包括多个加载测试用例的方法。返回一个测试套件
loadTestsFromModule(self, module)--根据给定的模块实例来获取测试用例套件

loadTestsFromName(self, name, module=None)
--根据给定的字符串来获取测试用例套件,字符串可以是模块名,测试类名,测试类中的测试方法名,或者一个可调用的是实例对象,这个实例对象返回一个测试用例或一个测试套件

loadTestsFromNames(self, names, module=None) --和上面功能相同,只不过接受的是字符串列表

loadTestsFromTestCase(self, testCaseClass)--根据给定的测试类,获取其中的所有测试方法,并返回一个测试套件

'TestProgram':命令行进行单元测试的调用方法,作用是执行一个测试用例。其实unittest.main()方法执行的就是这个命令,而这个类实例时默认加载当前执行的作为测试对象,
原型为 init(self, module='main', defaultTest=None, argv=None, testRunner=xx, testLoader=xx)
其中module='main'就是默认加载自身
'TestResult':测试用例的结果保存实例,通常有测试框架调用
'TestSuite':组织测试用例的实例,支持测试用例的添加和删除,最终将传递给testRunner进行测试执行
'TextTestRunner':进行测试用例执行的实例,其中Text的意思是以文本形式显示测试结果。显示测试名称,即完成的测试结果,其过同执行单元测试脚本时添加-v参数
'defaultTestLoader':其实就是TestLoader
'findTestCases', 'getTestCaseNames':这个2个就不用解释了
'main': 其实就是TestProgram
'makeSuite':通常是由单元测试框架调用的,用于生产testsuite对象的实例'''
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值