zoukankan      html  css  js  c++  java
  • unittest系统(六)如何在一个测试类多个测试用例执行中只初始化和清理一次?

    之前分享了一系列的文章,分别从原理,运行,断言,执行,测试套件,如何跳过用例来讲解unittest,那么我们继续分享

       我们首先看下下面的代码

    import  unittest
    class TestDemo(unittest.TestCase):
        
        def setUp(self):
            print("start")
        def tearDown(self):
            print("end")
        def testone(self):
            self.assertEqual(1,1)
            self.assertFalse(False)
    
        def testtwo(self):
            self.assertEqual(1, 1)
            self.assertFalse(False)
    if __name__=="__main__":
        unittest.main()

      我们执行下,看下结果

     

     我们发现在初始化的时候呢,我们每次都会初始化,但是在实际的测试中呢,我们可能会是有些参数或者动作只需要做一次即可,那么我们只能在用例中初始化一次。那么unittest里面有没有这样的方法 呢?答案是肯定呢,

     @classmethod
        def  setUpClass(cls):
            pass
    
        @classmethod
        def tearDownClass(cls):
            pass

    我们只需要在初始化一次的时候调用setUpClass和tearDownClass 即可。我们将这些代码带入到我们的测试用例中,看下效果会如何。

    import  unittest
    class TestDemo(unittest.TestCase):
    
        @classmethod
        def  setUpClass(cls):
            print("one start")
    
        @classmethod
        def tearDownClass(cls):
            print("one end")
        def setUp(self):
            print("start")
        def tearDown(self):
            print("end")
        def testone(self):
            self.assertEqual(1,1)
            self.assertFalse(False)
    
        def testtwo(self):
            self.assertEqual(1, 1)
            self.assertFalse(False)
    if __name__=="__main__":
        unittest.main()

    我们执行下看下最后的效果

      这样我们就实现了初始化一次,清理一次的需求。

    欢迎关注我的个人公众号

  • 相关阅读:
    js 创建Table,每行3列的方式
    多线程 笔记
    WCF binding
    table 变量
    Excel数据使用sql语句导入sqlserver (64位)
    sqlserver链接服务器到Mysql
    easyui datagrid 返回数据正确 fit='true' 时不显示内容
    js设置文本框只读属性的小bug
    windows64位下的redis及memcached的安装和使用
    spring.Net (Mvc)属性依赖注入------实例化对象
  • 原文地址:https://www.cnblogs.com/leiziv5/p/15085132.html
Copyright © 2011-2022 走看看