斷言:
ASSERT_TRUE(condition); EXPECT_TRUE(condition); condition為真
ASSERT_FALSE(condition); EXPECT_FALSE(condition); condition為假
ASSERT_EQ(expected, actual); EXPECT_EQ(expected, actual); expected == actual
ASSERT_NE(val1, val2); EXPECT_NE(val1, val2); val1 != val2
ASSERT_LT(val1, val2); EXPECT_LT(val1, val2); val1 < val2
ASSERT_LE(val1, val2); EXPECT_LE(val1, val2); val1 <= val2
ASSERT_GT(val1, val2); EXPECT_GT(val1, val2); val1 > val2
ASSERT_GE(val1, val2); EXPECT_GE(val1, val2); val1 >= val2
ASSERT_STREQ(expected_str, actual_str); EXPECT_STREQ(expected_str, actual_str); 兩個(gè)C字符串有相同的內(nèi)容
ASSERT_STRNE(str1, str2); EXPECT_STRNE(str1, str2); 兩個(gè)C字符串有不同的內(nèi)容
ASSERT_STRCASEEQ(expected_str, actual_str); EXPECT_STRCASEEQ(expected_str, actual_str); 兩個(gè)C字符串有相同的內(nèi)容,忽略大小寫
ASSERT_STRCASENE(str1, str2); EXPECT_STRCASENE(str1, str2); 兩個(gè)C字符串有不同的內(nèi)容,忽略大小寫
ASSERT_*版本的斷言失敗時(shí)會(huì)產(chǎn)生致命失敗,并結(jié)束當(dāng)前函數(shù)。EXPECT_*版本的斷言產(chǎn)生非致命失敗,而不會(huì)中止當(dāng)前函數(shù)。通常更推薦使用EXPECT_*斷言,因?yàn)樗鼈冞\(yùn)行一個(gè)測(cè)試中可以有不止一個(gè)的錯(cuò)誤被報(bào)告出來(lái)。但如果在編寫斷言如果失敗,就沒有必要繼續(xù)往下執(zhí)行的測(cè)試時(shí),你應(yīng)該使用ASSERT_*斷言。
因?yàn)槭〉腁SSERT_*斷言會(huì)立刻從當(dāng)前的函數(shù)返回,可能會(huì)跳過(guò)其后的一些的清潔代碼,這樣也許會(huì)導(dǎo)致空間泄漏。根據(jù)泄漏本身的特質(zhì),這種情況也許值得修復(fù),也可能不值得我們關(guān)心——所以,如果你得到斷言錯(cuò)誤的同時(shí),還得到了一個(gè)堆檢查的錯(cuò)誤,記住上面我們所說(shuō)的這一點(diǎn)。
要提供一個(gè)自定義的錯(cuò)誤消息,只需要使用<<操作符,或一個(gè)<<操作符的序列,將其輸入到框架定義的宏中。下面是一個(gè)例子:
ASSERT_EQ(x.size(), y.size()) << "Vectors x and y are of unequal length";

for (int i = 0; i < x.size(); ++i) {
EXPECT_EQ(x[i], y[i]) << "Vectors x and y differ at index " << i;
}
任何能夠被輸出到ostream中的信息都可以被輸出到一個(gè)斷言宏中——特別是C字符串和string對(duì)象。如果一個(gè)寬字符串(wchar_t*,windows上UNICODE模式TCHAR*或std::wstring)被輸出到一個(gè)斷言中,在打印時(shí)它會(huì)被轉(zhuǎn)換成UTF-8編碼。
如果需要將信息輸出到XML中。在參數(shù)中使用:
--gtest_output=xml:test.xml
就可以了