• <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>

            walt

              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
              4 隨筆 :: 3 文章 :: 1 評論 :: 0 Trackbacks
            轉自:  csdn

            fiftymetre(50米深藍)


            關于測試驅動開發(fā),     C++的庫比較多,   選擇是一個問題.  
               
              Boost.Test是一個用于C++開發(fā)的測試框架,   類似的還有CPPUnit,   個人認為,   CPPUnit過多的照搬了JUnit的框架,   有比較濃厚的Java風格,   用起來總感覺有些束縛,   不是那么native.    
               
              CXXTest   我用過Symbian版本的,   好像需要Perl,   不過Symbian本身安裝的時候就需要Perl,   因此對于Symbian上來說還是無所謂,而且使用Perl可以免除一些套路代碼的編寫.   (題外話,   Symbian啥都要,   裝個Symbian   C++   SDK還要JDK1.3.2,   不知道開發(fā)J2ME是否需要安裝一個GCC?   )   .    
               
              Boost.Test可以以#include一行代碼的代價實現(xiàn)一個test-case的編寫,   就測試來說,   越簡單就可以越使得開發(fā)者愿意使用,    
              比起繼承一個基類,   覆蓋其中的一個虛擬函數(shù)來說,   Boost.Test在某些情況下就顯得十分方便了.    
               
              下面是一個Hello,world般的測試例子:   測試你的系統(tǒng)是否1等于2   (玩笑)  
               
              #include   <boost/test/included/test_engine_monitor.hpp>                             #1  
               
              int   test_main(int   ,   char   *[])                             #2  
              {  
                    BOOST_CHECK_EQUAL(1   ,   2);                           #3  
                    return   1;                                                               #4  
                    throw   "Ooops..";                                                 #5  
              }  
               
               
              #1     就是我前面說的一行代碼的代價  
              #2     main當然已經被Boost.Test接管了,   我們就用test_main,   等著被調用.  
              #3     測試宏,   要求1   ==   2   .   當然會報錯  
              #4     按照C的傳統(tǒng),   如果我們的test_main函數(shù)返回非0的值也是一個錯誤.    
              #5     異常逃出test_main外也是錯誤,   當然這句并不會執(zhí)行.   舉個例子而已.  
               
               
              然后編譯運行,   例如使用VC,   那么  
               
              cl.exe     /GX   /ID:/boost   hello.cpp    
               
              D:/boost是我的Boost安裝路徑.   然后運行hello.exe,   結果應該不出意外是報錯2個.   指出文件名,   行號等.   例如  
               
              hello.cpp(7):   error   in   "test_main_caller(   argc,   argv   )":   check   1   ==   2   failed   [1   !=   2]  
               
              D  
               
              :/boost/boost/test/impl/test_main.ipp(39):   error   in   "test_main_caller(   argc,   argv   )":   check   test_main_result   ==   0   ||   test_main_result   ==   boost::exit_success   failed  
               
               
              一個是#3的錯誤,   一個是#4的   .    
               
              這是最簡單的情況,   適用于測試不多的情形,   如果測試比較多,   那么就應該將Boost.Test編譯成一個Lib,   然后Link到這個Lib上,    
              而不是每次都整個編譯一次Boost.Test,   這樣可以節(jié)約編譯的時間(   主要花費在#1處).    
               
              配合Boost.Build中的Bjam也是一個好主意. 

            posted on 2010-01-26 19:47 白宇皓 閱讀(214) 評論(0)  編輯 收藏 引用
            国产欧美久久一区二区| 久久免费国产精品| 久久99国产亚洲高清观看首页| 人妻无码中文久久久久专区| 国产成人精品久久一区二区三区| 亚洲国产成人久久综合碰碰动漫3d | 久久精品麻豆日日躁夜夜躁| 精品久久久久久亚洲| 亚洲午夜无码久久久久小说| 久久久精品国产sm调教网站| 久久久久亚洲?V成人无码| 国内精品久久久久影院优| 亚洲日本久久久午夜精品| 狠狠色丁香婷婷久久综合不卡 | 热久久国产欧美一区二区精品| 国产aⅴ激情无码久久| 精品久久久久一区二区三区| 久久无码人妻一区二区三区 | 激情伊人五月天久久综合| 欧美精品福利视频一区二区三区久久久精品| 精品伊人久久大线蕉色首页| 99久久国产亚洲高清观看2024 | 久久久久久精品免费免费自慰| 一本一道久久精品综合| 久久久久国产精品熟女影院 | 久久99精品久久久久久9蜜桃| 亚洲精品白浆高清久久久久久 | 国产成人精品久久综合| 国内精品久久久久影院优| 无码AV波多野结衣久久| 久久久久久久免费视频| 亚洲国产天堂久久久久久| 国产精品99久久久久久www| 久久国产免费观看精品| 久久综合88熟人妻| 色综合久久中文字幕无码| 久久久这里有精品| 久久综合九色综合网站| 久久久精品国产| 无码人妻精品一区二区三区久久| 偷偷做久久久久网站|