We're using Boost::Test to unit test our code (Visual Studio 2010, win32 C++ project). Since we're often working with Ogre::Vector3
objects (geometrical vectors in 3D space) I've written this wrapper to easily test two Vector3 objects for almost-equality:
static const double EPSILON = 1e-7;
void CHECK_CLOSE(const Ogre::Vector3 & actual, const Ogre::Vector3 & expected, Ogre::Real tolerance) {
if (std::fabs(expected.x) < EPSILON) BOOST_CHECK_SMALL(actual.x, tolerance);
else BOOST_CHECK_CLOSE(actual.x, expected.x, tolerance);
if (std::fabs(expected.y) < EPSILON) BOOST_CHECK_SMALL(actual.y, tolerance);
else BOOST_CHECK_CLOSE(actual.y, expected.y, tolerance);
if (std::fabs(expected.z) < EPSILON) BOOST_CHECK_SMALL(actual.z, tolerance);
else BOOST_CHECK_CLOSE(actual.z, expected.z, tolerance);
}
Unfortunately, when one of the BOOST_CHECK_XXX
calls fails, it reports the location in the wrapper function (which lives in rage_test.cpp):
../../../src/tests/boost_test/rage_test.cpp(20): error in
"km_bodyposemodifier_combo": difference{0.646806%} between
actual.y{3.01940417} and expected.y{3} exceeds 0.100000001%
I would much rather see it unwind another stack frame, and report the location of the CHECK_CLOSE
call. How do I do this?