|
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 |
}
|