详解Django中的unittest及应用

编辑: admin 分类: python 发布时间: 2021-12-04 来源:互联网
目录
  • 关于断言
  • 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应用内容请搜索hwidc以前的文章或继续浏览下面的相关文章希望大家以后多多支持hwidc!

    【来源:自由互联:http://www.yidunidc.com/usa.html 欢迎留下您的宝贵建议】