Blame examples/ClockerPlugIn/ClockerXmlHook.cpp

Packit Service e31359
// //////////////////////////////////////////////////////////////////////////
Packit Service e31359
// Implementation file ClockerXmlHook.cpp for class ClockerXmlHook
Packit Service e31359
// (c)Copyright 2000, Baptiste Lepilleur.
Packit Service e31359
// Created: 2002/06/14
Packit Service e31359
// //////////////////////////////////////////////////////////////////////////
Packit Service e31359
Packit Service e31359
#include <cppunit/Test.h>
Packit Service e31359
#include <cppunit/tools/XmlDocument.h>
Packit Service e31359
#include <cppunit/tools/XmlElement.h>
Packit Service e31359
#include "ClockerModel.h"
Packit Service e31359
#include "ClockerXmlHook.h"
Packit Service e31359
Packit Service e31359
Packit Service e31359
ClockerXmlHook::ClockerXmlHook( ClockerModel *model )
Packit Service e31359
    : m_model( model )
Packit Service e31359
{
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
ClockerXmlHook::~ClockerXmlHook()
Packit Service e31359
{
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
void 
Packit Service e31359
ClockerXmlHook::endDocument( CPPUNIT_NS::XmlDocument *document )
Packit Service e31359
{
Packit Service e31359
  CPPUNIT_NS::XmlElement *testTreeElement = new CPPUNIT_NS::XmlElement( "TimedTestTree" );
Packit Service e31359
  document->rootElement().addElement( testTreeElement );
Packit Service e31359
Packit Service e31359
  addTimedTest( testTreeElement, 0 );
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
void 
Packit Service e31359
ClockerXmlHook::addTimedTest( CPPUNIT_NS::XmlElement *parentElement, 
Packit Service e31359
                              int testIndex )
Packit Service e31359
{
Packit Service e31359
  std::string elementName = m_model->isSuite( testIndex ) ? "TimedSuite" : "TimedTest";
Packit Service e31359
  CPPUNIT_NS::XmlElement *testElement = new CPPUNIT_NS::XmlElement( elementName );
Packit Service e31359
  parentElement->addElement( testElement );
Packit Service e31359
  testElement->addAttribute( "id", testIndex );
Packit Service e31359
Packit Service e31359
  const CPPUNIT_NS::TestPath &path = m_model->testPathFor( testIndex );
Packit Service e31359
  testElement->addElement( new CPPUNIT_NS::XmlElement( "Name", 
Packit Service e31359
                                                    path.getChildTest()->getName() ) );
Packit Service e31359
  testElement->addElement( new CPPUNIT_NS::XmlElement( "TestPath", path.toString() ) );
Packit Service e31359
  testElement->addElement( new CPPUNIT_NS::XmlElement( "Time", 
Packit Service e31359
                                 ClockerModel::timeStringFor( 
Packit Service e31359
                                    m_model->testTimeFor( testIndex ) ) ) );
Packit Service e31359
Packit Service e31359
  if ( m_model->isSuite( testIndex ) )
Packit Service e31359
  {
Packit Service e31359
    for ( int childIndex =0; childIndex < m_model->childCountFor( testIndex ); ++childIndex )
Packit Service e31359
      addTimedTest( testElement, m_model->childAtFor( testIndex, childIndex ) );
Packit Service e31359
  }
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
void 
Packit Service e31359
ClockerXmlHook::failTestAdded( CPPUNIT_NS::XmlDocument *document,
Packit Service e31359
                               CPPUNIT_NS::XmlElement *testElement,
Packit Service e31359
                               CPPUNIT_NS::Test *test,
Packit Service e31359
                               CPPUNIT_NS::TestFailure *failure )
Packit Service e31359
{
Packit Service e31359
  successfulTestAdded( document, testElement, test );
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
void 
Packit Service e31359
ClockerXmlHook::successfulTestAdded( CPPUNIT_NS::XmlDocument *document,
Packit Service e31359
                                     CPPUNIT_NS::XmlElement *testElement,
Packit Service e31359
                                     CPPUNIT_NS::Test *test )
Packit Service e31359
{
Packit Service e31359
  int testIndex = m_model->indexOf( test );
Packit Service e31359
  double time = (testIndex >= 0) ? m_model->testTimeFor( testIndex ) : 0.0;
Packit Service e31359
  const CPPUNIT_NS::TestPath &path = m_model->testPathFor( testIndex );
Packit Service e31359
  testElement->addElement( new CPPUNIT_NS::XmlElement( "TestPath", path.toString() ) );
Packit Service e31359
  testElement->addElement( new CPPUNIT_NS::XmlElement( "Time",
Packit Service e31359
                                   ClockerModel::timeStringFor( time ) ) );
Packit Service e31359
}
Packit Service e31359
Packit Service e31359
Packit Service e31359
void 
Packit Service e31359
ClockerXmlHook::statisticsAdded( CPPUNIT_NS::XmlDocument *document,
Packit Service e31359
                                 CPPUNIT_NS::XmlElement *statisticsElement )
Packit Service e31359
{
Packit Service e31359
  statisticsElement->addElement( 
Packit Service e31359
      new CPPUNIT_NS::XmlElement( "TotalElapsedTime",
Packit Service e31359
           ClockerModel::timeStringFor( m_model->totalElapsedTime() ) ) );
Packit Service e31359
  statisticsElement->addElement( 
Packit Service e31359
      new CPPUNIT_NS::XmlElement( "AverageTestCaseTime",
Packit Service e31359
           ClockerModel::timeStringFor( m_model->averageTestCaseTime() ) ) );
Packit Service e31359
}