IUTEST(Hoge, ThrowValue) { IUTEST_ASSERT_THROW_VALUE_EQ(throw 2, int, 2); IUTEST_ASSERT_THROW_VALUE_STREQ(throw "error", const char *, "error"); }
int ReturnTest(void) { IUTEST_ASSERT_TRUE(true) << ::iutest::AssertionReturn<int>(-1); return 0; }
IUTEST(Hoge, Inform) { IUTEST_INFORM_TRUE(IsEven(2)); }
IUTEST(Hoge, Size) { IUTEST_ASSUME_EQ(4, sizeof(int)); }
IUTTEST(NullCheck, Sample) { int* p = (int*)malloc(4); IUTEST_ASSERT_TRUE(p != NULL); __analysis_assume(p != NULL); *p = 1; IUTEST_ASSERT_EQ(1, *p); }しかし、このような __analysis_assume は冗長な記述です。
IUTEST(NullCheck, Sample) { int* p = (int*)malloc(4); IUTEST_ASSERT_NOTNULL(p); *p = 1; IUTEST_ASSERT_EQ(1, *p); }
int f() { return 42; } IUTEST(Test, Sample) { IUTEST_ASSERT_EQ( 42, f() ); IUTEST_ASSERT_TRUE( f() == 42 ); IUTEST_ASSERT( f() == 42 ); IUTEST_ASSERT_LE( f(), 0 ); IUTEST_ASSERT_TRUE( f() <= 0 ); IUTEST_ASSERT( f() <= 0 ); }IUTEST_ASSERT_TRUE を使用した場合と違い、式アサーションでは式を分解して値を出力します。
IUTEST(Test, Sample) { IUTEST_ASSERT(f() <= 0 IUTEST_OPERAND(||) f() >= 100 ); }IUTEST_EXPRESSION:
IUTEST(Test, Sample) { IUTEST_ASSERT(f() <= 0 || IUTEST_EXPRESSION(f() >= 100) ); IUTEST_ASSERT(IUTEST_EXPRESSION(f() <= 0) || IUTEST_EXPRESSION(f() >= 100) ); IUTEST_ASSERT_TRUE(IUTEST_EXPRESSION(f() <= 0) || IUTEST_EXPRESSION(f() >= 100) ); }IUTEST_OPERAND は || , && を補助します。これは式アサーション専用のマクロになります。
void TestFunction(int x, int y) { IUTEST_ASSERT_EQ(x, y); } IUTEST_PMZ(ParamMethodTest, EQ, TestFunction, 0, 0); IUTEST_PMZ(ParamMethodTest, EQ, TestFunction, 1, 1);
//class AnyParamtest : public ::iutest::TestWithParam<int> {}; // 不要 IUTEST_P(AnyParamTest, Test) { const int value = GetParam<int>(); IUTEST_ASSERT_EQ(0, value); } IUTEST_INSTANTIATE_TEST_CASE_P(My1, AnyParamTest, ::iutest::Values(0));テストフィクスチャを省略した場合のパラメータ型は、::iutest::any になっています。
IUTEST_INSTANTIATE_TEST_CASE_P(A, TestP , ::iutest::Pairwise( ::iutest::Bool(), ::iutest::Values(1, 2), ::iutest::Values(10, 11) ) );
IUTEST_INSTANTIATE_TEST_CASE_P(A, TestP , ::iutest::RandomValues( 5 ) );RandomValues の第一引数にパラメータの総数を指定します。(第二引数に乱数シードを指定可能)
bool Filter(int n) { return n != 100 && n != 500 && n != 1000; } IUTEST_INSTANTIATE_TEST_CASE_P(A, TestP , ::iutest::ValuesGen( 5, ::iutest::RandomGenerator<int>(&Filter) ) );
IUTEST_INSTANTIATE_TEST_CASE_P(A1, TestP , ::iutest::Concat( ::iutest::Range(1, 10), ::iutest::Range(101, 110) ) ); IUTEST_INSTANTIATE_TEST_CASE_P(A2, TestP , ::iutest::Concat( ::iutest::Range(1, 10), ::iutest::Bool() ) );operator + の場合
IUTEST_INSTANTIATE_TEST_CASE_P(A1, TestP , ::iutest::Range(1, 10) + ::iutest::Range(101, 110) ); IUTEST_INSTANTIATE_TEST_CASE_P(A2, TestP , ::iutest::Range(1, 10) + ::iutest::Bool() + ::iutest::Values(99, 88, 77) ) );
IUTEST_PACKAGE(TestPackageA) { IUTEST(Test, Hoge) { IUTEST_ASSERT_TRUE(true); } } IUTEST_PACKAGE(TestPackageB) { IUTEST(Test, Hoge) { IUTEST_ASSERT_TRUE(true); } }また、--iutest_default_package_name コマンドラインオプションでデフォルトのパッケージ名を設定できます。
IUTEST(IUTEST_JAPANESE_NAME(あいうえお), IUTEST_JAPANESE_NAME(かきくけこ)) { }テストフィクスチャを利用する場合は、IUTEST_JAPANESE_NAME_F マクロを使用してください。
class FixedTest : public ::iutest::Test {}; IUTEST_F(IUTEST_JAPANESE_NAME_F(FixedTest, あいうえお), IUTEST_JAPANESE_NAME(かきくけこ)) { }※ IUTEST_TYPED_TEST_P は未対応です。
IUTEST(SkipTest, Skip) { if(sizeof(int) != 4 ) IUTEST_SKIP() << "sizeof(int) != 4"; }
class Hoge { int m_x; }; IUTEST_MAKE_PEEP(int Hoge::*, Hoge, m_x); IUTEST(ProdTest, Peep) { Hoge hoge; IUTEST_PEEP_GET(hoge, Hoge, m_x) = 4; IUTEST_ASSERT_EQ(4, IUTEST_PEEP_GET(hoge, Hoge, m_x)); }
//#include "iutest.hpp" #include "gtest/iutest_switch.hpp" // iutest.hpp の代わりに iutest_switch.hpp を使用する