200 lines
14 KiB
C++
200 lines
14 KiB
C++
#ifndef CPPUNIT_PLUGIN_TESTPLUGIN
|
||
#define CPPUNIT_PLUGIN_TESTPLUGIN
|
||
|
||
#include <cppunit/Portability.h>
|
||
|
||
#if !defined(CPPUNIT_NO_TESTPLUGIN)
|
||
|
||
#include <cppunit/plugin/PlugInParameters.h>
|
||
|
||
CPPUNIT_NS_BEGIN
|
||
|
||
|
||
class Test;
|
||
class TestFactoryRegistry;
|
||
class TestResult;
|
||
class XmlOutputter;
|
||
|
||
CPPUNIT_NS_END
|
||
|
||
/*! \file
|
||
*/
|
||
|
||
|
||
/*! \brief Test plug-in interface.
|
||
* \ingroup WritingTestPlugIn
|
||
*
|
||
* This class define the interface implemented by test plug-in. A pointer to that
|
||
* interface is returned by the function exported by the test plug-in.
|
||
*
|
||
* Plug-in are loaded/unloaded by PlugInManager. When a plug-in is loaded,
|
||
* initialize() is called. Before unloading the plug-in, the PlugInManager
|
||
* call uninitialize().
|
||
*
|
||
* addListener() and removeListener() are called respectively before and after
|
||
* the test run.
|
||
*
|
||
* addXmlOutputterHooks() and removeXmlOutputterHooks() are called respectively
|
||
* before and after writing the XML output using a XmlOutputter.
|
||
*
|
||
* \see CPPUNIT_PLUGIN_IMPLEMENT, CPPUNIT_PLUGIN_EXPORTED_FUNCTION_IMPL
|
||
* \see CppUnit::TestPlugInDefaultImpl, CppUnit::XmlOutputter.
|
||
*/
|
||
struct CppUnitTestPlugIn
|
||
{
|
||
/*! \brief Called just after loading the dynamic library.
|
||
*
|
||
* Override this method to add additional suite to the registry, though this
|
||
* is preferably done using the macros (CPPUNIT_TEST_SUITE_REGISTRATION...).
|
||
* If you are creating a custom listener to extends the plug-in runner,
|
||
* you can use this to configure the listener using the \a parameters.
|
||
*
|
||
* You could also use the parameters to specify some global parameter, such
|
||
* as test datas location, database name...
|
||
*
|
||
* N.B.: Parameters interface is not define yet, and the plug-in runner does
|
||
* not yet support plug-in parameter.
|
||
*/
|
||
virtual void initialize( CPPUNIT_NS::TestFactoryRegistry *registry,
|
||
const CPPUNIT_NS::PlugInParameters ¶meters ) =0;
|
||
|
||
/*! \brief Gives a chance to the plug-in to register TestListener.
|
||
*
|
||
* Override this method to add a TestListener for the test run. This is useful
|
||
* if you are writing a custom TestListener, but also if you need to
|
||
* setUp some global resource: listen to TestListener::startTestRun(),
|
||
* and TestListener::endTestRun().
|
||
*/
|
||
virtual void addListener( CPPUNIT_NS::TestResult *eventManager ) =0;
|
||
|
||
/*! \brief Gives a chance to the plug-in to remove its registered TestListener.
|
||
*
|
||
* Override this method to remove a TestListener that has been added.
|
||
*/
|
||
virtual void removeListener( CPPUNIT_NS::TestResult *eventManager ) =0;
|
||
|
||
/*! \brief Provides a way for the plug-in to register some XmlOutputterHook.
|
||
*/
|
||
virtual void addXmlOutputterHooks( CPPUNIT_NS::XmlOutputter *outputter ) =0;
|
||
|
||
/*! \brief Called when the XmlOutputter is destroyed.
|
||
*
|
||
* Can be used to free some resources allocated by addXmlOutputterHooks().
|
||
*/
|
||
virtual void removeXmlOutputterHooks() = 0;
|
||
|
||
/*! \brief Called just before unloading the dynamic library.
|
||
*
|
||
* Override this method to unregister test factory added in initialize().
|
||
* This is necessary to keep the TestFactoryRegistry 'clean'. When
|
||
* the plug-in is unloaded from memory, the TestFactoryRegistry will hold
|
||
* reference on test that are no longer available if they are not
|
||
* unregistered.
|
||
*/
|
||
virtual void uninitialize( CPPUNIT_NS::TestFactoryRegistry *registry ) =0;
|
||
|
||
virtual ~CppUnitTestPlugIn() {}
|
||
};
|
||
|
||
|
||
|
||
/*! \brief Name of the function exported by a test plug-in.
|
||
* \ingroup WritingTestPlugIn
|
||
*
|
||
* The signature of the exported function is:
|
||
* \code
|
||
* CppUnitTestPlugIn *CPPUNIT_PLUGIN_EXPORTED_NAME(void);
|
||
* \endcode
|
||
*/
|
||
#define CPPUNIT_PLUGIN_EXPORTED_NAME cppunitTestPlugIn
|
||
|
||
/*! \brief Type of the function exported by a plug-in.
|
||
* \ingroup WritingTestPlugIn
|
||
*/
|
||
typedef CppUnitTestPlugIn *(*TestPlugInSignature)();
|
||
|
||
|
||
/*! \brief Implements the function exported by the test plug-in
|
||
* \ingroup WritingTestPlugIn
|
||
*/
|
||
#define CPPUNIT_PLUGIN_EXPORTED_FUNCTION_IMPL( TestPlugInInterfaceType ) \
|
||
CPPUNIT_PLUGIN_EXPORT CppUnitTestPlugIn *CPPUNIT_PLUGIN_EXPORTED_NAME(void) \
|
||
{ \
|
||
static TestPlugInInterfaceType plugIn; \
|
||
return &plugIn; \
|
||
} \
|
||
typedef char __CppUnitPlugInExportFunctionDummyTypeDef // dummy typedef so it can end with ';'
|
||
|
||
|
||
// Note: This include should remain after definition of CppUnitTestPlugIn
|
||
#include <cppunit/plugin/TestPlugInDefaultImpl.h>
|
||
|
||
|
||
/*! \def CPPUNIT_PLUGIN_IMPLEMENT_MAIN()
|
||
* \brief Implements the 'main' function for the plug-in.
|
||
*
|
||
* This macros implements the main() function for dynamic library.
|
||
* For example, WIN32 requires a DllMain function, while some Unix
|
||
* requires a main() function. This macros takes care of the implementation.
|
||
*/
|
||
|
||
// Win32
|
||
#if defined(CPPUNIT_HAVE_WIN32_DLL_LOADER)
|
||
#if !defined(APIENTRY)
|
||
#define WIN32_LEAN_AND_MEAN
|
||
#define NOGDI
|
||
#define NOUSER
|
||
#define NOKERNEL
|
||
#define NOSOUND
|
||
#define NOMINMAX
|
||
#define BLENDFUNCTION void // for mingw & gcc
|
||
#include <windows.h>
|
||
#endif
|
||
#define CPPUNIT_PLUGIN_IMPLEMENT_MAIN() \
|
||
BOOL APIENTRY DllMain( HANDLE hModule, \
|
||
DWORD ul_reason_for_call, \
|
||
LPVOID lpReserved ) \
|
||
{ \
|
||
return TRUE; \
|
||
} \
|
||
typedef char __CppUnitPlugInImplementMainDummyTypeDef
|
||
|
||
// Unix
|
||
#elif defined(CPPUNIT_HAVE_UNIX_DLL_LOADER) || defined(CPPUNIT_HAVE_UNIX_SHL_LOADER)
|
||
#define CPPUNIT_PLUGIN_IMPLEMENT_MAIN() \
|
||
int main( int argc, char *argv[] ) \
|
||
{ \
|
||
return 0; \
|
||
} \
|
||
typedef char __CppUnitPlugInImplementMainDummyTypeDef
|
||
|
||
|
||
// Other
|
||
#else // other platforms don't require anything specifics
|
||
#endif
|
||
|
||
|
||
|
||
/*! \brief Implements and exports the test plug-in interface.
|
||
* \ingroup WritingTestPlugIn
|
||
*
|
||
* This macro exports the test plug-in function using the subclass,
|
||
* and implements the 'main' function for the plug-in using
|
||
* CPPUNIT_PLUGIN_IMPLEMENT_MAIN().
|
||
*
|
||
* When using this macro, CppUnit must be linked as a DLL (shared library).
|
||
* Otherwise, tests registered to the TestFactoryRegistry in the DLL will
|
||
* not be visible to the DllPlugInTester.
|
||
*
|
||
* \see CppUnitTestPlugIn
|
||
* \see CPPUNIT_PLUGIN_EXPORTED_FUNCTION_IMPL(), CPPUNIT_PLUGIN_IMPLEMENT_MAIN().
|
||
*/
|
||
#define CPPUNIT_PLUGIN_IMPLEMENT() \
|
||
CPPUNIT_PLUGIN_EXPORTED_FUNCTION_IMPL( CPPUNIT_NS::TestPlugInDefaultImpl ); \
|
||
CPPUNIT_PLUGIN_IMPLEMENT_MAIN()
|
||
|
||
|
||
#endif // !defined(CPPUNIT_NO_TESTPLUGIN)
|
||
|
||
|
||
#endif // CPPUNIT_PLUGIN_TESTPLUGIN
|