BDE 4.14.0 Production release
|
Typedefs | |
typedef bsls::AssertTestException | bsls_AssertTestException |
This alias is defined for backward compatibility. | |
Provide an exception type to support testing for failed assertions.
This component implements an exception class, bsls::AssertTestException
, that provides a mechanism to convey context information from a failing assertion to a test handler. The context that is captured consists of the program source of the failing expression, the name of the file containing the assertion, the line number within that file where the asserted expression may be found, and the level of the assertion that has failed.
Note that this class is intended as an implementation detail of the bsls
testing framework (see bsls_asserttest ), though it may be used in other contexts.
First we write a macro to act as an assert
facility that will throw an exception of type bsls::AssertTestException
if the asserted expression fails. The thrown exception will capture the source code, filename, and line number of the failing expression:
Next we use the macro inside a try
-block, so that we can catch the exception thrown if the tested expression fails:
If the assertion fails, catch the exception and confirm that it correctly recorded the context of where the assertion failed: