目录
  • 关于断言
  • unittest模块属性说明
    • unittest的属性
    • testcase类的属性
    • texttextrunner的属性
  • unittest框架使用

    unittest是python的一个单元测试框架

    关于断言

    它是用于对一个确定结果和预测结果的一种判断,如果结果正确无任何返回效果,如果结果错误;会抛出assertionerror 异常,如果后面跟了msg则返回msg内容

    assert 2 == 2
    assert 2 == 1 * 2
    assert 2 + 0 == 1 * 2
    # ----------------- 以上无任何返回效果
     
    assert 1 > 3, 'wrong'
    '''
    traceback (most recent call last):
      file "d:/project_of_3期课程/day22/类.py", line 259, in <module>
        assert 1 > 3, 'wrong'
    assertionerror: wrong
    '''

    unittest模块属性说明

    unittest的属性

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

    unittest.testsuite():unittest框架的testsuite()类是用来创建测试套件的。

    unittest.texttextrunner():unittest框架的texttextrunner()类,通过该类下面的run()方法来运行suite所组装的测试用例,入参为suite测试套件。

    testcase类的属性

    setup():方法用于测试用例执行前的初始化工作。如测试用例中需要访问数据库,可以在setup中建立数据库连接并进行初始化。如测试用例需要登录web,可以先实例化浏览器。

    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的一个实例,不是则测试用例通过。

    texttextrunner的属性

    run():是运行测试套件的测试用例,入参为suite测试套件。

    unittest.texttestrunner(verbosity=2).run(suite)
    

    unittest框架使用

    方式一:unittest.main()来启动单元测试模块

    # coding=utf-8
    import unittest
    # 方式一:unittest.main()来启动单元测试模块
    class mytestcase(unittest.testcase):
        def setup(self):
            print('测试环境')
     
        def test(self):
            print('测试用例')
            self.assertequals(4, 2 * 2)
            self.assertequal(1, 3, 'something was wrong')
        def teardown(self):
            print('环境销毁')
    if __name__ == '__main__':
        unittest.main()

    方式二:添加到testsuite集合中,再加载所有的被测试对象

    # coding=utf-8<br>import unittest<br><br>class testcase(unittest.testcase):
        def test1(self):
            print('one')
     
        def test2(self):
            print('two')
     
    class testcase1(unittest.testcase):
        def test1(self):
            print('three')
     
        def test2(self):
            print('four')
     
    if __name__ == '__main__':
        un1 = unittest.testloader().loadtestsfromtestcase(testcase)
        un2 = unittest.testloader().loadtestsfromtestcase(testcase1)
     
        suite = unittest.testsuite([un1, un2])
        unittest.texttestrunner(verbosity=2).run(suite)

    到此这篇关于django中的unittest及应用的文章就介绍到这了,更多相关django unittest应用内容请搜索www.887551.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.887551.com!