/**************************************************************************** ** ** Copyright (C) 2014 Digia Plc and/or its subsidiary(-ies). ** Contact: http://www.qt-project.org/legal ** ** This file is part of the QtTest module of the Qt Toolkit. ** ** $QT_BEGIN_LICENSE:LGPL$ ** Commercial License Usage ** Licensees holding valid commercial Qt licenses may use this file in ** accordance with the commercial license agreement provided with the ** Software or, alternatively, in accordance with the terms contained in ** a written agreement between you and Digia. For licensing terms and ** conditions see http://qt.digia.com/licensing. For further information ** use the contact form at http://qt.digia.com/contact-us. ** ** GNU Lesser General Public License Usage ** Alternatively, this file may be used under the terms of the GNU Lesser ** General Public License version 2.1 as published by the Free Software ** Foundation and appearing in the file LICENSE.LGPL included in the ** packaging of this file. Please review the following information to ** ensure the GNU Lesser General Public License version 2.1 requirements ** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html. ** ** In addition, as a special exception, Digia gives you certain additional ** rights. These rights are described in the Digia Qt LGPL Exception ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package. ** ** GNU General Public License Usage ** Alternatively, this file may be used under the terms of the GNU ** General Public License version 3.0 as published by the Free Software ** Foundation and appearing in the file LICENSE.GPL included in the ** packaging of this file. Please review the following information to ** ensure the GNU General Public License version 3.0 requirements will be ** met: http://www.gnu.org/copyleft/gpl.html. ** ** ** $QT_END_LICENSE$ ** ****************************************************************************/ #include "qtestxmlstreamer.h" #include "qtestelement.h" #include "qtestelementattribute.h" #include "qtestlogger_p.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, QTestCharBuffer *formatted) const { if(!element || !formatted) return; switch(element->elementType()){ case QTest::LET_TestCase: { QTestCharBuffer quotedTf; QXmlTestLogger::xmlQuote("edTf, element->attributeValue(QTest::AI_Name)); QTest::qt_asprintf(formatted, "\n", quotedTf.constData()); break; } case QTest::LET_Failure: { QTestCharBuffer cdataDesc; QXmlTestLogger::xmlCdata(&cdataDesc, element->attributeValue(QTest::AI_Description)); QTestCharBuffer location; QTestCharBuffer quotedFile; QXmlTestLogger::xmlQuote("edFile, element->attributeValue(QTest::AI_File)); QTest::qt_asprintf(&location, "%s=\"%s\" %s=\"%s\"", element->attributeName(QTest::AI_File), quotedFile.constData(), element->attributeName(QTest::AI_Line), element->attributeValue(QTest::AI_Line)); if (element->attribute(QTest::AI_Tag)) { QTestCharBuffer cdataTag; QXmlTestLogger::xmlCdata(&cdataTag, element->attributeValue(QTest::AI_Tag)); QTest::qt_asprintf(formatted, "\n" " \n" " \n" "\n", element->attributeValue(QTest::AI_Result), location.constData(), cdataTag.constData(), cdataDesc.constData()); } else { QTest::qt_asprintf(formatted, "\n" " \n" "\n", element->attributeValue(QTest::AI_Result), location.constData(), cdataDesc.constData()); } break; } case QTest::LET_Error: { // assuming type and attribute names don't need quoting QTestCharBuffer quotedFile; QTestCharBuffer cdataDesc; QXmlTestLogger::xmlQuote("edFile, element->attributeValue(QTest::AI_File)); QXmlTestLogger::xmlCdata(&cdataDesc, element->attributeValue(QTest::AI_Description)); QTestCharBuffer tagbuf; if (element->attribute(QTest::AI_Tag)) { QTestCharBuffer cdataTag; QXmlTestLogger::xmlCdata(&cdataTag, element->attributeValue(QTest::AI_Tag)); QTest::qt_asprintf(&tagbuf, " \n", cdataTag.constData()); } QTest::qt_asprintf(formatted, "\n%s \n\n", element->attributeValue(QTest::AI_Type), element->attributeName(QTest::AI_File), quotedFile.constData(), element->attributeName(QTest::AI_Line), element->attributeValue(QTest::AI_Line), tagbuf.constData(), cdataDesc.constData()); break; } case QTest::LET_Benchmark: { // assuming value and iterations don't need quoting QTestCharBuffer quotedMetric; QTestCharBuffer quotedTag; QXmlTestLogger::xmlQuote("edMetric, element->attributeValue(QTest::AI_Metric)); QXmlTestLogger::xmlQuote("edTag, element->attributeValue(QTest::AI_Tag)); QTest::qt_asprintf(formatted, "\n", element->attributeName(QTest::AI_Metric), quotedMetric.constData(), element->attributeName(QTest::AI_Tag), quotedTag.constData(), element->attributeName(QTest::AI_Value), element->attributeValue(QTest::AI_Value), element->attributeName(QTest::AI_Iterations), element->attributeValue(QTest::AI_Iterations) ); break; } default: formatted->data()[0] = '\0'; } } void QTestXmlStreamer::formatEnd(const QTestElement *element, QTestCharBuffer *formatted) const { if(!element || !formatted) return; if (element->elementType() == QTest::LET_TestCase) { bool failed = false; for (QTestElement* child = element->childElements(); child; child = child->nextElement()) { if ( child->elementType() == QTest::LET_Failure && child->attribute(QTest::AI_Result) && ( !strcmp(child->attributeValue(QTest::AI_Result), "fail") || !strcmp(child->attributeValue(QTest::AI_Result), "xpass")) ) { failed = true; break; } } // For passing functions, no Incident has been output yet. // For failing functions, we already output one. // Please note: we are outputting "pass" even if there was an xfail etc. // This is by design (arguably bad design, but dangerous to change now!) if (element->attribute(QTest::AI_Result) && !failed) { QTest::qt_asprintf(formatted, "\n\n"); } else { QTest::qt_asprintf(formatted, "\n"); } } else { formatted->data()[0] = '\0'; } } void QTestXmlStreamer::formatBeforeAttributes(const QTestElement *element, QTestCharBuffer *formatted) const { Q_UNUSED(element); if (!formatted) return; formatted->data()[0] = '\0'; } void QTestXmlStreamer::output(QTestElement *element) const { QTestCharBuffer buf; QTestCharBuffer quotedTc; QXmlTestLogger::xmlQuote("edTc, QTestResult::currentTestObjectName()); QTest::qt_asprintf(&buf, "\n\n", quotedTc.constData()); outputString(buf.constData()); if (logger()->hasRandomSeed()) { QTest::qt_asprintf(&buf, "\n %s\n %s\n %d\n", qVersion(), QTEST_VERSION_STR, logger()->randomSeed() ); } else { QTest::qt_asprintf(&buf, "\n %s\n %s\n", qVersion(), QTEST_VERSION_STR ); } outputString(buf.constData()); QTest::qt_asprintf(&buf, "\n"); outputString(buf.constData()); QTestBasicStreamer::output(element); QTest::qt_asprintf(&buf, "\n"); outputString(buf.constData()); } QT_END_NAMESPACE