BDE 4.14.0 Production release
|
#include <bsls_protocoltest.h>
Public Types | |
typedef BSLS_PROTOCOL | ProtocolType |
Public Member Functions | |
ProtocolTestImp () | |
Create an object of the ProtocolTestImp class. | |
~ProtocolTestImp () | |
BSLS_PROTOCOL * | operator-> () |
const BSLS_PROTOCOL * | operator-> () const |
ProtocolTest_MethodReturnType | markDone () const |
ProtocolTest_MethodReturnRefType | markDoneRef () const |
template<class T > | |
T | markDoneVal (const T &value) const |
void | markEnter () const |
void | setTestStatus (ProtocolTest_Status *testStatus) const |
This mechanism class template is a base class for a test implementation of a protocol class defined by the BSLS_PROTOCOL
template parameter. Its purpose is to reduce the boilerplate test code required to verify that derived virtual methods are called. It provides markDone
member functions one of which should be called from each method of the protocol class test implementation to indicate that the virtual method is correctly overridden. It also overloads operator->
to serve as a proxy to BSLS_PROTOCOL
and detect when BSLS_PROTOCOL
methods are called.
typedef BSLS_PROTOCOL bsls::ProtocolTestImp< BSLS_PROTOCOL >::ProtocolType |
|
inline |
|
inline |
Destroy this object and check the status of the test execution (success or failure). On test failure, report it to ProtocolTest_Status
.
|
inline |
Return a proxy object convertible to any value or pointer type. Derived classed should call this method from their implementations of protocol virtual methods to indicate that virtual methods were overridden correctly.
|
inline |
Return a proxy object convertible to any reference type. Derived classed should call this method from their implementations of protocol virtual methods to indicate that virtual methods were overridden correctly.
|
inline |
Return the specified value
. Derived classes should call this method from their implementations of protocol virtual methods to indicate that virtual methods were overridden correctly.
|
inline |
Mark this object as entered for the purpose of calling a protocol method. The entered
property is tested in the destructor to check for test failures (i.e., if entered == false
then the test cannot fail since it never ran). Note that markEnter
and markDone
calls have to be paired for a protocol-method-call test to succeed.
|
inline |
Dereference this object as if it were a pointer to BSLS_PROTOCOL
in order to call a method on BSLS_PROTOCOL
. Also mark this object as entered
for the purpose of calling a protocol method.
|
inline |
Dereference this object as if it were a const BSLS_PROTOCOL *s
in order to call a const
method on BSLS_PROTOCOL
. Also mark this object as entered
for the purpose of calling a protocol method.
|
inline |
Connect this protocol test object with the specified testStatus
object, which will be used for test failure reporting.