# unittest 单元测试的一个框架 # 什么框架 # 一堆工具的集合。 # TestCase # TestSuite 测试套件,多个用例在一起 # TestLoader是用来加载TestCase到TestSuite中的 # TestRunner是来执行测试用例的,测试的结果会保存到TestResult实例中, # 包括运行了多少测试用例,成功了多少,失败了多少等信息 # # 1、用例必须以test开头 # 2、用例执行的顺序是安装字母排列的顺序来的 import unittest import HTMLTestRunner from BeautifulReport import BeautifulReport def calc(x,y): return x+y class TestCalc(unittest.TestCase): def test_pass_case(self): '''这个通过的测试用例''' print('这个通过用例') res = calc(1,2) self.assertEqual(3,res) self.assertNotEqual(2,3)#返回的结果不一样 def setUp(self): print('我是setUp。。') #每个用例运行之前都会执行它 def tearDown(self): #每个用用例运行完之后都会执行它 print('我是tearDown') @classmethod def setUpClass(cls): print('我是setupClass') #所有的用例执行之前执行一次 @classmethod def tearDownClass(cls): print('我是tearDownClass') #所用的用例都运行完之后执行一次 def test_a(self): '''这个普通的测试用例''' print('a') def test_fail_case(self): '''这个是失败的测试用例''' print('这个是失败的测试用例') res = calc(9,8) self.assertEqual(98,res) def test_haha(self): '''哈哈哈''' self.assertEqual(1,2) if __name__ =='__main__': unittest.main() #他会帮你运行当前这个python里面所有的测试用例。 # suite = unittest.TestSuite()#定义一个测试套件 # # suite.addTest(TestCalc('test_pass_case')) # # suite.addTest(TestCalc('test_a')) # # suite.addTest(TestCalc('test_fail_case')) #单个添加用例的 # suite.addTests(unittest.makeSuite(TestCalc)) #这个类里面的所有测试用例 # # f = open('report.html','wb')#打开一个测试报告的文件 # # runner = HTMLTestRunner.HTMLTestRunner(stream=f,title='牛寒阳测试结果', # # description='描述') # # runner.run(suite) #运行 难看的报告 # result = BeautifulReport(suite) # result.report(filename='测试报告', description='描述', log_path='.') #运行多个目录下的单元测试文件 import unittest from BeautifulReport import BeautifulReport import xmlrunner suite = unittest.TestSuite() all_case = unittest.defaultTestLoader.discover('cases','test*.py') # # for case in all_case: # suite.addTests(case) [ suite.addTests(case) for case in all_case ] #和上面的注释代码是一样的 result = BeautifulReport(suite) result.report(filename='很多测试用例.html',description='这个是描述',log_path='.') # runner = xmlrunner.XMLTestRunner('.') #这个是为了产生报告给Jenkins用 # runner.run(suite) #运行用例