这篇文章主要讲解了“Django中的unittest应用是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Django中的unittest应用是什么”吧!
关于断言
它是用于对一个确定结果和预测结果的一种判断,如果结果正确无任何返回效果,如果结果错误;会抛出AssertionError异常,如果后面跟了味精则返回味精内容
assert 2,==2 assert 2,==, 1, * 2 assert 2, +, 0,==, 1 *, 2 #,- - - - - - - - - - - - - - - - -作用;以上无任何返回效果 , assert 1,祝辞,3,& # 39;错误# 39; & # 39;& # 39;& # 39; Traceback (most recent call 最后一个): File 才能“D:/project_of_3期课程/day22/类.py",, line 259年,拷贝& lt; module> ,,,assert 1,祝辞,3,& # 39;错误# 39; AssertionError:错了 '''
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 设置(自我): ,,,,,,,印刷(& # 39;测试环境& # 39;) , ,,,def 测试(自我): ,,,,,,,印刷(& # 39;测试用例& # 39;) ,,,,,,,self.assertEquals (4,, 2, *, 2) ,,,,,,,self.assertEqual (1,, 3,, & # 39; something was 错误# 39;) ,,,def 拆卸(自我): ,,,,,,,印刷(& # 39;环境销毁& # 39;) if __name__ ==, & # 39; __main__ # 39;: ,,,unittest.main ()
方式二:添加到testsuite集合中,再加载所有的被测试对象
#,编码=utf-8
import unittest
& lt; br> class TestCase (unittest.TestCase): ,,,def test1(自我): ,,,,,,,印刷(& # 39;一个# 39;) , ,,,def test2(自我): ,,,,,,,印刷(& # 39;两个# 39;) , class TestCase1 (unittest.TestCase): ,,,def test1(自我): ,,,,,,,印刷(& # 39;3 # 39;) , ,,,def test2(自我): ,,,,,,,印刷(& # 39;4 # 39;) , if __name__ ==, & # 39; __main__ # 39;: ,,,un1 =, unittest.TestLoader () .loadTestsFromTestCase (TestCase) ,,,un2 =, unittest.TestLoader () .loadTestsFromTestCase (TestCase1) , ,,,suite =, unittest.TestSuite ([un2 un1也]) ,,,unittest.TextTestRunner(冗长=2).run(套件)Django中的unittest应用是什么