一、前言
這篇文章主要總結gtest中的所有斷言相關的宏。 gtest中,斷言的宏可以理解為分為兩類,一類是ASSERT系列,一類是EXPECT系列。一個直觀的解釋是:
1. ASSERT_* 系列的斷言,當檢查點失敗時,退出當前函數(shù)(注意:并非退出當前案例)。
2. EXPECT_* 系列的斷言,當檢查點失敗時,繼續(xù)往下執(zhí)行。
二、示例
// int型比較,預期值:3,實際值:Add(1, 2)
EXPECT_EQ(3, Add(1, 2))
//
假如你的Add(1, 2) 結果為4的話,會在結果中輸出:
g:myprojectc++gtestdemogtestdemogtestdemo.cpp(16): error: Value of: Add(1, 2)
Actual:4
Expected:3
如果是將結果輸出到xml里的話,將輸出:(關于將結果輸出 為xml,見:http://www.cnblogs.com/coderzh/archive/2009/04/10/1432789.html)
<testcase name="Demo" status="run" time="0" classname="AddTest">
<failure message="Value of: Add(1, 2) Actual: 4 Expected: 3" type=""><![CDATA[g:myprojectc++gtestdemogtestdemogtestdemo.cpp:16
Value of: Add(1, 2)
Actual: 4
Expected: 3]]></failure>
</testcase>
如果你對自動輸出的出錯信 息不滿意的話,你還可以通過操作符<<將一些自定義的信息輸出,通常,這對于調試或是對一些檢查點的補充說明來說,非常有用!
下 面舉個例子:
如果不使用<<操作符自定義輸出的話:
for (int i = 0; i < x.size(); ++i)
{
EXPECT_EQ(x[i], y[i]);
}
看到的結果將是這樣的,你根本不知 道出錯時 i 等于幾:
g:myprojectc++gtestdemogtestdemogtestdemo.cpp(25): error: Value of: y[i]
Actual: 4
Expected: x[i]
Which is: 3
如 果使用<<操作符將一些重要信息輸出的話:
for (int i = 0; i < x.size(); ++i)
{
EXPECT_EQ(x[i], y[i]) << "Vectors x and y differ at index " << i;
}
從輸出結果中可 以定位到在 i = 2 時出現(xiàn)了錯誤。這樣的輸出結果看起來更加有用,容易理解:
g:myprojectc++gtestdemogtestdemogtestdemo.cpp(25): error: Value of: y[i]
Actual: 4
Expected: x[i]
Which is: 3
Vectors x and y differ at index 2