root/headers/tools/cppunit/cppunit/TestSuite.h
#ifndef CPPUNIT_TESTSUITE_H    // -*- C++ -*-
#define CPPUNIT_TESTSUITE_H

#include <cppunit/Portability.h>

#if CPPUNIT_NEED_DLL_DECL
#pragma warning( push )
#pragma warning( disable: 4251 )  // X needs to have dll-interface to be used by clients of class Z
#endif

#include <cppunit/Test.h>
#include <vector>
#include <string>

using std::string;
using std::vector;

namespace CppUnit {

class TestResult;

#if CPPUNIT_NEED_DLL_DECL
  template class CPPUNIT_API vector<Test *>;
#endif


/*! \brief A Composite of Tests.
 * \ingroup CreatingTestSuite
 *
 * It runs a collection of test cases. Here is an example.
 * \code
 * CppUnit::TestSuite *suite= new CppUnit::TestSuite();
 * suite->addTest(new CppUnit::TestCaller<MathTest> (
 *                  "testAdd", testAdd));
 * suite->addTest(new CppUnit::TestCaller<MathTest> (
 *                  "testDivideByZero", testDivideByZero));
 * \endcode
 * Note that TestSuites assume lifetime
 * control for any tests added to them.
 *
 * TestSuites do not register themselves in the TestRegistry.
 * \see Test
 * \see TestCaller
 */


class CPPUNIT_API TestSuite : public Test
{
public:
  TestSuite( string name = "" );
  ~TestSuite();

  void run( TestResult *result );
  int countTestCases() const;
  string getName() const;
  string toString() const;

  void addTest( Test *test );
  const vector<Test *> &getTests() const;

  virtual void deleteContents();

private:
  TestSuite( const TestSuite &other );
  TestSuite &operator =( const TestSuite &other );

private:
  vector<Test *> m_tests;
  const string m_name;
};


} // namespace CppUnit


#if CPPUNIT_NEED_DLL_DECL
#pragma warning( pop )
#endif

#endif // CPPUNIT_TESTSUITE_H