• <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)  編輯 收藏 引用
            AV狠狠色丁香婷婷综合久久| 久久精品免费全国观看国产| 国产91久久精品一区二区| 久久免费的精品国产V∧ | 大蕉久久伊人中文字幕| 久久国产精品一区| 精品综合久久久久久97| 久久久久久夜精品精品免费啦| 精品一区二区久久久久久久网站| 久久黄视频| 亚洲精品国产字幕久久不卡| 亚洲国产精品久久久久婷婷软件 | 久久亚洲国产最新网站| 精品综合久久久久久888蜜芽| 91久久香蕉国产熟女线看| 要久久爱在线免费观看| av国内精品久久久久影院| 久久精品国产欧美日韩| 性做久久久久久久| 国内精品久久久久久久coent| 久久精品国产亚洲αv忘忧草| 国产精品福利一区二区久久| 青青草原综合久久大伊人| 精品久久人人做人人爽综合| 三上悠亚久久精品| 久久精品免费一区二区| 久久夜色精品国产www| 99久久精品毛片免费播放| 亚洲中文字幕久久精品无码APP | 久久久久亚洲AV片无码下载蜜桃| 久久午夜综合久久| 国产精品热久久无码av| 精品国产福利久久久| 精品久久久无码人妻中文字幕豆芽 | 偷偷做久久久久网站| 久久久久亚洲精品天堂久久久久久| 久久精品中文騷妇女内射| 乱亲女H秽乱长久久久| 色婷婷久久综合中文久久蜜桃av| 久久久久久精品免费看SSS| 亚洲精品综合久久|