• <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)  編輯 收藏 引用

            <2009年8月>
            2627282930311
            2345678
            9101112131415
            16171819202122
            23242526272829
            303112345

            導航

            統計

            常用鏈接

            留言簿(3)

            隨筆分類

            隨筆檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            成人国内精品久久久久影院VR| 久久久精品国产免大香伊| 中文国产成人精品久久亚洲精品AⅤ无码精品| 国产精品福利一区二区久久| 久久九九亚洲精品| 最新久久免费视频| 久久国产乱子伦精品免费强| 久久夜色精品国产www| 人妻无码中文久久久久专区| 国产精品嫩草影院久久| 伊人久久大香线蕉av不卡| 国产亚洲精午夜久久久久久| 热re99久久6国产精品免费| 久久精品亚洲福利| 99久久超碰中文字幕伊人| 亚洲精品综合久久| 久久精品国产69国产精品亚洲| 国产欧美久久久精品影院| 国产精品亚洲综合专区片高清久久久 | 久久精品国产一区二区三区不卡 | 精品熟女少妇aⅴ免费久久| 亚洲色大成网站WWW久久九九| 欧美日韩精品久久久久| 999久久久免费精品国产| 人妻精品久久久久中文字幕一冢本| 亚洲国产精品成人久久蜜臀 | 精品一久久香蕉国产线看播放| 人妻丰满AV无码久久不卡| 久久人人爽人人爽人人爽| 欧美性大战久久久久久| 久久久久国色AV免费观看| 久久久久97国产精华液好用吗| 久久电影网一区| 99久久精品免费看国产免费| 国产精品99久久免费观看| 精品久久人妻av中文字幕| AV无码久久久久不卡蜜桃| 国产精品久久久久久搜索| 久久精品国产秦先生| 曰曰摸天天摸人人看久久久| 品成人欧美大片久久国产欧美...|