1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88
| #include <cppunit/Test.h>
#include <cppunit/tools/XmlDocument.h>
#include <cppunit/tools/XmlElement.h>
#include "ClockerModel.hpp"
#include "ClockerXmlHook.hpp"
ClockerXmlHook::ClockerXmlHook( ClockerModel *model )
: m_model( model )
{
}
ClockerXmlHook::~ClockerXmlHook()
{
}
void
ClockerXmlHook::endDocument( CPPUNIT_NS::XmlDocument *document )
{
CPPUNIT_NS::XmlElement *testTreeElement = new CPPUNIT_NS::XmlElement( "TimedTestTree" );
document->rootElement().addElement( testTreeElement );
addTimedTest( testTreeElement, 0 );
}
void
ClockerXmlHook::addTimedTest( CPPUNIT_NS::XmlElement *parentElement,
int testIndex )
{
std::string elementName = m_model->isSuite( testIndex ) ? "TimedSuite" : "TimedTest";
CPPUNIT_NS::XmlElement *testElement = new CPPUNIT_NS::XmlElement( elementName );
parentElement->addElement( testElement );
testElement->addAttribute( "id", testIndex );
const CPPUNIT_NS::TestPath &path = m_model->testPathFor( testIndex );
testElement->addElement( new CPPUNIT_NS::XmlElement( "Name",
path.getChildTest()->getName() ) );
testElement->addElement( new CPPUNIT_NS::XmlElement( "TestPath", path.toString() ) );
testElement->addElement( new CPPUNIT_NS::XmlElement( "Time",
ClockerModel::timeStringFor(
m_model->testTimeFor( testIndex ) ) ) );
if ( m_model->isSuite( testIndex ) )
{
for ( int childIndex =0; childIndex < m_model->childCountFor( testIndex ); ++childIndex )
addTimedTest( testElement, m_model->childAtFor( testIndex, childIndex ) );
}
}
void
ClockerXmlHook::failTestAdded( CPPUNIT_NS::XmlDocument *document,
CPPUNIT_NS::XmlElement *testElement,
CPPUNIT_NS::Test *test,
CPPUNIT_NS::TestFailure *failure )
{
successfulTestAdded( document, testElement, test );
}
void
ClockerXmlHook::successfulTestAdded( CPPUNIT_NS::XmlDocument *document,
CPPUNIT_NS::XmlElement *testElement,
CPPUNIT_NS::Test *test )
{
int testIndex = m_model->indexOf( test );
double time = (testIndex >= 0) ? m_model->testTimeFor( testIndex ) : 0.0;
const CPPUNIT_NS::TestPath &path = m_model->testPathFor( testIndex );
testElement->addElement( new CPPUNIT_NS::XmlElement( "TestPath", path.toString() ) );
testElement->addElement( new CPPUNIT_NS::XmlElement( "Time",
ClockerModel::timeStringFor( time ) ) );
}
void
ClockerXmlHook::statisticsAdded( CPPUNIT_NS::XmlDocument *document,
CPPUNIT_NS::XmlElement *statisticsElement )
{
statisticsElement->addElement(
new CPPUNIT_NS::XmlElement( "TotalElapsedTime",
ClockerModel::timeStringFor( m_model->totalElapsedTime() ) ) );
statisticsElement->addElement(
new CPPUNIT_NS::XmlElement( "AverageTestCaseTime",
ClockerModel::timeStringFor( m_model->averageTestCaseTime() ) ) );
} |
Partager