unittest框架解析
unittest 是python 的单元测试框架,unittest 单元测试提供了创建测试用例,测试套件以及批量执行的方案, unittest 在安装pyhton 以后就直接自带了,直接import unittest 就可以使用。
作为单元测试的框架, unittest 也是可以对程序最小模块的一种敏捷化的测试。在自动化测试中,必须需要知道所使用语言的单元测试框架。利用单元测试框架,创建一个类,该类继承unittest的TestCase,这样可以把每个case看成是一个最小的单元, 由测试容器组织起来,到时候直接执行,同时引入测试报告。
unittest.TestCase:TestCase类,所有测试用例类继承的基本类。
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测试套件。
unittest.defaultTestLoader(): defaultTestLoader()类,通过该类下面的discover()方法可自动更具测试目录start_dir匹配查找测试用例文件(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()测试标记为失败。
unittest断言
自动化的测试中, 对于每个单独的case来说,一个case的执行结果中, 必然会有期望结果与实际结果, 来判断该case是通过还是失败, 在unittest 的库中提供了大量的实用方法来检查预期值与实际值, 来验证case的结果, 一般来说, 检查条件大体分为等价性, 逻辑比较以及其他, 如果给定的断言通过, 测试会继续执行到下一行的代码, 如果断言失败, 对应的case测试会立即停止或者生成错误信息( 一般打印错误信息即可) ,但是不要影响其他的case执行。
import unittest
# 被测试方法
class Search:
def search_fun(self):
print("search")
return True
class TestSearch(unittest.TestCase):
@classmethod
def setUpClass(cls) -> None:
cls.search = Search()
@classmethod
def tearDownClass(cls) -> None:
cls.search = Search()
def test_search1(self):
print("testsearch1")
#search = Search()
assert True == self.search.search_fun()
def test_search2(self):
print("testsearch2")
#search = Search()
assert True == self.search.search_fun()
def test_search3(self):
print("testsearch3")
#search = Search()
assert True == self.search.search_fun()
class TestSearch1(unittest.TestCase):
@classmethod
def setUpClass(cls) -> None:
cls.search = Search()
print("set up class1")
@classmethod
def tearDownClass(cls) -> None:
cls.search = Search()
print("tear down class1")
def test_search1(self):
print("testsearch1")
#search = Search()
assert True == self.search.search_fun()
def test_search2(self):
print("testsearch2")
#search = Search()
assert True == self.search.search_fun()
def test_search3(self):
print("testsearch3")
#search = Search()
assert True == self.search.search_fun()
def test_equal(self):
print("断言相等")
self.assertEqual(1,1,"判断1 == 1")
def test_notequal(self):
print("断言不相等")
self.assertNotEqual(1,2,"判断1 != 2")
class TestSearch2(unittest.TestCase):
def test_case1(self):
print("testsearch2")
if __name__ == '__main__':
#方法一、执行当前文件所有的unittest测试用例
#unittest.main()
#方法二、执行指定的测试用例,将要执行的测试用例添加到测试套件里面,批量执行
#创建一个测试套件 testsuite
# suite = unittest.TestSuite()
# suite.addTest(TestSearch1("test_search1"))
# unittest.TextTestRunner().run(suite)
#方法三、执行某个或多个测试类
suite1 = unittest.TestLoader().loadTestsFromTestCase(TestSearch1)
suite2 = unittest.TestLoader().loadTestsFromTestCase(TestSearch2)
suite = unittest.TestSuite([suite1,suite2])
unittest.TextTestRunner(verbosity=2).run(suite)
HTML报告生成
脚本执行完毕之后,还需要看到HTML报告,下面我们就通过HTMLTestRunner.py 来生成测试报告