Python内部自带了一个单元测试的模块——pyUnit,也就是我们说的:unittest
先介绍一下unittest的基本使用方法
1. import unittest模块
2. 定义一个继承 unittest.TestCase 的测试用例类
3. 定义 setUp 和 tearDown两个方法,tearDown的过程很重要,是为以后的TestCase留一个干净的测试环境。
4. 定义测试用例,均要以test开头
5. 一个测试用例只需要测试一个方面,测试的目的和测试内容要很明确。一般使用assertEqual、assertIn等断言方法去判断程序执行的结果和预期结果是否相符
6. 调用 unittest.main() 开始跑测试用例
7. 测试全部通过,不输出任何东西;若测试未通过,则会输出相应的错误提示。
unittest执行顺序
在pycharm里执行脚本的时候,发现了一个问题。本来在执行的时候,我还加了几步往config文件里写登录信息的步骤,但是在执行完成之后我发现,config文件里根本没有我想要写入的信息。然后我就加了一些打印信息,发现在执行这个脚本的时候,红框里的方法根本没有执行。后来查了一下,找到了原因,是pycharm里执行方式选择导致的。
主程序中先加载哪个方法,或者后加载哪个方法,在unittests运行的模式下,没有任何作用。在该模式运行下,主程序先执行哪个类,是按照这个类的名字字母以及数据排序的;先运行哪个方法,是按照某类中,方法的名字、数字排序的。
而在普通模式下,就是按照写的执行顺序运行的。而unittest.main()方法会自动把所有的测试类加到测试集里,然后再加载到runner中去执行。
下面是unittest中常用的assert语句
assertEqual(a,b,[msg='测试失败时打印的信息']):若 a=b,则测试用例通过
assertNotEqual(a,b,[msg='测试失败时打印的信息']):若a != b,则测试用例通过
assertTrue(x,[msg='测试失败时打印的信息']):若x是True,则测试用例通过
assertFalse(x,[msg='测试失败时打印的信息']):若x是False,则测试用例通过
assertIs(a,b,[msg='测试失败时打印的信息']):若a是b,则测试用例通过
assertNotIs(a,b,[msg='测试失败时打印的信息']):若a不是b,则测试用例通过
assertIsNone(x,[msg='测试失败时打印的信息']):若x是None,则测试用例通过
assertIsNotNone(x,[msg='测试失败时打印的信息']):若x不是None,则测试用例通过
assertIn(a,b,[msg='测试失败时打印的信息']):若a在b中,则测试用例通过
assertNotIn(a,b,[msg='测试失败时打印的信息']):若a不在b中,则测试用例通过
assertIsInstance(a,b,[msg='测试失败时打印的信息']):若a是b的一个实例,则测试用例通过
assertNotIsInstance(a,b,[msg='测试失败时打印的信息']):若a不是b的实例,则测试用例通过
assertAlmostEqual(a, b):round(a-b, 7) == 0
assertNotAlmostEqual(a, b):round(a-b, 7) != 0
assertGreater(a, b):a > b
assertGreaterEqual(a, b):a >= b
assertLess(a, b):a < b
assertLessEqual(a, b):a <= b
assertRegexpMatches(s, re):regex.search(s)
assertNotRegexpMatches(s, re):not regex.search(s)
assertItemsEqual(a, b):sorted(a) == sorted(b) and works with unhashable objs
assertDictContainsSubset(a, b):all the key/value pairs in a exist in b
assertMultiLineEqual(a, b):strings
assertSequenceEqual(a, b):sequences
assertListEqual(a, b):lists
assertTupleEqual(a, b):tuples
assertSetEqual(a, b):sets or frozensets
assertDictEqual(a, b):dicts