From 3bd2f07d9c7cc3f9b727ecbaa3b93633d78fc908 Mon Sep 17 00:00:00 2001 From: Roland Kaufmann Date: Thu, 1 Aug 2013 10:19:44 +0200 Subject: [PATCH] Convert cubic interpolator to use Boost::UnitTest --- tests/test_cubic.cpp | 34 ++++++++++++++++++++++++++-------- 1 file changed, 26 insertions(+), 8 deletions(-) diff --git a/tests/test_cubic.cpp b/tests/test_cubic.cpp index 278e586c..ecbb3f68 100644 --- a/tests/test_cubic.cpp +++ b/tests/test_cubic.cpp @@ -16,6 +16,7 @@ /* Copyright 2009, 2010 SINTEF ICT, Applied Mathematics. Copyright 2009, 2010 Statoil ASA. + Portions Copyright 2013 Uni Research AS. This file is part of The Open Reservoir Simulator Project (OpenRS). @@ -34,10 +35,25 @@ */ #include "config.h" + +/* --- Boost.Test boilerplate --- */ +#if HAVE_DYNAMIC_BOOST_TEST +#define BOOST_TEST_DYN_LINK +#endif + +#define NVERBOSE // Suppress own messages when throw()ing + +#define BOOST_TEST_MODULE CubicTest +#include +#include + +/* --- our own headers --- */ #include using namespace Opm; -int main() +BOOST_AUTO_TEST_SUITE () + +BOOST_AUTO_TEST_CASE (cubic) { const int num_v = 3; double xv[num_v] = {0.0, 1.0, 2.0}; @@ -45,11 +61,13 @@ int main() std::vector x(xv, xv + num_v); std::vector f(fv, fv + num_v); MonotCubicInterpolator interp(x, f); - interp.evaluate(-1.0); - interp.evaluate(0.0); - interp.evaluate(0.0001); - interp.evaluate(0.5); - interp.evaluate(1.0); - interp.evaluate(2.0); - interp.evaluate(4.0); + BOOST_REQUIRE_CLOSE (interp.evaluate(-1.0), 10., 0.00001); + BOOST_REQUIRE_CLOSE (interp.evaluate(0.0), 10., 0.00001); + BOOST_REQUIRE_CLOSE (interp.evaluate(0.0001), 10.0011, 0.00001); + BOOST_REQUIRE_CLOSE (interp.evaluate(0.5), 17.375, 0.00001); + BOOST_REQUIRE_CLOSE (interp.evaluate(1.0), 21., 0.00001); + BOOST_REQUIRE_CLOSE (interp.evaluate(2.0), 2., 0.00001); + BOOST_REQUIRE_CLOSE (interp.evaluate(4.0), 2., 0.00001); } + +BOOST_AUTO_TEST_SUITE_END()