zoukankan      html  css  js  c++  java
  • 让一个继承unittest.TestCase的类下的setUp和tearDown只执行一次

    知道unittest单元测试框架的朋友应该都知道,

    执行继承了unittest.TestCase的类下每个test开头的方法(就是用例)时,都会执行setUp和tearDown,如下面的例子所示:  

    import unittest
    
    class TestSetupTeardown(unittest.TestCase):
        def setUp(self):
            print('连接数据库成功...')
        def tearDown(self):
            print('关闭数据库。')
    
        def test_a(self):
            print('test_a')
    
        def test_b(self):
            print('test_b')
    
    if __name__ == '__main__':
        unittest.main()
    

    setUp连接数据库,tearDown关闭数据库,这样反复执行,无疑是会增加数据库服务器资源的损耗,且浪费时间

    能不能只执行一次呢?

    答案是肯定的,通过装饰器就可以实现 

    import unittest
    
    class TestSetupTeardown(unittest.TestCase):
        @classmethod
        def setUpClass(cls):
            print('连接数据库成功...')
        @classmethod
        def tearDownClass(cls):
            print('关闭数据库。')
    
        def test_a(self):
            print('test_a')
    
        def test_b(self):
            print('test_b')
    
    if __name__ == '__main__':
        unittest.main()
    

    import unittest


    class TestSetupTeardown(unittest.TestCase):
      @classmethod
      def setUpClass(cls):
        print('连接数据库成功...')
      @classmethod
      def tearDownClass(cls):
      print('关闭数据库。')

      def test_a(self):
        print('test_a')

      def test_b(self):
        print('test_b')

    if __name__ == '__main__':
      unittest.main()

  • 相关阅读:
    WinForm里保存TreeView状态
    动态规划 回溯和较难题
    go 基本链表操作
    leetcode 42接雨水
    leetcode 旋转数组搜索
    leetcode 牛客编程 子序列 树 数组(积累)
    剑指offer(积累)
    go快排计算最小k个数和第k大的数
    leetcode 打家劫舍
    leetcode 字符串相关问题
  • 原文地址:https://www.cnblogs.com/uncleyong/p/7076872.html
Copyright © 2011-2022 走看看