青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 26, comments - 2, trackbacks - 0, articles - 0
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

gtest的一個簡單擴展

Posted on 2008-08-27 23:14 小夜 閱讀(2331) 評論(0)  編輯 收藏 引用 所屬分類: [07] 單元測試[51] C&C++

看了gtest的一個simple,其中有測試運行時間的方法,但使用起來稍微負責,因此做了一個簡單的擴展。

擴展內容:
1. TEST_T(test_case_name, test_name),用于定義運行時間測試用例。
2. TEST_T_SHOWTIME(),打開打印測試用例運行時間打印開關。
3. EXCEPT_TIME(second)和ASSERT_TIME(second),斷言,second為double類型,測試運行時間是否小于second。

使用說明:
向正常使用一樣,只是在需要時間測試時include “gtest_e.h”即可,當然也得把相應的庫鏈接到執行文件中。

具體實現:
源文件gtest_e.h----

/**
 * gtest_e.h
 
*/


#ifndef GTEST_E_H_
#define GTEST_E_H_

#include 
"gtest_time.h"

#define TEST_T(test_case_name, test_name)\
    GTEST_TEST(TIME_##test_case_name, test_name, ::TimeTest)

#define TEST_T_SHOWTIME() TimeTest_setShowFlag(1)

#define ASSERT_TIME(time) if(TimeTest_setTimePoint() - time > 0) \
    FAIL() 
<< "Time: running " << TimeTest_getTime() << "(s) > " << time << "(s)"

#define EXCEPT_TIME(time) if(TimeTest_setTimePoint() - time > 0) \
    ADD_FAILURE() 
<< "Time: running " << TimeTest_getTime() << "(s) > " << time << "(s)"

#endif /* GTEST_E_H_ */
源文件gtest_time.h----
/**
 * gtest_time.h
 
*/


#ifndef GTEST_TIME_H_
#define GTEST_TIME_H_

#include 
<gtest/gtest.h>

class TimeTest: public testing::Test
{
public:
    inline 
void TimeTest_setShowFlag(int flag)
    
{
        show_time_ 
= flag;
    }


    inline 
double TimeTest_getTime()
    
{
        
return end_time_ - start_time_;
    }


    
double TimeTest_setTimePoint();

protected:
    
double start_time_;
    
double end_time_;
    
int show_time_;

    
virtual void SetUp();
    
virtual void TearDown();
}
;

#endif /* GTEST_TIME_H_ */
源文件gtest_time.cpp----
/**
 * gtest_time.cpp
 
*/


#include 
<iostream>
#include 
"gtest_time.h"

using namespace std;

#if defined(WIN32)
#include 
<sys/timeb.h>
double now()
{
    
struct _timeb current;
    _ftime(
&current);
    
return (((double) current.time) + (1.0 * current.millitm) * 0.000001);
}

#else
double now()
{
    
struct timeval current;
    gettimeofday(
&current, NULL);
    
return (((double) current.tv_sec) + 1.0e-6 * ((double) current.tv_usec));
}

#endif

void TimeTest::SetUp()
{
    start_time_ 
= now();
    end_time_ 
= 0;
    TimeTest_setShowFlag(
0);
}


void TimeTest::TearDown()
{
    
if (show_time_)
    
{
        
double used_time = TimeTest_setTimePoint();
        cout 
<< "[   TIME   ] used time: " << used_time << "(s)"
                
<< endl;
    }

}


double TimeTest::TimeTest_setTimePoint()
{
    end_time_ 
= now();
    
return TimeTest_getTime();
}


以上內容只是一個簡單的實現,沒有過多的測試,且時間精度不夠,誤差較大。
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            日韩午夜激情| 国语自产精品视频在线看8查询8| 欧美激情一二区| 久久偷窥视频| 欧美多人爱爱视频网站| 欧美国产另类| 国产精品99久久不卡二区| 久久精品女人| 亚洲视频在线二区| 亚洲电影免费观看高清完整版| 欧美福利在线| 亚洲欧美日韩中文视频| 在线观看视频欧美| 美女爽到呻吟久久久久| 免费毛片一区二区三区久久久| 免费亚洲一区二区| 国产精品福利在线观看| 国产偷国产偷亚洲高清97cao| 在线播放亚洲| 亚洲一本视频| 麻豆精品一区二区综合av| 亚洲春色另类小说| 亚洲人成亚洲人成在线观看图片 | 日韩西西人体444www| 一本一本a久久| 欧美一区二区视频网站| 欧美精品一区二| 国产午夜精品理论片a级大结局 | 精品动漫av| 一本大道久久a久久精品综合 | 亚洲另类视频| 午夜亚洲性色视频| 欧美精选一区| 尤物yw午夜国产精品视频| 亚洲一区在线播放| 欧美电影在线| 欧美在线综合视频| 国产精品高潮呻吟久久av无限| 91久久线看在观草草青青| 久久久国产成人精品| 日韩亚洲欧美在线观看| 免费成人av在线| 激情婷婷欧美| 久久久久国色av免费观看性色| 制服丝袜激情欧洲亚洲| 欧美日韩亚洲精品内裤| 日韩午夜中文字幕| 亚洲韩日在线| 免费在线播放第一区高清av| 中文高清一区| 先锋影音网一区二区| 欧美成人免费全部| 亚洲欧美国产精品桃花| 欧美视频在线观看免费| 9久re热视频在线精品| 亚洲福利视频一区二区| 久久精品国产亚洲一区二区| 国产精品综合久久久| 亚洲欧美中文日韩v在线观看| 亚洲欧洲在线看| 米奇777超碰欧美日韩亚洲| 尤物99国产成人精品视频| 久久午夜av| 久久婷婷久久一区二区三区| 激情一区二区三区| 久久人人97超碰精品888| 久久久激情视频| 亚洲国产另类久久精品| 亚洲国产网站| 欧美色视频日本高清在线观看| 亚洲一区制服诱惑| 午夜久久资源| 亚洲高清一二三区| 亚洲精品美女在线| 欧美午夜精彩| 久久精品一区中文字幕| 久久免费黄色| 亚洲乱码国产乱码精品精天堂 | 欧美成人国产一区二区| 在线观看欧美激情| 亚洲国产激情| 国产精品久久夜| 久久深夜福利| 欧美大片在线观看| 亚洲欧美视频在线观看视频| 性久久久久久| 亚洲欧洲在线免费| 一本大道久久a久久精二百| 国产精品美女久久久| 久久一区二区三区国产精品| 欧美韩日一区二区| 久久不射网站| 欧美好吊妞视频| 午夜在线a亚洲v天堂网2018| 欧美一区二区三区播放老司机| 最新国产拍偷乱拍精品| 亚洲特级片在线| 亚洲国产精品ⅴa在线观看| 99精品免费网| 在线精品视频一区二区| 亚洲视频一二| 亚洲精品欧美日韩专区| 午夜精品亚洲| 一区二区三区四区五区视频| 久久久久久久一区二区| 小处雏高清一区二区三区| 欧美激情精品久久久久久免费印度| 久久av一区二区| 欧美日韩理论| 欧美中日韩免费视频| 国产精品劲爆视频| 国内精品久久久久久 | 99在线精品免费视频九九视| 亚洲女女女同性video| 亚洲蜜桃精久久久久久久| 午夜免费电影一区在线观看| 日韩手机在线导航| 久久天堂精品| 久久爱另类一区二区小说| 欧美肉体xxxx裸体137大胆| 嫩草成人www欧美| 国产亚洲精品成人av久久ww| 亚洲人体影院| 亚洲国产91| 久久精品一二三| 久久成人免费网| 国产精品永久入口久久久| 一本久久a久久精品亚洲| 日韩视频一区二区三区在线播放| 欧美中文字幕视频在线观看| 午夜国产精品影院在线观看| 欧美日韩国产色视频| 亚洲国产欧美精品| 亚洲欧洲日韩女同| 麻豆精品视频在线| 免费看黄裸体一级大秀欧美| 国内视频一区| 久久不射网站| 久久久久久**毛片大全| 国产欧美短视频| 午夜精品成人在线| 欧美在线视频观看免费网站| 国产精品社区| 欧美一级成年大片在线观看| 欧美在线国产| 国产亚洲综合在线| 欧美亚洲一区三区| 久久久久综合网| 激情五月婷婷综合| 美女网站久久| 亚洲欧洲在线视频| 亚洲一区二区三区三| 国产免费成人在线视频| 欧美在线亚洲在线| 欧美高清在线精品一区| 亚洲最新在线视频| 国产精品久久久久一区二区三区共 | 欧美一区亚洲二区| 久久全国免费视频| 亚洲日本一区二区| 欧美日韩一级片在线观看| 中文国产一区| 久久久久国产一区二区| 在线日本高清免费不卡| 欧美大片国产精品| 亚洲一区国产一区| 久久综合久色欧美综合狠狠| 亚洲精品久久久一区二区三区| 一区二区三区导航| 国外成人性视频| 久久久国产亚洲精品| 亚洲欧洲一级| 性色av一区二区三区红粉影视| 国产欧美精品日韩精品| 久久综合中文| 一区二区三区久久久| 久久久一区二区三区| 亚洲精品一级| 国产精品三级视频| 麻豆av一区二区三区久久| 99视频精品全国免费| 久久综合狠狠| 亚洲免费在线观看| 亚洲激情小视频| 国产精品电影观看| 麻豆91精品| 亚洲欧美在线视频观看| 亚洲国产精品成人综合色在线婷婷 | 欧美激情视频一区二区三区在线播放 | 激情自拍一区| 国产精品极品美女粉嫩高清在线 | 欧美在线日韩| 99re8这里有精品热视频免费| 国产九九视频一区二区三区| 欧美电影免费观看高清| 欧美在线1区| 亚洲午夜激情网页| 亚洲美女淫视频| 男人的天堂成人在线| 久久国产夜色精品鲁鲁99|