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

            <2009年6月>
            31123456
            78910111213
            14151617181920
            21222324252627
            2829301234
            567891011

            導航

            統計

            常用鏈接

            留言簿(3)

            隨筆分類

            隨筆檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            久久精品国产国产精品四凭 | 免费观看成人久久网免费观看| 日产精品久久久久久久| 久久久久久人妻无码| 国产精品欧美久久久久无广告| 国产真实乱对白精彩久久| 色欲综合久久躁天天躁| 久久99国产精品尤物| 免费观看成人久久网免费观看| 亚洲精品高清一二区久久| 久久精品国产亚洲AV香蕉| 99精品伊人久久久大香线蕉| 久久久久亚洲AV成人网人人网站 | 国产成人精品久久亚洲高清不卡 | 久久久久免费精品国产| 久久久久亚洲精品天堂久久久久久 | 久久99久久99小草精品免视看 | 久久久久亚洲精品无码网址| 久久综合视频网站| 久久99精品综合国产首页| 无码AV中文字幕久久专区| 性做久久久久久久久老女人| 久久亚洲高清观看| 久久综合给久久狠狠97色 | 亚洲色欲久久久综合网| 老司机国内精品久久久久| 久久青青草原亚洲av无码app| 色天使久久综合网天天| 国产伊人久久| 久久本道综合久久伊人| 久久最近最新中文字幕大全| 久久久亚洲欧洲日产国码aⅴ| 久久影院久久香蕉国产线看观看| 亚洲精品乱码久久久久久| 青青青青久久精品国产h久久精品五福影院1421 | 亚洲综合婷婷久久| 99999久久久久久亚洲| AV无码久久久久不卡网站下载| 99精品久久精品一区二区| 久久久午夜精品| 模特私拍国产精品久久|