您的位置:軟件測試 > 開源軟件測試 > 開源單元測試工具 > cppUnit
便利的開發(fā)工具CppUnit快速使用指南
作者:網(wǎng)絡(luò)轉(zhuǎn)載 發(fā)布時間:[ 2013/7/16 10:31:18 ] 推薦標(biāo)簽:

4. 常用使用方式

按照上面的方式,如果要添加新的測試用例,需要把每個測試用例添加到 TestSuite 中,而且添加新的 TestFixture 需要把所有頭文件添加到 main.cpp 中,比較麻煩。為此 CppUnit 提供了 CppUnit::TestSuiteBuilder,CppUnit::TestFactoryRegistry 和一堆宏,用來方便地把 TestFixture 和測試用例注冊到 TestSuite 中。下面是通常的使用方式:

    /// MathTest.h 
    // A TestFixture subclass. 
    // Announce: use as your owner risk. 
    // Author  : liqun (liqun@nsfocus.com) 
    // Data    : 2003-7-5 
    #include "cppunit/extensions/HelperMacros.h" 
    class MathTest : public CppUnit::TestFixture { 
        // 聲明一個TestSuite 
        CPPUNIT_TEST_SUITE( MathTest ); 
        // 添加測試用例到TestSuite, 定義新的測試用例需要在這兒聲明一下 
        CPPUNIT_TEST( testAdd ); 
        // TestSuite聲明完成 
        CPPUNIT_TEST_SUITE_END(); 
        // 其余不變 
    protected: 
        int m_value1, m_value2; 
         
    public: 
        MathTest() {} 
         
        // 初始化函數(shù) 
        void setUp (); 
        // 清理函數(shù) 
        void tearDown(); 
         
        // 測試加法的測試函數(shù) 
        void testAdd (); 
        // 可以添加新的測試函數(shù) 
    }; 
    /// MathTest.cpp 
    // A TestFixture subclass. 
    // Announce: use as your owner risk. 
    // Author  : liqun (liqun@nsfocus.com) 
    // Data    : 2003-7-5 
    #include "MathTest.h" 
    // 把這個TestSuite注冊到名字為"alltest"的TestSuite中, 如果沒有定義會自動定義 
    // 也可以CPPUNIT_TEST_SUITE_REGISTRATION( MathTest );注冊到全局的一個未命名的TestSuite中. 
    CPPUNIT_TEST_SUITE_NAMED_REGISTRATION( MathTest, "alltest" ); 
    // 下面不變 
    void MathTest::setUp() 
    { 
         m_value1 = 2; 
         m_value2 = 3; 
    } 
    void MathTest::tearDown() 
    { 
    } 
    void MathTest::testAdd() 
    { 
         int result = m_value1 + m_value2; 
         CPPUNIT_ASSERT( result == 5 ); 
    } 
    /// main.cpp 
    // Main file for cppunit test. 
    // Announce: use as your owner risk. 
    // Compile : g++ -lcppunit MathTest.cpp main.cpp 
    // Run     : ./a.out 
    // Test    : RedHat 8.0 CppUnit1.8.0 
    // Author  : liqun ( a litthle modification. liqun@nsfocus.com) 
    // Data    : 2003-7-5 
    // 不用再包含所有TestFixture子類的頭文件 
    #include <cppunit/extensions/TestFactoryRegistry.h> 
    #include <cppunit/ui/text/TestRunner.h> 
    // 如果不更改TestSuite, 本文件后期不需要更改.  
    int main() 
    { 
        CppUnit::TextUi::TestRunner runner; 
         
        // 從注冊的TestSuite中獲取特定的TestSuite, 沒有參數(shù)獲取未命名的TestSuite. 
        CppUnit::TestFactoryRegistry &registry = CppUnit::TestFactoryRegistry::getRegistry("alltest"); 
    <!-- code sample is too wide -->  // 添加這個TestSuite到TestRunner中 
        runner.addTest( registry.makeTest() ); 
        // 運行測試 
        runner.run(); 
    } 

這樣添加新的測試用例只需要在類定義的開始聲明一下即可。

5. 其他實際問題

通常包含測試用例代碼和被測試對象是在不同的項目中。應(yīng)該在另一個項目(好在不同的目錄)中編寫 TestFixture,然后把被測試的對象包含在測試項目中。

對某個類或者某個函數(shù)進(jìn)行測試的時候,這個 TestFixture 可能引用了別的類或者別的函數(shù),為了隔離其他部分代碼的影響,應(yīng)該在源文件中臨時定義一些樁程序,模擬這些類或者函數(shù)。這些代碼可以通過宏定義在測試項目中有效,而在被測試的項目中無效。

上一頁1234下一頁
軟件測試工具 | 聯(lián)系我們 | 投訴建議 | 誠聘英才 | 申請使用列表 | 網(wǎng)站地圖
滬ICP備07036474 2003-2017 版權(quán)所有 上海澤眾軟件科技有限公司 Shanghai ZeZhong Software Co.,Ltd