ASSERT_DOUBLE_EQ の ASSERT_EQ / ASSERT_NE に似たものを探しています。
ASSERT_DOUBLE_NE を使わずにこれを行う簡単な方法を見逃しているのでしょうか?
ASSERT_DOUBLE_EQ の ASSERT_EQ / ASSERT_NE に似たものを探しています。
ASSERT_DOUBLE_NE を使わずにこれを行う簡単な方法を見逃しているのでしょうか?
コンパニオンのモック フレームワーク Google Mock を使用できます。EXPECT_THAT/ASSERT_THAT マクロで使用できる強力なマッチャー (Hamcrest 風) のライブラリがあります。
EXPECT_THAT(value, FloatEq(1));
EXPECT_THAT(another_value, Not(DoubleEq(3.14)));
運が悪いようです。ただし、自分で追加することもできます。ASSERT_DOUBLE_EQ と ASSERT_NE をパターンとして使用して、次のコードを作成しました。
#define ASSERT_DOUBLE_NE(expected, actual)\
ASSERT_PRED_FORMAT2(::testing::internal::CmpHelperFloatingPointNE<double>, \
expected, actual)
// Helper template function for comparing floating-points.
//
// Template parameter:
//
// RawType: the raw floating-point type (either float or double)
//
// INTERNAL IMPLEMENTATION - DO NOT USE IN A USER PROGRAM.
template <typename RawType>
AssertionResult CmpHelperFloatingPointNE(const char* expected_expression,
const char* actual_expression,
RawType expected,
RawType actual) {
const FloatingPoint<RawType> lhs(expected), rhs(actual);
if ( ! lhs.AlmostEquals(rhs)) {
return AssertionSuccess();
}
StrStream expected_ss;
expected_ss << std::setprecision(std::numeric_limits<RawType>::digits10 + 2)
<< expected;
StrStream actual_ss;
actual_ss << std::setprecision(std::numeric_limits<RawType>::digits10 + 2)
<< actual;
Message msg;
msg << "Expected: (" << expected_expression << ") != (" << actual_expression
<< "), actual: (" << StrStreamToString(expected_ss) << ") == ("
<< StrStreamToString(actual_ss) << ")";
return AssertionFailure(msg);
}