#include "qtestxmlstreamer.h" #include "qtestelement.h" #include "qtestelementattribute.h" #include "QtTest/private/qtestlog_p.h" #include "QtTest/private/qtestresult_p.h" #include "QtTest/private/qxmltestlogger_p.h" #include #include QT_BEGIN_NAMESPACE QTestXmlStreamer::QTestXmlStreamer() :QTestBasicStreamer() { } QTestXmlStreamer::~QTestXmlStreamer() {} void QTestXmlStreamer::formatStart(const QTestElement *element, char *formatted) const { if(!element || !formatted) return; switch(element->elementType()){ case QTest::LET_TestCase: { char quotedTf[950]; QXmlTestLogger::xmlQuote(quotedTf, element->attributeValue(QTest::AI_Name), sizeof(quotedTf)); QTest::qt_snprintf(formatted, 1024, "\n", quotedTf); break; } case QTest::LET_Failure: { char cdataDesc[800]; QXmlTestLogger::xmlCdata(cdataDesc, element->attributeValue(QTest::AI_Description), sizeof(cdataDesc)); char location[100]; char quotedFile[70]; QXmlTestLogger::xmlQuote(quotedFile, element->attributeValue(QTest::AI_File), sizeof(quotedFile)); QTest::qt_snprintf(location, sizeof(location), "%s=\"%s\" %s=\"%s\"", element->attributeName(QTest::AI_File), quotedFile, element->attributeName(QTest::AI_Line), element->attributeValue(QTest::AI_Line)); if (element->attribute(QTest::AI_Tag)) { char cdataTag[100]; QXmlTestLogger::xmlCdata(cdataTag, element->attributeValue(QTest::AI_Tag), sizeof(cdataTag)); QTest::qt_snprintf(formatted, 1024, "\n" " \n" " \n" "\n", element->attributeValue(QTest::AI_Result), location, cdataTag, cdataDesc); } else { QTest::qt_snprintf(formatted, 1024, "\n" " \n" "\n", element->attributeValue(QTest::AI_Result), location, cdataDesc); } break; } case QTest::LET_Error: { // assuming type and attribute names don't need quoting char quotedFile[128]; char cdataDesc[700]; QXmlTestLogger::xmlQuote(quotedFile, element->attributeValue(QTest::AI_File), sizeof(quotedFile)); QXmlTestLogger::xmlCdata(cdataDesc, element->attributeValue(QTest::AI_Description), sizeof(cdataDesc)); QTest::qt_snprintf(formatted, 1024, "\n \n\n", element->attributeValue(QTest::AI_Type), element->attributeName(QTest::AI_File), quotedFile, element->attributeName(QTest::AI_Line), element->attributeValue(QTest::AI_Line), cdataDesc); break; } case QTest::LET_Benchmark: { // assuming value and iterations don't need quoting char quotedMetric[256]; char quotedTag[256]; QXmlTestLogger::xmlQuote(quotedMetric, element->attributeValue(QTest::AI_Metric), sizeof(quotedMetric)); QXmlTestLogger::xmlQuote(quotedTag, element->attributeValue(QTest::AI_Tag), sizeof(quotedTag)); QTest::qt_snprintf(formatted, 1024, "\n", element->attributeName(QTest::AI_Metric), quotedMetric, element->attributeName(QTest::AI_Tag), quotedTag, element->attributeName(QTest::AI_Value), element->attributeValue(QTest::AI_Value), element->attributeName(QTest::AI_Iterations), element->attributeValue(QTest::AI_Iterations) ); break; } default: QTest::qt_snprintf(formatted, 10, ""); } } void QTestXmlStreamer::formatEnd(const QTestElement *element, char *formatted) const { if(!element || !formatted) return; if (element->elementType() == QTest::LET_TestCase) { QTest::qt_snprintf(formatted, 1024, "\n"); } else QTest::qt_snprintf(formatted, 10, ""); } void QTestXmlStreamer::formatBeforeAttributes(const QTestElement *element, char *formatted) const { if(!element || !formatted) return; if (element->elementType() == QTest::LET_TestCase && element->attribute(QTest::AI_Result)){ char buf[900]; char quotedFile[700]; QXmlTestLogger::xmlQuote(quotedFile, element->attributeValue(QTest::AI_File), sizeof(quotedFile)); QTest::qt_snprintf(buf, sizeof(buf), "%s=\"%s\" %s=\"%s\"", element->attributeName(QTest::AI_File), quotedFile, element->attributeName(QTest::AI_Line), element->attributeValue(QTest::AI_Line)); if( !element->childElements() ) { QTest::qt_snprintf(formatted, 1024, "\n", element->attributeValue(QTest::AI_Result), buf); } else { QTest::qt_snprintf(formatted, 10, ""); } }else{ QTest::qt_snprintf(formatted, 10, ""); } } void QTestXmlStreamer::output(QTestElement *element) const { char buf[1024]; char quotedTc[800]; QXmlTestLogger::xmlQuote(quotedTc, QTestResult::currentTestObjectName(), sizeof(quotedTc)); QTest::qt_snprintf(buf, sizeof(buf), "\n\n", quotedTc); outputString(buf); QTest::qt_snprintf(buf, sizeof(buf), "\n %s\n %s\n", qVersion(), QTEST_VERSION_STR ); outputString(buf); QTest::qt_snprintf(buf, sizeof(buf), "\n"); outputString(buf); QTestBasicStreamer::output(element); QTest::qt_snprintf(buf, sizeof(buf), "\n"); outputString(buf); } QT_END_NAMESPACE