• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            馭風萬里無垠

            Python中根據不同參數組合產生單獨的test case的一種方法

             
            Python自帶的unittest和test兩個模塊為編寫test case提供了很靈活的支持,最常用的情況就是繼承自unittest.TestCase類,然后對每一個要進行測試的行為寫一個test_開頭的類成員函數,最后可以利用test.test_support.run_unittest函數跑所有的test case.
             
             
            在某種情況下,可能需要用不同的參數組合測試同樣的行為,這些行為要么很耗時間(譬如下載數據),要么是你希望從test case的執行結果上知道在測試什么,而不是單單得到一個大的 test case;此時如果僅僅寫一個test case并用內嵌循環來進行,那么其中一個除了錯誤,很難從測試結果里邊看出來。
             
            問題的關鍵在于是否有辦法根據輸入參數的不同組合產生出對應的test case;譬如你有10組數據,那么得到10個test case,當然不適用純手工的方式寫那么多個test_成員函數。
            一種可能的思路是不利用unittest.TestCase這個類框中的test_成員函數的方法,而是自己寫runTest這個成員函數,那樣會有一些額外的工作,而且看起來不是那么“智能”,如果目的是讓框架自動調用testcase.
             
            自然的思路就是
            • 利用setattr來自動為已有的TestCase類添加成員函數
            • 為了使這個方法湊效,需要用類的static method來生成decorate類的成員函數,并使該函數返回一個test函數對象出去
            • 在某個地方注冊這個添加test成員函數的調用(只需要在實際執行前就可以,可以放在模塊中自動執行亦可以手動調用)

            最后的代碼就有了:

             
            01 import unittest
            02 from test import test_support
            03
            04 def MyTestCase(unittest.TestCase):
            05     def setUp(self):
            06         #some setup code
            07         pass
            08        
            09     def clear(self):
            10         #some cleanup code
            11         pass
            12        
            13     def action(self, arg1, arg2):
            14         pass
            15        
            16     @staticmethod   
            17     def getTestFunc(arg1, arg2):
            18         def func(self):
            19             self.actions(arg1, arg2)
            20         return func
            21        
            22 def __generateTestCases():
            23     arglists = [('arg11', 'arg12'), ('arg21', 'arg22'), ('arg31', 'arg32')]
            24     for args in arglists:
            25         setattr(MyTestCase, 'test_func_%s_%s'%(args[0], args[1]),
            26             MyTestCase.getTestFunc(*args) )
            27 __generateTestCases()
            28      
            29 def test_main():
            30     test_support.run_unittest(MyTestCase)

             

            如此,添加一個新的可變參數組合,就會新生成一個test case, 只需要將參數組合添加到arglist中就可以了。

            posted on 2009-10-12 21:20 skyscribe 閱讀(1594) 評論(0)  編輯 收藏 引用

            <2010年1月>
            272829303112
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            導航

            統計

            常用鏈接

            留言簿(3)

            隨筆分類

            隨筆檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            99精品久久久久中文字幕| 日韩亚洲欧美久久久www综合网| 久久精品国产精品青草app| 韩国免费A级毛片久久| 国产国产成人精品久久| 色综合久久中文色婷婷| 日本高清无卡码一区二区久久| 久久人与动人物a级毛片| 精品久久久久久亚洲精品 | 久久精品国产亚洲AV电影| 久久精品国产福利国产秒| 久久精品国产男包| 99re这里只有精品热久久| 久久精品中文字幕大胸| 国产精品青草久久久久婷婷| 亚洲国产天堂久久综合| 久久久精品午夜免费不卡| 久久国内免费视频| 久久久久九国产精品| 久久这里只有精品首页| 久久精品中文字幕无码绿巨人| 久久精品中文字幕一区| 91精品国产综合久久婷婷| 少妇人妻综合久久中文字幕| 国产A级毛片久久久精品毛片| 一本色道久久88精品综合| 亚洲国产日韩欧美综合久久| 久久精品夜色噜噜亚洲A∨| 88久久精品无码一区二区毛片 | 久久久久四虎国产精品| 亚洲国产精品无码成人片久久| 久久国产香蕉一区精品| 99热精品久久只有精品| 99久久伊人精品综合观看| 九九精品99久久久香蕉| 97精品国产91久久久久久| 亚洲国产精品无码成人片久久| 亚洲精品无码专区久久久| 国内精品综合久久久40p| 精品久久久无码21p发布| 亚洲午夜久久久久久久久久|