如何在jenkins中使用Xunit打印测试结果以进行QT5多单元测试

时间:2014-07-03 07:46:23

标签: xml qt unit-testing jenkins xunit

我已经开始开发QT项目了。我想在jenkins中运行多个单元测试,我想在jenkins仪表板中看到测试结果。所以我安装了Xunit插件。 1个单元测试类正在运行。但我想运行多个单元测试或测试套件。但是我不知道如何处理QT应用程序。我尝试过一种方式。但它产生了错误的xml格式。然后Xunit给出了错误。我认为错误的原因是有两个

TestMathTokenizer testTokenizer;
TestMathParser testParser;
return QTest::qExec(&testTokenizer, argc, argv) |
        QTest::qExec(&testParser, argc, argv);

在jenkins中,我为post build编写了命令:

qttest-example-test -xml > "C:\Program Files (x86)\Jenkins\workspace\hostGit\testResult2.xml"

生成的XML如下:

<?xml version="1.0" encoding="UTF-8"?>
<TestCase name="TestMathTokenizer">
<Environment>
    <QtVersion>5.2.1</QtVersion>
    <QTestVersion>5.2.1</QTestVersion>
</Environment>
<TestFunction name="initTestCase">
<Message type="qdebug" file="" line="0">
    <Description><![CDATA[TestMathTokenizer::initTestCase() ]]></Description>
</Message>
<Incident type="pass" file="" line="0" />
</TestFunction>
<TestFunction name="testEmpty">
<Message type="qdebug" file="" line="0">
    <Description><![CDATA[TestMathTokenizer::init() ]]></Description>
</Message>
<Message type="qdebug" file="" line="0">
    <Description><![CDATA[Inside TestMathTokenizer::testEmpty() ]]></Description>
</Message>
<Message type="qdebug" file="" line="0">
    <Description><![CDATA[TestMathTokenizer::cleanup() ]]></Description>
</Message>
<Incident type="pass" file="" line="0" />
</TestFunction>
<TestFunction name="testInt">
<Message type="qdebug" file="" line="0">
    <Description><![CDATA[TestMathTokenizer::init() ]]></Description>
</Message>
<Message type="qdebug" file="" line="0">
    <Description><![CDATA[TestMathTokenizer::cleanup() ]]></Description>
</Message>
<Incident type="pass" file="" line="0" />
</TestFunction>
<TestFunction name="testIntFail">
<Message type="qdebug" file="" line="0">
    <Description><![CDATA[TestMathTokenizer::init() ]]></Description>
</Message>
<Message type="qdebug" file="" line="0">
    <Description><![CDATA[TestMathTokenizer::cleanup() ]]></Description>
</Message>
<Incident type="pass" file="" line="0" />
</TestFunction>
<TestFunction name="testExpr">
<Message type="qdebug" file="" line="0">
    <Description><![CDATA[TestMathTokenizer::init() ]]></Description>
</Message>
<Message type="qdebug" file="" line="0">
    <Description><![CDATA[TestMathTokenizer::cleanup() ]]></Description>
</Message>
<Incident type="pass" file="" line="0" />
</TestFunction>
<TestFunction name="testUnexpectedCharacterFail">
<Message type="qdebug" file="" line="0">
    <Description><![CDATA[TestMathTokenizer::init() ]]></Description>
</Message>
<Message type="qdebug" file="" line="0">
    <Description><![CDATA[TestMathTokenizer::cleanup() ]]></Description>
</Message>
<Incident type="pass" file="" line="0" />
</TestFunction>
<TestFunction name="testFutureFunctionality">
<Message type="qdebug" file="" line="0">
    <Description><![CDATA[TestMathTokenizer::init() ]]></Description>
</Message>
<Incident type="xfail" file="test\testmathtokenizer.cpp" line="86">
    <Description><![CDATA[sqrt not implemented yet]]></Description>
