CppUnitLite
Test.h
Go to the documentation of this file.
1
/* ----------------------------------------------------------------------------
2
3
* GTSAM Copyright 2010, Georgia Tech Research Corporation,
4
* Atlanta, Georgia 30332-0415
5
* All Rights Reserved
6
* Authors: Frank Dellaert, et al. (see THANKS for the full author list)
7
8
* See LICENSE for the license information
9
10
* -------------------------------------------------------------------------- */
11
13
//
14
// TEST.H
15
//
16
// This file contains the Test class along with the macros which make effective
17
// in the harness.
18
//
20
21
#ifndef TEST_H
22
#define TEST_H
23
24
25
#include <cmath>
26
#include <string>
27
28
class
TestResult
;
29
30
class
Test
31
{
32
public
:
33
Test
(
const
std::string& testName);
34
Test
(
const
std::string& testName,
const
std::string&
filename
,
long
lineNumber,
bool
safeCheck);
35
virtual
~Test
() {}
36
37
virtual
void
run
(
TestResult
&
result
) = 0;
38
39
40
void
setNext
(
Test
*
test
);
41
Test
*
getNext
()
const
;
42
std::string
getName
()
const
{
return
name_
;}
43
std::string
getFilename
()
const
{
return
filename_
;}
44
long
getLineNumber
()
const
{
return
lineNumber_
;}
45
bool
safe
()
const
{
return
safeCheck_
;}
46
47
protected
:
48
49
bool
check
(
long
expected
,
long
actual,
TestResult
&
result
,
const
std::string& fileName,
long
lineNumber);
50
bool
check
(
const
std::string&
expected
,
const
std::string& actual,
TestResult
&
result
,
const
std::string& fileName,
long
lineNumber);
51
52
std::string
name_
;
53
Test
*
next_
;
54
std::string
filename_
;
55
long
lineNumber_
;
56
bool
safeCheck_
;
57
58
};
59
63
#define TEST(testGroup, testName)\
64
class testGroup##testName##Test : public Test \
65
{ public: testGroup##testName##Test () : Test (#testName "Test", __FILE__, __LINE__, true) {} \
66
void run (TestResult& result_) override;} \
67
testGroup##testName##Instance; \
68
void testGroup##testName##Test::run (TestResult& result_)
69
73
#define FRIEND_TEST(testGroup, testName) \
74
friend class testGroup##testName##Test;
75
80
#define TEST_UNSAFE(testGroup, testName)\
81
class testGroup##testName##Test : public Test \
82
{ public: testGroup##testName##Test () : Test (#testName "Test", __FILE__, __LINE__, false) {} \
83
virtual ~testGroup##testName##Test () {} \
84
void run (TestResult& result_) override;} \
85
testGroup##testName##Instance; \
86
void testGroup##testName##Test::run (TestResult& result_)
87
91
#define TEST_DISABLED(testGroup, testName)\
92
void testGroup##testName##Test(TestResult& result_, const std::string& name_)
93
94
/*
95
* Convention for tests:
96
* - "EXPECT" is a test that will not end execution of the series of tests
97
* - Otherwise, upon a failure, the test will end
98
*
99
* Usage:
100
* EXPECT is useful when checking several different parts of an condition so
101
* that a failure of one check won't hide another failure.
102
*
103
* Note: Exception tests are not available in a EXPECT form, as exceptions rarely
104
* fit the criteria of an assertion that does not need to be true to continue
105
*/
106
107
/* True ASSERTs: tests end at first failure */
108
#define CHECK(condition)\
109
{ if (!(condition)) \
110
{ result_.addFailure (Failure (name_, __FILE__,__LINE__, #condition)); return; } }
111
112
#define THROWS_EXCEPTION(condition)\
113
{ try { condition; \
114
result_.addFailure (Failure (name_, __FILE__,__LINE__, std::string("Didn't throw: ") + std::string(#condition))); \
115
return; } \
116
catch (...) {} }
117
118
#define CHECK_EXCEPTION(condition, exception_name)\
119
{ try { condition; \
120
result_.addFailure (Failure (name_, __FILE__,__LINE__, std::string("Didn't throw: ") + std::string(#condition))); \
121
return; } \
122
catch (exception_name&) {} \
123
catch (...) { \
124
result_.addFailure (Failure (name_, __FILE__,__LINE__, std::string("Wrong exception: ") + std::string(#condition) + std::string(", expected: ") + std::string(#exception_name))); \
125
return; } }
126
127
#define EQUALITY(expected,actual)\
128
{ if (!assert_equal(expected,actual)) \
129
result_.addFailure(Failure(name_, __FILE__, __LINE__, #expected, #actual)); }
130
131
#define CHECK_EQUAL(expected,actual)\
132
{ if (!((expected) == (actual))) { result_.addFailure(Failure(name_, __FILE__, __LINE__, std::to_string(expected), std::to_string(actual))); return; } }
133
134
#define LONGS_EQUAL(expected,actual)\
135
{ long actualTemp = actual; \
136
long expectedTemp = expected; \
137
if ((expectedTemp) != (actualTemp)) \
138
{ result_.addFailure (Failure (name_, __FILE__, __LINE__, std::to_string(expectedTemp), \
139
std::to_string(actualTemp))); return; } }
140
141
#define DOUBLES_EQUAL(expected,actual,threshold)\
142
{ double actualTemp = actual; \
143
double expectedTemp = expected; \
144
if (!std::isfinite(actualTemp) || !std::isfinite(expectedTemp) || fabs ((expectedTemp)-(actualTemp)) > threshold) \
145
{ result_.addFailure (Failure (name_, __FILE__, __LINE__, \
146
std::to_string((double)expectedTemp), std::to_string((double)actualTemp))); return; } }
147
148
149
/* EXPECTs: tests will continue running after a failure */
150
#define EXPECT(condition)\
151
{ if (!(condition)) \
152
{ result_.addFailure (Failure (name_, __FILE__,__LINE__, #condition)); } }
153
154
#define EXPECT_LONGS_EQUAL(expected,actual)\
155
{ long actualTemp = actual; \
156
long expectedTemp = expected; \
157
if ((expectedTemp) != (actualTemp)) \
158
{ result_.addFailure (Failure (name_, __FILE__, __LINE__, std::to_string(expectedTemp), \
159
std::to_string(actualTemp))); } }
160
161
#define EXPECT_DOUBLES_EQUAL(expected,actual,threshold)\
162
{ double actualTemp = actual; \
163
double expectedTemp = expected; \
164
if (!std::isfinite(actualTemp) || !std::isfinite(expectedTemp) || fabs ((expectedTemp)-(actualTemp)) > threshold) \
165
{ result_.addFailure (Failure (name_, __FILE__, __LINE__, \
166
std::to_string((double)expectedTemp), std::to_string((double)actualTemp))); } }
167
168
169
#define FAIL(text) \
170
{ result_.addFailure (Failure (name_, __FILE__, __LINE__,(text))); return; }
171
172
173
174
#endif
Test::safeCheck_
bool safeCheck_
This is the line line number of the test, rather than the a single check.
Definition:
Test.h:56
Test::check
bool check(long expected, long actual, TestResult &result, const std::string &fileName, long lineNumber)
Definition:
Test.cpp:41
Test::getName
std::string getName() const
Definition:
Test.h:42
Test::getFilename
std::string getFilename() const
Definition:
Test.h:43
result
Values result
Definition:
OdometryOptimize.cpp:8
Test::name_
std::string name_
Definition:
Test.h:52
test
Definition:
test.py:1
Test::~Test
virtual ~Test()
Definition:
Test.h:35
Test::safe
bool safe() const
Definition:
Test.h:45
Test::next_
Test * next_
Definition:
Test.h:53
relicense.filename
filename
Definition:
relicense.py:57
cholesky::expected
Matrix expected
Definition:
testMatrix.cpp:971
Test::getNext
Test * getNext() const
Definition:
Test.cpp:31
Test::setNext
void setNext(Test *test)
Definition:
Test.cpp:36
TestResult
Definition:
TestResult.h:26
Test::getLineNumber
long getLineNumber() const
Definition:
Test.h:44
Test::filename_
std::string filename_
Definition:
Test.h:54
Test
Definition:
Test.h:30
Test::lineNumber_
long lineNumber_
Definition:
Test.h:55
Test::Test
Test(const std::string &testName)
Definition:
Test.cpp:18
Test::run
virtual void run(TestResult &result)=0
gtsam
Author(s):
autogenerated on Tue Jan 7 2025 04:06:53