16#if !defined(_CRT_SECURE_NO_WARNINGS)
17#define _CRT_SECURE_NO_WARNINGS
41#error Macro CHECK is already defined
47 if (!UnitTest::Check(value)) \
48 UnitTest::ReportFailure (__FILE__, __LINE__, "Check failed: " #value);\
51 UnitTest::ReportFailure (__FILE__, __LINE__, \
52 "Unhandled exception in CHECK(" #value ")"); \
63#error Macro CHECK_EX is already defined
65#define CHECK_EX(value, ...) \
69 if (!UnitTest::Check(value)){ \
70 char message[UnitTest::MAX_MESSAGE_SIZE]; \
71 snprintf (message, UnitTest::MAX_MESSAGE_SIZE, __VA_ARGS__); \
72 UnitTest::ReportFailure (__FILE__, __LINE__, message); \
76 UnitTest::ReportFailure (__FILE__, __LINE__, \
77 "Unhandled exception in CHECK_EX(" #value ")"); \
88#error Macro CHECK_EQUAL is already defined
91#define CHECK_EQUAL(expected, actual) \
96 if (!UnitTest::CheckEqual((expected), (actual), str__)) \
97 UnitTest::ReportFailure (__FILE__, __LINE__, str__); \
100 UnitTest::ReportFailure (__FILE__, __LINE__, \
101 "Unhandled exception in CHECK_EQUAL(" #expected ", " #actual ")"); \
112#error Macro CHECK_NAN is already defined
115#define CHECK_NAN(value) \
119 if (!UnitTest::CheckNaN(value)) \
120 UnitTest::ReportFailure (__FILE__, __LINE__, "Check failed: " #value " is not NaN");\
123 UnitTest::ReportFailure (__FILE__, __LINE__, \
124 "Unhandled exception in CHECK_NAN(" #value ")"); \
136#error Macro CHECK_EQUAL_EX is already defined
138#define CHECK_EQUAL_EX(expected, actual, ...) \
143 if (!UnitTest::CheckEqual((expected), (actual), str__)) \
145 char message[UnitTest::MAX_MESSAGE_SIZE]; \
146 snprintf (message, UnitTest::MAX_MESSAGE_SIZE, __VA_ARGS__); \
149 UnitTest::ReportFailure (__FILE__, __LINE__, str__); \
153 UnitTest::ReportFailure (__FILE__, __LINE__, \
154 "Unhandled exception in CHECK_EQUAL_EX(" #expected ", " #actual ")"); \
167#error Macro CHECK_CLOSE is already defined
169#define CHECK_CLOSE(expected, actual,...) \
174 if (!UnitTest::CheckClose ((expected), (actual), (__VA_ARGS__+0), str__)) \
175 UnitTest::ReportFailure (__FILE__, __LINE__, str__); \
177 catch (UnitTest::tolerance_not_set&) \
179 throw UnitTest::test_abort (__FILE__, __LINE__, "UnitTest::default_tolerance not set"); \
182 UnitTest::ReportFailure (__FILE__, __LINE__, \
183 "Unhandled exception in CHECK_CLOSE(" #expected ", " #actual ")"); \
196#error Macro CHECK_CLOSE_EX is already defined
198#define CHECK_CLOSE_EX(expected, actual, tolerance, ...) \
203 if (!UnitTest::CheckClose ((expected), (actual), (tolerance), str__)) \
205 char message[UnitTest::MAX_MESSAGE_SIZE]; \
206 snprintf (message, UnitTest::MAX_MESSAGE_SIZE, __VA_ARGS__); \
209 UnitTest::ReportFailure (__FILE__, __LINE__, str__); \
212 catch (UnitTest::tolerance_not_set&) \
214 throw UnitTest::test_abort (__FILE__, __LINE__, "UnitTest::default_tolerance not set"); \
217 UnitTest::ReportFailure (__FILE__, __LINE__, \
218 "Unhandled exception in CHECK_CLOSE_EX(" #expected ", " #actual ")"); \
228#ifdef CHECK_ARRAY_EQUAL
229#error Macro CHECK_ARRAY_EQUAL is already defined
232#define CHECK_ARRAY_EQUAL(expected, actual, count) \
237 if (!UnitTest::CheckArrayEqual ((expected), (actual), (count), str__)) \
238 UnitTest::ReportFailure (__FILE__, __LINE__, str__); \
241 UnitTest::ReportFailure (__FILE__, __LINE__, \
242 "Unhandled exception in CHECK_ARRAY_EQUAL(" #expected ", " #actual ")"); \
253#ifdef CHECK_ARRAY_CLOSE
254#error Macro CHECK_ARRAY_CLOSE is already defined
257#define CHECK_ARRAY_CLOSE(expected, actual, count, ...) \
262 if (!UnitTest::CheckArrayClose ((expected), (actual), (count), (__VA_ARGS__+0), str__)) \
263 UnitTest::ReportFailure (__FILE__, __LINE__, str__); \
265 catch (UnitTest::tolerance_not_set&) \
267 throw UnitTest::test_abort (__FILE__, __LINE__, "UnitTest::default_tolerance not set"); \
270 UnitTest::ReportFailure (__FILE__, __LINE__, \
271 "Unhandled exception in CHECK_ARRAY_CLOSE(" #expected ", " #actual ")"); \
282#ifdef CHECK_ARRAY2D_EQUAL
283#error Macro CHECK_ARRAY2D_EQUAL is already defined
286#define CHECK_ARRAY2D_EQUAL(expected, actual, rows, columns) \
291 if (!UnitTest::CheckArray2DEqual ((expected), (actual), (rows), (columns), str__)) \
292 UnitTest::ReportFailure (__FILE__, __LINE__, str__); \
295 UnitTest::ReportFailure (__FILE__, __LINE__, \
296 "Unhandled exception in CHECK_ARRAY2D_EQUAL(" #expected ", " #actual ")"); \
308#ifdef CHECK_ARRAY2D_CLOSE
309#error Macro CHECK_ARRAY2D_CLOSE is already defined
312#define CHECK_ARRAY2D_CLOSE(expected, actual, rows, columns, ...) \
317 if (!UnitTest::CheckArray2DClose (expected, actual, rows, columns, (__VA_ARGS__+0), str__)) \
318 UnitTest::ReportFailure (__FILE__, __LINE__, str__); \
320 catch (UnitTest::tolerance_not_set&) \
322 throw UnitTest::test_abort (__FILE__, __LINE__, "UnitTest::default_tolerance not set"); \
325 UnitTest::ReportFailure (__FILE__, __LINE__, \
326 "Unhandled exception in CHECK_ARRAY2D_CLOSE(" #expected ", " #actual ")"); \
339#error Macro CHECK_THROW is already defined
341#define CHECK_THROW(expr, except) \
344 bool caught_ = false; \
346 catch (const except& ) { caught_ = true; } \
348 UnitTest::ReportFailure (__FILE__, __LINE__, \
349 "Unexpected exception in CHECK_THROW"); \
352 UnitTest::ReportFailure (__FILE__, __LINE__, \
353 "Expected exception: \"" #except "\", not thrown"); \
365#error Macro CHECK_THROW_EX is already defined
367#define CHECK_THROW_EX(expr, except, ...) \
370 bool caught_ = false; \
372 catch (const except& ) { caught_ = true; } \
374 UnitTest::ReportFailure (__FILE__, __LINE__, \
375 "Unexpected exception in CHECK_THROW_EX"); \
378 std::string str__{"Expected exception: \"" #except "\", not thrown"}; \
379 char message[UnitTest::MAX_MESSAGE_SIZE]; \
380 snprintf (message, UnitTest::MAX_MESSAGE_SIZE, __VA_ARGS__); \
383 UnitTest::ReportFailure (__FILE__, __LINE__, str__); \
395#ifdef CHECK_THROW_EQUAL
396#error Macro CHECK_THROW_EQUAL is already defined
398#define CHECK_THROW_EQUAL(expression, value, except) \
401 bool caught_ = false; \
402 try { expression; } \
403 catch (const except& actual) { \
406 if (!UnitTest::CheckEqual(value, actual, str__)) \
407 UnitTest::ReportFailure (__FILE__, __LINE__, str__); \
410 UnitTest::ReportFailure (__FILE__, __LINE__, \
411 "Unexpected exception in CHECK_THROW_EQUAL"); \
414 UnitTest::ReportFailure (__FILE__, __LINE__, \
415 "Expected exception: \"" #except "\", not thrown"); \
427#ifdef CHECK_THROW_EQUAL_EX
428#error Macro CHECK_THROW_EQUAL_EX is already defined
430#define CHECK_THROW_EQUAL_EX(expression, value, except, ...) \
433 bool caught_ = false; \
434 try { expression; } \
435 catch (const except& actual) { \
438 if (!UnitTest::CheckEqual(value, actual, str__)) \
440 char message[UnitTest::MAX_MESSAGE_SIZE]; \
441 snprintf (message, UnitTest::MAX_MESSAGE_SIZE, __VA_ARGS__); \
444 UnitTest::ReportFailure (__FILE__, __LINE__, str__); \
448 UnitTest::ReportFailure (__FILE__, __LINE__, \
449 "Unexpected exception in CHECK_THROW_EQUAL"); \
453 std::string str__{ "Expected exception: \"" #except "\", not thrown" }; \
454 char message[UnitTest::MAX_MESSAGE_SIZE]; \
455 snprintf (message, UnitTest::MAX_MESSAGE_SIZE, __VA_ARGS__); \
458 UnitTest::ReportFailure (__FILE__, __LINE__, \
459 "Expected exception: \"" #except "\", not thrown"); \
469#ifdef CHECK_FILE_EQUAL
470#error Macro CHECK_FILE_EQUAL is already defined
472#define CHECK_FILE_EQUAL(expected, actual) \
477 if (!UnitTest::CheckFileEqual((expected), (actual), str__)) \
478 UnitTest::ReportFailure (__FILE__, __LINE__, str__); \
481 UnitTest::ReportFailure (__FILE__, __LINE__, \
482 "Unhandled exception in CHECK_EQUAL(" #expected ", " #actual ")"); \
493#error Macro FAILURE is already defined
495#define FAILURE(...) \
498 char message[UnitTest::MAX_MESSAGE_SIZE]; \
499 snprintf (message, UnitTest::MAX_MESSAGE_SIZE, __VA_ARGS__); \
500 UnitTest::ReportFailure (__FILE__, __LINE__, message); \
507#if _MSVC_LANG < 201703L
509extern double default_tolerance;
512inline double default_tolerance = 0;
524template <
typename Value>
536template <
typename Value>
539 return std::isnan(value);
551template <
typename expected_T,
typename actual_T>
552bool CheckEqual (
const expected_T& expected,
const actual_T& actual, std::string& msg)
554 if (!(expected == actual))
556 std::stringstream stream;
557 stream <<
"Expected " << expected <<
" but was " << actual;
566template <
typename expected_T,
typename actual_T>
567bool CheckEqual (
const expected_T* expected,
const actual_T* actual, std::string& msg)
569 if (!(*expected == *actual))
571 std::stringstream stream;
572 stream <<
"Expected " << *expected <<
" but was " << *actual;
593template <
typename expected_T,
typename actual_T>
595bool CheckEqual (
const std::vector<expected_T>& expected,
const std::vector<actual_T>& actual, std::string& msg)
597 if (expected != actual)
599 std::stringstream stream;
600 stream <<
"Expected [ ";
601 for (
auto& p : expected)
604 stream <<
"] but was [ ";
605 for (
auto& p : actual)
628template <
typename expected_T,
typename actual_T,
size_t N>
630bool CheckEqual (
const std::array<expected_T,N>& expected,
const std::array<actual_T,N>& actual, std::string& msg)
632 if (expected != actual)
634 std::stringstream stream;
635 stream <<
"Expected [ ";
636 for (
size_t i = 0; i < N; ++i)
637 stream << expected[i] <<
" ";
639 stream <<
"] but was [ ";
640 for (
size_t i = 0; i < N; ++i)
641 stream << actual[i] <<
" ";
663template <
typename expected_T,
typename actual_T>
665bool CheckEqual (
const std::list<expected_T>& expected,
const std::list<actual_T>& actual, std::string& msg)
667 if (expected != actual)
669 std::stringstream stream;
670 stream <<
"Expected ( ";
671 for (
auto const& x : expected)
674 stream <<
") but was ( ";
675 for (
auto const& x : actual)
689#if __WCHAR_MAX__ > 0x10000
690inline std::string to_utf8 (
const std::wstring& ws)
693 auto in = ws.cbegin ();
694 while (in != ws.end ())
696 unsigned int c = (
unsigned int)*in++;
698 out.push_back ((
char)c);
701 out.push_back (0xC0 | (c >> 6));
702 out.push_back (0x80 | (c & 0x3f));
706 out.push_back (0xE0 | (c >> 12));
707 out.push_back (0x80 | ((c >> 6) & 0x3f));
708 out.push_back (0x80 | (c & 0x3f));
712 out.push_back (0xF0 | (c >> 18));
713 out.push_back (0x80 | ((c >> 12) & 0x3f));
714 out.push_back (0x80 | ((c >> 6) & 0x3f));
715 out.push_back (0x80 | (c & 0x3f));
721inline std::string
to_utf8 (
const std::wstring& ws)
724 auto in = ws.cbegin ();
725 while (in != ws.end ())
727 unsigned int c1 = (
unsigned int)*in++;
728 if (c1 < 0xD800 || c1 > 0xe000)
731 out.push_back ((
char)c1);
734 out.push_back (
char(0xC0 | (c1 >> 6)));
735 out.push_back (
char(0x80 | (c1 & 0x3f)));
739 out.push_back (
char(0xE0 | (c1 >> 12)));
740 out.push_back (
char(0x80 | ((c1 >> 6) & 0x3f)));
741 out.push_back (
char(0x80 | (c1 & 0x3f)));
744 else if (in != ws.end ())
746 unsigned int c2 = (
unsigned int)*in++;
747 if (c1 > 0xdbff || c2 < 0xdc00)
753 unsigned int c = ((c1 << 10) | c2) + 0x10000;
755 out.push_back (
char(0xF0 | (c >> 18)));
756 out.push_back (
char(0x80 | ((c >> 12) & 0x3f)));
757 out.push_back (
char(0x80 | ((c >> 6) & 0x3f)));
758 out.push_back (
char(0x80 | (c & 0x3f)));
777bool CheckEqual (
const std::wstring expected,
const std::wstring actual,
780 if (expected != actual)
782 std::stringstream stream;
783 std::string u8exp =
to_utf8 (expected);
784 std::string u8act =
to_utf8 (actual);
785 stream <<
"Expected \'" << u8exp <<
"\' but was \'" << u8act <<
"\'";
805bool CheckEqual (
const wchar_t *expected,
const wchar_t *actual,
808 if (wcscmp (expected, actual))
810 std::stringstream stream;
811 std::string u8exp =
to_utf8 (expected);
812 std::string u8act =
to_utf8 (actual);
813 stream <<
"Expected \'" << u8exp <<
"\' but was \'" << u8act <<
"\'";
824bool CheckEqual (
wchar_t *expected,
wchar_t *actual, std::string &msg)
826 return CheckEqual (
const_cast<const wchar_t *
> (expected),
const_cast<const wchar_t *
> (actual), msg);
830bool CheckEqual (
const wchar_t *expected,
wchar_t *actual, std::string &msg)
832 return CheckEqual (expected,
const_cast<const wchar_t *
> (actual), msg);
836bool CheckEqual (
wchar_t *expected,
const wchar_t *actual, std::string &msg)
838 return CheckEqual (
const_cast<const wchar_t *
> (expected), actual, msg);
848bool CheckEqual (
const char* expected,
const char* actual, std::string& msg)
850 if (strcmp (expected, actual))
852 std::stringstream stream;
853 stream <<
"Expected \'" << expected <<
"\' but was \'" << actual <<
"\'";
861bool CheckEqual (
char* expected,
char* actual, std::string& msg)
863 return CheckEqual (
const_cast<const char *
>(expected),
const_cast<const char*
>(actual), msg);
867bool CheckEqual (
const char* expected,
char* actual, std::string& msg)
869 return CheckEqual (
const_cast<const char *
>(expected),
const_cast<const char*
>(actual), msg);
873bool CheckEqual (
char* expected,
const char* actual, std::string& msg)
875 return CheckEqual (
const_cast<const char *
>(expected),
const_cast<const char*
>(actual), msg);
894template <
typename expected_T,
typename actual_T>
895bool isClose (
const expected_T& expected,
const actual_T& actual,
double tolerance)
903 return fabs ((
double)(actual - expected)) <= tolerance;
916template <
typename expected_T,
typename actual_T>
917bool CheckClose (
const expected_T& expected,
const actual_T& actual,
double tolerance,
920 if (!
isClose(actual, expected, tolerance))
923 int prec = (int)(1 - log10 (fail_tol));
924 std::stringstream stream;
925 stream.precision (prec);
926 stream.setf (std::ios::fixed);
927 stream <<
"Expected " << expected <<
" +/- " << fail_tol <<
" but was " << actual;
944template <
typename expected_T,
typename actual_T>
945bool Equal1D (
const expected_T& expected,
const actual_T& actual,
size_t count)
947 for (
size_t i = 0; i < count; ++i)
948 if (expected[i] != actual[i])
962template <
typename expected_T,
typename actual_T>
964 size_t count, std::string& msg)
966 if (!
Equal1D (expected, actual, count))
968 std::stringstream stream;
969 stream <<
"Expected [ ";
970 for (
size_t i = 0; i < count; ++i)
971 stream << expected[i] <<
" ";
973 stream <<
"] but was [ ";
974 for (
size_t i = 0; i < count; ++i)
975 stream << actual[i] <<
" ";
997template <
typename expected_T,
typename actual_T>
998bool isClose1D (
const expected_T& expected,
const actual_T& actual,
size_t count,
double tolerance)
1000 for (
size_t i = 0; i < count; ++i)
1002 if (!
isClose(expected[i], actual[i], tolerance))
1021template <
typename expected_T,
typename actual_T>
1023 double tolerance, std::string& msg)
1025 if (!
isClose1D (expected, actual, count, tolerance))
1028 int prec = (int)(1 - log10 (fail_tol));
1030 std::stringstream stream;
1031 stream.precision (prec);
1032 stream.setf (std::ios::fixed);
1033 stream <<
"Expected [ ";
1034 for (
size_t i = 0; i < count; ++i)
1035 stream << expected[i] <<
" ";
1037 stream <<
"] +/- " << fail_tol <<
" but was [ ";
1038 for (
size_t i = 0; i < count; ++i)
1039 stream << actual[i] <<
" ";
1041 msg = stream.str ();
1060 if (!(expected == actual)) {
1061 std::stringstream stream;
1062 stream <<
"Expected " << expected <<
" but was " << actual;
1080template <
typename expected_T,
typename actual_T>
1081bool CheckClose (
const std::vector<expected_T>& expected,
const std::vector<actual_T>& actual,
double tolerance,
1084 if (expected.size () != actual.size ()
1085 || !
isClose1D (&expected[0], &actual[0], expected.size(), tolerance))
1088 int prec = (int)(1 - log10 (fail_tol));
1089 std::stringstream stream;
1090 stream.precision (prec);
1091 stream.setf (std::ios::fixed);
1092 stream <<
"Expected [ ";
1093 for (
auto& p : expected)
1096 stream <<
"] +/- " << fail_tol <<
" but was [ ";
1097 for (
auto& p : actual)
1100 msg = stream.str ();
1116template <
typename expected_T,
typename actual_T,
size_t N>
1117bool CheckClose (
const std::array<expected_T, N>& expected,
const std::array<actual_T, N>& actual,
double tolerance,
1120 if (!
isClose1D (&expected[0], &actual[0], N, tolerance))
1123 int prec = (int)(1 - log10 (fail_tol));
1124 std::stringstream stream;
1125 stream.precision (prec);
1126 stream.setf (std::ios::fixed);
1127 stream <<
"Expected [ ";
1128 for (
auto& p : expected)
1131 stream <<
"] +/- " << fail_tol <<
" but was [ ";
1132 for (
auto& p : actual)
1135 msg = stream.str ();
1150template <
typename expected_T,
typename actual_T>
1151bool Equal2D (
const expected_T& expected,
const actual_T& actual,
size_t rows,
size_t columns)
1153 for (
size_t i = 0; i < rows; ++i)
1154 if (!
Equal1D (expected[i], actual[i], columns))
1169template <
typename expected_T,
typename actual_T>
1171 size_t rows,
size_t columns, std::string& msg)
1173 if (!
Equal2D (expected, actual, rows, columns))
1175 std::stringstream stream;
1177 stream <<
"Expected [\n";
1178 for (i = 0; i < rows; ++i)
1181 for (j = 0; j < columns; ++j)
1182 stream << expected[i][j] <<
" ";
1186 stream <<
"] but was [\n";
1187 for (i = 0; i < rows; ++i)
1190 for (j = 0; j < columns; ++j)
1191 stream << actual[i][j] <<
" ";
1195 msg = stream.str ();
1211template <
typename expected_T,
typename actual_T>
1212bool isClose2D (
const expected_T& expected,
const actual_T& actual,
size_t rows,
size_t columns,
1215 for (
size_t i = 0; i < rows; ++i)
1216 if (!
isClose1D (expected[i], actual[i], columns, tolerance))
1233template <
typename expected_T,
typename actual_T>
1235 size_t rows,
size_t columns,
double tolerance, std::string& msg)
1237 if (!
isClose2D (expected, actual, rows, columns, tolerance))
1240 int prec = (int)(1 - log10 (fail_tol));
1241 std::stringstream stream;
1242 stream.precision (prec);
1243 stream.setf (std::ios::fixed);
1244 stream <<
"Expected [\n";
1246 for (i = 0; i < rows; ++i)
1249 for (j = 0; j < columns; ++j)
1250 stream << expected[i][j] <<
" ";
1254 stream <<
"] +/- " << fail_tol <<
" but was [\n";
1255 for (i = 0; i < rows; ++i)
1258 for (j = 0; j < columns; ++j)
1259 stream << actual[i][j] <<
" ";
1263 msg = stream.str ();
1281bool CheckFileEqual (
const std::string& ref,
const std::string& actual, std::string& message)
1283 struct stat st1, st2;
1284 std::ostringstream buf;
1286 stat (ref.c_str(), &st1);
1287 stat (actual.c_str(), &st2);
1288 if (st1.st_size != st2.st_size)
1290 buf <<
"Size is different (" << st1.st_size <<
" vs " << st2.st_size
1291 <<
") while comparing " << ref <<
" and " << actual;
1292 message = buf.str();
1297 f1 = fopen (ref.c_str(),
"r");
1298 f2 = fopen (actual.c_str(),
"r");
1301 if (f1) fclose (f1);
1302 if (f2) fclose (f2);
1303 buf <<
"Failed to open files while comparing "
1304 << ref <<
" and " << actual;
1305 message = buf.str();
1311 char ln1[1024], ln2[1024];
1315 if (fgets (ln1,
sizeof (ln1), f1)
1316 && fgets (ln2,
sizeof (ln2), f2))
1317 ok = !strcmp (ln1, ln2);
1327 for (off = 0, p1 = ln1, p2 = ln2;
1328 *p1 && *p2 && *p1 == *p2;
1331 buf <<
"Difference at line " << ln <<
" position " << off
1332 <<
" while comparing " << ref <<
" and " << actual;
1333 message = buf.str();
1348#define EXPECT_TRUE(x) CHECK (x)
1349#define EXPECT_FALSE(x) CHECK (!(x))
1350#define EXPECT_EQ(A, B) CHECK_EQUAL (B, A)
1351#define EXPECT_NE(A, B) \
1355 std::string str__; \
1356 if (UnitTest::CheckEqual ((A), (B), str__)) \
1357 UnitTest::ReportFailure (__FILE__, __LINE__, str__); \
1360 UnitTest::ReportFailure (__FILE__, __LINE__, \
1361 "Unhandled exception in CHECK_EQUAL(" #A ", " #B ")"); \
1365#define EXPECT_GE(A, B) CHECK ((A) >= (B))
1366#define EXPECT_GT(A, B) CHECK ((A) > (B))
1367#define EXPECT_LE(A, B) CHECK ((A) <= (B))
1368#define EXPECT_LT(A, B) CHECK ((A) < (B))
1370#define EXPECT_NEAR(A, B, tol) CHECK_CLOSE(B, A, tol)
1371#define EXPECT_THROW(expr, except) CHECK_THROW(expr, except)
1373#define ASSERT_TRUE(expr) ABORT (!(expr))
1374#define ASSERT_FALSE(expr) ABORT (expr)
1375#define ASSERT_EQ(e1, e2) \
1378 std::string str__; \
1379 if (!UnitTest::CheckEqual((e1), (e2), str__)) \
1380 throw UnitTest::test_abort (__FILE__, __LINE__, str__.c_str()); \
1383#define ASSERT_NE(e1, e2) \
1386 std::string str__; \
1387 if (UnitTest::CheckEqual ((e1), (e2), str__)) \
1389 std::stringstream stream__; \
1390 stream__ << (e1) << " and " << (e2) << " should be different"; \
1391 throw UnitTest::test_abort (__FILE__, __LINE__, stream__.str ().c_str ());\
1395#define ASSERT_GE(e1, e2) ABORT ((e1) < (e2))
1396#define ASSERT_GT(e1, e2) ABORT ((e1) <= (e2))
1397#define ASSERT_LE(e1, e2) ABORT ((e1) > (e2))
1398#define ASSERT_LT(e1, e2) ABORT ((e1) >= (e2))
bool CheckNaN(Value const value)
Definition checks.h:537
double default_tolerance
Default tolerance for CLOSE... macros.
std::string to_utf8(const std::wstring &ws)
Internal function for conversion from UTF-16 to UTF-8.
Definition checks.h:721
bool CheckArray2DClose(const expected_T &expected, const actual_T &actual, size_t rows, size_t columns, double tolerance, std::string &msg)
Definition checks.h:1234
bool CheckClose(const expected_T &expected, const actual_T &actual, double tolerance, std::string &msg)
Definition checks.h:917
bool Check(Value const value)
Definition checks.h:525
bool isClose1D(const expected_T &expected, const actual_T &actual, size_t count, double tolerance)
Definition checks.h:998
bool CheckArrayClose(const expected_T &expected, const actual_T &actual, size_t count, double tolerance, std::string &msg)
Definition checks.h:1022
bool CheckArrayEqual(const expected_T &expected, const actual_T &actual, size_t count, std::string &msg)
Definition checks.h:963
bool CheckArray2DEqual(const expected_T &expected, const actual_T &actual, size_t rows, size_t columns, std::string &msg)
Definition checks.h:1170
bool CheckEqual(const expected_T &expected, const actual_T &actual, std::string &msg)
Definition checks.h:552
bool Equal1D(const expected_T &expected, const actual_T &actual, size_t count)
Definition checks.h:945
bool isClose2D(const expected_T &expected, const actual_T &actual, size_t rows, size_t columns, double tolerance)
Definition checks.h:1212
bool CheckFileEqual(const std::string &ref, const std::string &actual, std::string &message)
Definition checks.h:1281
bool Equal2D(const expected_T &expected, const actual_T &actual, size_t rows, size_t columns)
Definition checks.h:1151
bool isClose(const expected_T &expected, const actual_T &actual, double tolerance)
Definition checks.h:895