Simbody
3.3
|
This file defines a SimTK::Test class and some related macros which provide functionality useful in regression tests. More...
#include "SimTKcommon/basics.h"
#include "SimTKcommon/Simmatrix.h"
#include "SimTKcommon/internal/Random.h"
#include <cmath>
#include <ctime>
#include <algorithm>
#include <iostream>
Go to the source code of this file.
Classes | |
class | SimTK::Test |
This is the main class to support testing. More... | |
class | SimTK::Test::Subtest |
Internal utility class for generating test messages for subtests. More... | |
Namespaces | |
SimTK | |
This is the top-level SimTK namespace into which all SimTK names are placed to avoid collision with other symbols. | |
Macros | |
#define | SimTK_START_TEST(testName) |
Invoke this macro before anything else in your test's main(). More... | |
#define | SimTK_END_TEST() |
Invoke this macro as the last thing in your test's main(). More... | |
#define | SimTK_SUBTEST(testFunction) do {SimTK::Test::Subtest sub(#testFunction); (testFunction)();} while(false) |
Invoke a subtest in the form of a no-argument function, arranging for some friendly output and timing information. More... | |
#define | SimTK_SUBTEST1(testFunction, arg1) do {SimTK::Test::Subtest sub(#testFunction); (testFunction)(arg1);} while(false) |
Invoke a subtest in the form of a 1-argument function, arranging for some friendly output and timing information. More... | |
#define | SimTK_SUBTEST2(testFunction, arg1, arg2) do {SimTK::Test::Subtest sub(#testFunction); (testFunction)(arg1,arg2);} while(false) |
Invoke a subtest in the form of a 2-argument function, arranging for some friendly output and timing information. More... | |
#define | SimTK_SUBTEST3(testFunction, arg1, arg2, arg3) do {SimTK::Test::Subtest sub(#testFunction); (testFunction)(arg1,arg2,arg3);} while(false) |
Invoke a subtest in the form of a 3-argument function, arranging for some friendly output and timing information. More... | |
#define | SimTK_SUBTEST4(testFunction, arg1, arg2, arg3, arg4) do {SimTK::Test::Subtest sub(#testFunction); (testFunction)(arg1,arg2,arg3,arg4);} while(false) |
Invoke a subtest in the form of a 4-argument function, arranging for some friendly output and timing information. More... | |
#define | SimTK_TEST(cond) {SimTK_ASSERT_ALWAYS((cond), "Test condition failed.");} |
Test that some condition holds and complain if it doesn't. More... | |
#define | SimTK_TEST_FAILED(msg) {SimTK_ASSERT_ALWAYS(!"Test case failed.", msg);} |
Call this if you have determined that a test case has failed and just need to report it and die. More... | |
#define | SimTK_TEST_FAILED1(fmt, a1) {SimTK_ASSERT1_ALWAYS(!"Test case failed.",fmt,a1);} |
Call this if you have determined that a test case has failed and just need to report it and die. More... | |
#define | SimTK_TEST_FAILED2(fmt, a1, a2) {SimTK_ASSERT2_ALWAYS(!"Test case failed.",fmt,a1,a2);} |
Call this if you have determined that a test case has failed and just need to report it and die. More... | |
#define | SimTK_TEST_EQ(v1, v2) |
Test that two numerical values are equal to within a reasonable numerical error tolerance, using a relative and absolute error tolerance. More... | |
#define | SimTK_TEST_EQ_SIZE(v1, v2, n) |
Test that two numerical values are equal to within a specified multiple of the default error tolerance. More... | |
#define | SimTK_TEST_EQ_TOL(v1, v2, tol) |
Test that two numerical values are equal to within a specified numerical error tolerance, using a relative and absolute error tolerance. More... | |
#define | SimTK_TEST_NOTEQ(v1, v2) |
Test that two numerical values are NOT equal to within a reasonable numerical error tolerance, using a relative and absolute error tolerance. More... | |
#define | SimTK_TEST_NOTEQ_SIZE(v1, v2, n) |
Test that two numerical values are NOT equal to within a specified multiple of the default error tolerance, using a relative and absolute error tolerance. More... | |
#define | SimTK_TEST_NOTEQ_TOL(v1, v2, tol) |
Test that two numerical values are NOT equal to within a specified numerical error tolerance, using a relative and absolute error tolerance. More... | |
#define | SimTK_TEST_MUST_THROW(stmt) |
Test that the supplied statement throws an std::exception of some kind. More... | |
#define | SimTK_TEST_MUST_THROW_EXC(stmt, exc) |
Test that the supplied statement throws a particular exception. More... | |
#define | SimTK_TEST_MAY_THROW(stmt) |
Allow the supplied statement to throw any std::exception without failing. More... | |
#define | SimTK_TEST_MAY_THROW_EXC(stmt, exc) |
Allow the supplied statement to throw a particular exception without failing. More... | |
#define | SimTK_TEST_MUST_THROW_DEBUG(stmt) SimTK_TEST_MUST_THROW(stmt) |
Include a bad statement when in Debug and insist that it get caught, but don't include the statement at all in Release. More... | |
#define | SimTK_TEST_MUST_THROW_EXC_DEBUG(stmt, exc) SimTK_TEST_MUST_THROW_EXC(stmt,exc) |
Include a bad statement when in Debug and insist that it get caught, but don't include the statement at all in Release. More... | |
This file defines a SimTK::Test class and some related macros which provide functionality useful in regression tests.
#define SimTK_START_TEST | ( | testName | ) |
Invoke this macro before anything else in your test's main().
#define SimTK_END_TEST | ( | ) |
Invoke this macro as the last thing in your test's main().
#define SimTK_SUBTEST | ( | testFunction | ) | do {SimTK::Test::Subtest sub(#testFunction); (testFunction)();} while(false) |
Invoke a subtest in the form of a no-argument function, arranging for some friendly output and timing information.
#define SimTK_SUBTEST1 | ( | testFunction, | |
arg1 | |||
) | do {SimTK::Test::Subtest sub(#testFunction); (testFunction)(arg1);} while(false) |
Invoke a subtest in the form of a 1-argument function, arranging for some friendly output and timing information.
#define SimTK_SUBTEST2 | ( | testFunction, | |
arg1, | |||
arg2 | |||
) | do {SimTK::Test::Subtest sub(#testFunction); (testFunction)(arg1,arg2);} while(false) |
Invoke a subtest in the form of a 2-argument function, arranging for some friendly output and timing information.
#define SimTK_SUBTEST3 | ( | testFunction, | |
arg1, | |||
arg2, | |||
arg3 | |||
) | do {SimTK::Test::Subtest sub(#testFunction); (testFunction)(arg1,arg2,arg3);} while(false) |
Invoke a subtest in the form of a 3-argument function, arranging for some friendly output and timing information.
#define SimTK_SUBTEST4 | ( | testFunction, | |
arg1, | |||
arg2, | |||
arg3, | |||
arg4 | |||
) | do {SimTK::Test::Subtest sub(#testFunction); (testFunction)(arg1,arg2,arg3,arg4);} while(false) |
Invoke a subtest in the form of a 4-argument function, arranging for some friendly output and timing information.
#define SimTK_TEST | ( | cond | ) | {SimTK_ASSERT_ALWAYS((cond), "Test condition failed.");} |
Test that some condition holds and complain if it doesn't.
#define SimTK_TEST_FAILED | ( | msg | ) | {SimTK_ASSERT_ALWAYS(!"Test case failed.", msg);} |
Call this if you have determined that a test case has failed and just need to report it and die.
Pass the message as a string in quotes.
#define SimTK_TEST_FAILED1 | ( | fmt, | |
a1 | |||
) | {SimTK_ASSERT1_ALWAYS(!"Test case failed.",fmt,a1);} |
Call this if you have determined that a test case has failed and just need to report it and die.
The message is a printf format string in quotes; here with one argument expected.
#define SimTK_TEST_FAILED2 | ( | fmt, | |
a1, | |||
a2 | |||
) | {SimTK_ASSERT2_ALWAYS(!"Test case failed.",fmt,a1,a2);} |
Call this if you have determined that a test case has failed and just need to report it and die.
The message is a printf format string in quotes; here with two arguments expected.
#define SimTK_TEST_EQ | ( | v1, | |
v2 | |||
) |
Test that two numerical values are equal to within a reasonable numerical error tolerance, using a relative and absolute error tolerance.
In the case of composite types, the test is performed elementwise.
#define SimTK_TEST_EQ_SIZE | ( | v1, | |
v2, | |||
n | |||
) |
Test that two numerical values are equal to within a specified multiple of the default error tolerance.
#define SimTK_TEST_EQ_TOL | ( | v1, | |
v2, | |||
tol | |||
) |
Test that two numerical values are equal to within a specified numerical error tolerance, using a relative and absolute error tolerance.
In the case of composite types, the test is performed elementwise.
#define SimTK_TEST_NOTEQ | ( | v1, | |
v2 | |||
) |
Test that two numerical values are NOT equal to within a reasonable numerical error tolerance, using a relative and absolute error tolerance.
In the case of composite types, the equality test is performed elementwise.
#define SimTK_TEST_NOTEQ_SIZE | ( | v1, | |
v2, | |||
n | |||
) |
Test that two numerical values are NOT equal to within a specified multiple of the default error tolerance, using a relative and absolute error tolerance.
In the case of composite types, the equality test is performed elementwise.
#define SimTK_TEST_NOTEQ_TOL | ( | v1, | |
v2, | |||
tol | |||
) |
Test that two numerical values are NOT equal to within a specified numerical error tolerance, using a relative and absolute error tolerance.
In the case of composite types, the equality test is performed elementwise.
#define SimTK_TEST_MUST_THROW | ( | stmt | ) |
Test that the supplied statement throws an std::exception of some kind.
#define SimTK_TEST_MUST_THROW_EXC | ( | stmt, | |
exc | |||
) |
Test that the supplied statement throws a particular exception.
#define SimTK_TEST_MAY_THROW | ( | stmt | ) |
Allow the supplied statement to throw any std::exception without failing.
#define SimTK_TEST_MAY_THROW_EXC | ( | stmt, | |
exc | |||
) |
Allow the supplied statement to throw a particular exception without failing.
#define SimTK_TEST_MUST_THROW_DEBUG | ( | stmt | ) | SimTK_TEST_MUST_THROW(stmt) |
Include a bad statement when in Debug and insist that it get caught, but don't include the statement at all in Release.
#define SimTK_TEST_MUST_THROW_EXC_DEBUG | ( | stmt, | |
exc | |||
) | SimTK_TEST_MUST_THROW_EXC(stmt,exc) |
Include a bad statement when in Debug and insist that it get caught, but don't include the statement at all in Release.