Как получить результат теста во время выполнения тестов WebDriver в Jenkins? - PullRequest
2 голосов
/ 26 февраля 2012

Я использую Play! Модуль WebDrive и задания работают нормально, но при сбое тестов задание Jenkins показывает «Все тесты пройдены». Я пытаюсь зафиксировать результаты теста, но продолжаю сталкиваться с неприятностями.

Я попытался использовать плагин SeleniumHQ для Jenkins, но это приводит к ошибке, показанной ниже. Я использую Firefox, поэтому мне было задано расположение результатов теста {app} / test-result / FirefoxDriver / *. Html

Publishing Selenium report...
ERROR: No Test Report Found
Build step 'Publish Selenium Report' changed build result to FAILURE
Finished: FAILURE

Так что я полагаю, что на самом деле это не Selenium. Я пытался вытянуть в Play! Плагин и это не дало никаких хороших вариантов. Я попробовал Play! автоматическое тестирование отчетов после этапа сборки, но это привело только к отображению журнала приложения.

Наконец, я попытался использовать шаг после создания отчета о результатах тестирования инструментов публикации. Это особенно расстраивает, потому что документы такие ужасные, а Дженкинс не предоставляет никакой информации по отладке / устранению неполадок, которую я могу найти.

Custom Tool Pattern: {app}/test-result/FirefoxDriver/*.html
Custom stylesheet: scripts/webdrive2junit.xsl

XSL, который я установил, ниже, а затем ошибка, которую я постоянно получаю, ниже этого. Кто-нибудь получает результаты теста от webdrive: тест на работу Дженкинса?

<?xml version="1.0" encoding="UTF-8"?>
<!--
 - Hopefully we won't use this for long.  I put it together to get some information
 - out of the webdrive:test results while I look for a better solution.
 -->
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
  <xsl:template match="child::body">
    <xsl:variable name="test" select="normalize-space(descendant::div/h1)"/>
    <testsuite>
      <xsl:attribute name="name">
        <xsl:value-of select="$test"/>
      </xsl:attribute>
      <testcase>
        <xsl:attribute name="classname">
          <xsl:value-of select="$test"/>
        </xsl:attribute>
        <xsl:attribute name="name">
          <xsl:value-of select="descendant::div/div/table/thead/tr/th"/>
        </xsl:attribute>
        <xsl:if test="descendant::tr[@class='  status_failed']">
          <error />
        </xsl:if>
      </testcase>
    </testsuite>   
  </xsl:template>
</xsl:stylesheet>

Вот ошибка, которую я получаю в журнале заданий.

[xUnit] [INFO] - [Custom Tool] - 1 test report file(s) were found with the pattern 'src/test-result/FirefoxDriver/*.html' relative to '/opt/ci/hudson/workspace/enterprise_another-play-test' for the testing framework 'Custom Tool'.
[xUnit] [ERROR] - Conversion error Error to convert - A file not found
ERROR: Publisher org.jenkinsci.plugins.xunit.XUnitPublisher aborted due to exception
hudson.util.IOException2: remote file operation failed: /opt/ci/hudson/workspace/enterprise_another-play-test at hudson.remoting.Channel@34b246:build-trunk-2
...
Caused by: com.thalesgroup.hudson.plugins.xunit.exception.XUnitException: Conversion error Error to convert - A file not found
    at com.thalesgroup.hudson.plugins.xunit.service.XUnitConversionService.convert(XUnitConversionService.java:89)
    at com.thalesgroup.hudson.plugins.xunit.service.XUnitTransformer.invoke(XUnitTransformer.java:135)
    ... 11 more
Caused by: com.thalesgroup.dtkit.util.converter.ConversionException: Error to convert - A file not found
    at com.thalesgroup.dtkit.util.converter.ConversionService.convert(ConversionService.java:369)
    at com.thalesgroup.dtkit.util.converter.ConversionService.convert(ConversionService.java:177)
    at com.thalesgroup.dtkit.util.converter.ConversionService.convert(ConversionService.java:114)
    at com.thalesgroup.dtkit.metrics.model.InputMetricXSL.convert(InputMetricXSL.java:196)
    at com.thalesgroup.dtkit.metrics.model.InputMetricXSL.convert(InputMetricXSL.java:202)
    at com.thalesgroup.hudson.plugins.xunit.service.XUnitConversionService.convertCustomInputMetric(XUnitConversionService.java:104)
    at com.thalesgroup.hudson.plugins.xunit.service.XUnitConversionService.convert(XUnitConversionService.java:78)
    ... 12 more
Caused by: org.xml.sax.SAXParseException: The element type "meta" must be terminated by the matching end-tag "</meta>".
    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:324)
    ... 18 more
Finished: FAILURE

1 Ответ

0 голосов
/ 28 февраля 2012

Мой текущий способ обхода ниже. Любые улучшения будут оценены. Поскольку плагин Play не работает для меня (так как появляется модуль webdrive), мои шаги по сборке - это скрипты bash.

# work-around for the XUnit Plugin trouble; feel free to Tidy up
find src/test-result/FirefoxDriver -name "*.html" -print0 | xargs -r0 -n 1 bash -c '
  testname=$(basename ${0%.html.*.html});
  xsltproc --html -o src/test-result/FirefoxDriver/TEST-$testname.xml scripts/webdrive2junit.xsl $0
'

Я посмотрел код для плагина XUnit для Jenkins (который, по-моему, стоит за шагом после создания отчета о результатах тестирования инструментов публикации), и я понял, что он не выполняет то, что я думал.

...