单元测试-unittest

一、简介

unittest单元测试框架可组织执行测试用例,并且提供了丰富的断言方法,判断测试用例是否通过,最终生成测试结果。

二、属性介绍

1、unittest模块的各个属性

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

unittest.main():将一个单元测试模块变为可直接运行的测试脚本,main方法使用TestLoader类来搜索所有包含在该模块中以“test”命名开头的测试方法,并自动执行它们。执行方法的默认顺序是: 根据ASCII码的顺序加载测试用例,数字与字母的顺序为0-9、A-Z、a-z。

unittest.TestSuite():创建测试套件

unittest.TextTextRunner():unittest框架的TextTextRunner类,通过该类的run()方法来运行suite所组装的测试用例,参数是suite测试套件

unittest.dedaultTestLoaser():defaultTestLoader()类,通过该类下的discover方法,可自动根据测试目录匹配查找测试用例文件(test*.py),并将查找到的测试用例组装到测试套件,因此可以直接通过run()方法执行discover.

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():setUp()方法用于每个测试用例执行前的初始化工作。如测试用例中需要访问数据库,可以在setUp中建立数据库连接并进行初始化。如测试用例需要登录web,可以先实例化浏览器。

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

assert*():一些断言方法:在执行测试用例的过程中,最终用例是否执行通过,是通过判断测试得到的实际结果和预期结果是否相等决定的。

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

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

3、TestSuite类的属性

addTest()addTest()方法是将测试用例添加到测试套件中,一次只能添加一个测试用例,如下方,是将本模块下的MyTest类下的testcasea测试用例添加到测试套件中

suite=unittest.TestSuite()
suite.addTests(MyTest('testcasea'))

addTests():addTest()方法是将多个测试用例添加到测试套件中,参数是可迭代对象,如下方,是将本模块下的MyTest类下的testcasea、testcaseA测试用例添加到测试套件中。

suite=unittest.TestSuite()
suite.addTests([MyTest('testcasea'),MyTest('testcaseA')])

4、TextTextRunner的属性

run():run方法是运行测试套件的测试用例,参数是suite测试套件。

三、示例

import unittest
#定义要校验的函数,函数的功能是传递两个参数,做两个参数的除法计算
def division(a,b):
    try:
        return round(a/b,1)
    except Exception as e:
        return '不可计算'


#定义测试类,继承unittest.TestCase类
#可以继承unittest.TestCase类的setUp方法和tearDown方法
#可以继承unittest.TestCase类的各种断言方法
class MyTest(unittest.TestCase):

    ##定义tearDown()做每一个测试用例执行前的初始化工作
    def setUp(self):
        print('开始测试')

#定义测试用例:以“test_”开头命名的方法
#注意,方法的入参为self
#可使用unittest.TestCase类下面的各种断言方法用于对测试结果的判断
#可定义多个测试用例

    def testcasea(self):
        print('testcasea')
        res=division(1,2)
        self.assertEqual(res,0.5,'算错')

    def testcaseA(self):
        print('testcaseA')
        res = division(1, 0)
        self.assertEqual(res,'不可计算', '算错')

    @unittest.skip('暂时跳过测试用例3')
    def testcaseB(self):
        res = division(1, -2)
        self.assertEqual(res,-0.5, '算错')

    #定义tearDown()做每一个测试用例执行完毕的善后工作
    def tearDown(self):
        print('测试用例执行完毕')

#执行测试用例方案1
#main方法会搜索该模块下所有以test开头的测试用例方法,并自动执行它们。
#执行顺序是根据测试用例(方法)的名称的ASCII码顺序
unittest.main()


#执行测试用例方法2:
#先构造测试集
#实例化测试套件
suite=unittest.TestSuite()
#添加测试用例到测试套件中
#测试用例的执行顺序是根据添加测试用例的顺序,
#如下,会先执行testcasea,再执行testcaseA、再执行testcaseB
suite.addTests([MyTest('testcasea'),MyTest('testcaseA'),MyTest('testcaseB')])


#执行测试用例,实例化TextTestRunner类
#调用run方法,运行测试套件
#执行时,也会根据装饰器判断是否执行或者屏蔽测试用例
runner=unittest.TextTestRunner()
runner.run(suite)

# 执行测试用例方案三
#使用defaultTestLoader类的discover()方法自动到指定目录下匹配查找测试用例文件
#并自动将找到的测试用例组装到测试套件中

#定义查找目录
test_dir='./'
disco=unittest.defaultTestLoader.discover(test_dir,pattern='yaml1.py')
runner = unittest.TextTestRunner()
runner.run(disco)

 执行方案1和3的运行结果如下:

可以看到先执行的testcaseA、在执行的testcasea,且没有执行testcaseB

开始测试
testcaseA
测试用例执行完毕
开始测试
testcasea
测试用例执行完毕
.s.
----------------------------------------------------------------------
Ran 3 tests in 0.000s

OK (skipped=1)

执行方案2的运行结果如下:

可以看到先执行的testcasea、在执行的testcaseA,且testcaseB跳过不执行

开始测试
testcasea
测试用例执行完毕
开始测试
testcaseA
测试用例执行完毕
..s
----------------------------------------------------------------------
Ran 3 tests in 0.000s

OK (skipped=1)

参考网站:

https://www.cnblogs.com/yufeihlf/p/5707929.html

猜你喜欢

转载自www.cnblogs.com/ruijie/p/9133654.html