• python--unittest单元测试


    单元测试:开发自测时写的代码

    几个概念:

    TestCase 也就是测试用例

    TestSuite 多个测试用例集合在一起

    TestLoader是用来加载TestCase到TestSuite中的

    TestRunner是来执行测试用例的,测试的结果会保存到TestResult实例中,包括运行了多少测试用例,成功了多少,失败了多少等信息

     unittest 测试

    def cal(a,b):
        return a+b
    #
    # res = cal(1,9)
    # if res == 3:
    #     print('成功')
    # else:
    #     raise Exception('测试失败')
    
    # unittest python中的单元测试框架
    import unittest
    
    class MyTest(unittest.TestCase):   #继承TestCase
        def test_a(self):   #函数的名字必须以test开头
            res = cal(1,2)
            self.assertEqual(3,res,msg='预期结果和实际结果不一致')
    
        def test_b(self):
            res = cal(9,3)
            self.assertEqual(3,res,msg='预期结果和实际结果不一致')
    
    unittest.main()  #运行测试用例

    unittest 测试产生报告

    两种生成测试报告的方式:

    1、安装BeautifulReport模块

    2、把HTMLTestRunner.py 放到pyCharm的External Libraries中

    import unittest
    import HTMLTestRunner
    import BeautifulReport
    
    class MyTest(unittest.TestCase):
        def test_reg(self):
            '''注册'''       #加这一行会在报告中显示用例描述
            print('reg')
            self.assertEqual(1,1)
    
        def test_log(self):
            '''登录'''
            print('log')
            self.assertEqual(1,1)
    
        def test_buy(self):
            self.assertEqual(1,2,msg='购买失败')
    
        def test_z(self):
            self.assertIn(1,[1,2,3])
    
        def test_assert(self):
            res = False
            self.assertFalse(res,)
    
    #下面这一坨是用HTMLTestRunner,产生不好看的测试报告
    f = open('report.html','wb')
    runner = HTMLTestRunner.HTMLTestRunner(f,title='lhtest',description='XX接口测试')  #实例化一个runner,帮你跑测试用例
    suit = unittest.makeSuite(MyTest)  #MyTest类变成测试集合
    runner.run(suit)
    
    #下面这一坨是用BeautifulReport,产生不好看的测试报告
    suite = unittest.makeSuite(MyTest)   #变成测试集合
    report = BeautifulReport.BeautifulReport(suite)
    report.report(filename='bfreport.html',description='接口测试报告')
    
    # 测试集合:testsuite  多个用例放在一起
    # unittest  1、函数名必须是test开头,unittest才会帮你执行
    #           2、用例运行的顺序是按照函数的首字母排序的,a-z
    # testrunner  运行测试用例的
    # testloader  查找测试用例的

    如果我们有很多个模块,每个模块下面都写了很多python文件,每个python文件里面都有测试用例,那怎么把这个目录下的用例都执行了呢,就要先找到这个目录下的所有python文件,然后找到里面的测试用例,逐个执行,代码如下:

    import unittest,HTMLTestRunner
            suite = unittest.TestSuite()#创建测试套件
            all_cases = unittest.defaultTestLoader.discover('.','test_*.py')
            #找到某个目录下所有的以test开头的Python文件里面的测试用例
            for case in all_cases:
                suite.addTests(case)#把所有的测试用例添加进来
            fp = open('res.html','wb')
            runner = HTMLTestRunner.HTMLTestRunner(stream=fp,title='all_tests',description='所有测试情况')
            runner.run(suite)
            #运行测试

     参数化

    安装nose-parameterized模块

    import unittest
    from parameterized import parameterized
    
    def login(username,password):
        print(username,password)
        print('=============')
        return 1
    
    class MyTest(unittest.TestCase):
        @parameterized.expand(
            [
               ['xiaodong','123','success'],
               ['yangfan','456','fail'],
               ['hailong','1273','success'],
               ['liurongxin','1273','success'],
            ]
        )
        def test_login(self,username,passwd,check):
            '正常登陆'
            res = login(username,passwd)
            self.assertEqual(check,res)
    
    unittest.main()

     setUp、tearDown、setUpClass、tearDownClass

    import unittest
    import HTMLTestRunner
    from BeautifulReport import BeautifulReport
    class MyTest(unittest.TestCase):
        def setUp(self):
            #每条用例执行之前会执行setup
            print('这是setup')
        def tearDown(self):
            #每条用例执行之后都会执行teardown
            print('这是teardown')
    
        @classmethod
        def setUpClass(cls):
            #这个类里面的用例执行之前,最先执行它,最前面
            print('这是setupclass')
    
        @classmethod
        def tearDownClass(cls):
            #这个类里面所有的用例执行完之后执行它,最后面
            print('tearDownClass')
    
        def test_reg(self):
            '''注册'''
            print('reg')
            self.assertEqual(1,2,msg='token不对')
        def test_login(self):
            '''登录'''
            print('login')
            self.assertEqual(1,1)
        def test_buy(self):
            self.assertEqual(1,2,msg='购买失败')
        def test_z(self):
            self.assertIn(1,[1,23])
        def test_assert(self):
            res = False
            self.assertFalse(res,)
            print('test_assert')
  • 相关阅读:
    洛谷P2331 [SCOI2005]最大子矩阵 DP
    洛谷P2216: [HAOI2007]理想的正方形 单调队列优化DP
    牛客练习赛38 E 出题人的数组 2018ccpc桂林A题 贪心
    zstu19一月月赛 duxing201606的原味鸡树
    gym/102021/J GCPC18 模拟拼图
    gym/102021/K GCPC18 背包dp算不同数和的可能
    洛谷 P2051 [AHOI2009]中国象棋 状态压缩思想DP
    洛谷 P1070 道路游戏 DP
    洛谷P2577 [ZJOI2005]午餐 打饭时间作为容量DP
    动态规划:插头DP
  • 原文地址:https://www.cnblogs.com/HathawayLee/p/9978371.html
Copyright © 2020-2023  润新知