• <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 閱讀(1598) 評論(0)  編輯 收藏 引用

            <2009年7月>
            2829301234
            567891011
            12131415161718
            19202122232425
            2627282930311
            2345678

            導航

            統計

            常用鏈接

            留言簿(3)

            隨筆分類

            隨筆檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            久久综合综合久久狠狠狠97色88| 狠狠色狠狠色综合久久| 青青青青久久精品国产| 国产L精品国产亚洲区久久| 久久亚洲AV无码西西人体| 亚洲精品乱码久久久久久中文字幕| 久久国产精品久久久| 久久精品极品盛宴观看| 成人免费网站久久久| 麻豆av久久av盛宴av| 国产精品VIDEOSSEX久久发布 | 久久久久亚洲AV无码专区网站| 国内精品伊人久久久久777| 久久性精品| 久久亚洲视频| 久久青青草原综合伊人| 一本色道久久99一综合| 久久综合一区二区无码| 久久青草国产手机看片福利盒子| 中文字幕乱码人妻无码久久| 欧美色综合久久久久久| 国产精品免费看久久久香蕉| 国内精品久久久久影院免费| 久久婷婷五月综合97色一本一本| 色妞色综合久久夜夜| 亚洲人成无码www久久久| 日本国产精品久久| 久久男人AV资源网站| 久久久中文字幕日本| 久久亚洲2019中文字幕| 久久午夜无码鲁丝片午夜精品| 久久精品无码一区二区日韩AV| 国产99久久久久久免费看| 久久久久久综合一区中文字幕| 久久精品人成免费| 久久国产成人精品麻豆| 中文字幕亚洲综合久久2| 国产免费久久久久久无码| 久久久久久无码国产精品中文字幕| 久久精品国产WWW456C0M| 久久青草国产精品一区|