</Incident>
<Message type="qdebug" file="" line="0">
    <Description><![CDATA[TestMathTokenizer::cleanup() ]]></Description>
</Message>
<Incident type="pass" file="" line="0" />
</TestFunction>
<TestFunction name="testZero">
<Message type="qdebug" file="" line="0">
    <Description><![CDATA[TestMathTokenizer::init() ]]></Description>
</Message>
<Incident type="fail" file="test\testmathtokenizer.cpp" line="95">
    <Description><![CDATA['false' returned FALSE. ()]]></Description>
</Incident>
<Message type="qdebug" file="" line="0">
    <Description><![CDATA[TestMathTokenizer::cleanup() ]]></Description>
</Message>
</TestFunction>
<TestFunction name="evilFunction">
<Message type="qdebug" file="" line="0">
    <Description><![CDATA[TestMathTokenizer::init() ]]></Description>
</Message>
<Message type="qdebug" file="" line="0">
    <Description><![CDATA[TestMathTokenizer::cleanup() ]]></Description>
</Message>
<Incident type="pass" file="" line="0" />
</TestFunction>
<TestFunction name="cleanupTestCase">
<Message type="qdebug" file="" line="0">
    <Description><![CDATA[TestMathTokenizer::cleanupTestCase() ]]></Description>
</Message>
<Incident type="pass" file="" line="0" />
</TestFunction>
</TestCase>
<?xml version="1.0" encoding="UTF-8"?>
<TestCase name="TestMathParser">
<Environment>
    <QtVersion>5.2.1</QtVersion>
    <QTestVersion>5.2.1</QTestVersion>
</Environment>
<TestFunction name="initTestCase">
<Incident type="pass" file="" line="0" />
</TestFunction>
<TestFunction name="testEmptyFail">
<Incident type="pass" file="" line="0" />
</TestFunction>
<TestFunction name="testInt">
<Incident type="pass" file="" line="0" />
</TestFunction>
<TestFunction name="testInvalidOperator">
<Incident type="pass" file="" line="0" />
</TestFunction>
<TestFunction name="testAllOperators">
<Incident type="pass" file="" line="0" />
</TestFunction>
<TestFunction name="testDivisionByZeroFail">
<Incident type="pass" file="" line="0" />
</TestFunction>
<TestFunction name="testUnexpectedEndFail">
<Incident type="pass" file="" line="0" />
</TestFunction>
<TestFunction name="cleanupTestCase">
<Incident type="pass" file="" line="0" />
</TestFunction>
</TestCase>

错误:

 Caused by: org.xml.sax.SAXParseException; lineNumber: 100; columnNumber: 6; The processing instruction target matching "[xX][mM][lL]" is not allowed.
    at com.sun.org.apache.xerces.internal.parsers.DOMParser.parse(Unknown Source)
    at com.sun.org.apache.xerces.internal.jaxp.DocumentBuilderImpl.parse(Unknown Source)
    at com.thalesgroup.dtkit.util.converter.ConversionService.convert(ConversionService.java:316)
    ... 21 more

1 个答案:

答案 0 :(得分:1)

问题是你有2个xml标签(文件),因为你的代码为你拥有的每个测试类生成一个。

您的输出应该以2 xmls进行分析和分割,遇到同样的问题。

这是一个CMD脚本,可以将文件拆分为2:

set /a filenameCounter=0 
setlocal ENABLEDELAYEDEXPANSION 
for /f "tokens=*" %%a in (testResult2.xml) do (    
   if "%%a"=="<?xml version="1.0" encoding="ISO-8859-1"?>" (
       set /a filenameCounter=filenameCounter+1
   )
   set splitFile=file!filenameCounter!.xml
   echo %%a>>!splitFile! 
) 
endlocal 
del testResult2.xml

在执行Windows批处理命令中添加此脚本,当然如果构建在Windows下,如果没有,我可以为您提供perl脚本。