Сбой сборки Jmeter Maven освещения, хотя генерирует вывод

Я пытаюсь использовать плагин освещения jmeter maven для автоматического анализа отчетов, однако получаю ошибку сборки. Освещение позволяет интегрировать CI/CD с Jmeter.

Мне удалось настроить демонстрационный проект освещения, однако, когда я сделаю это для своего проекта, это приведет к сбою сборки. Ошибка ниже:

              [ERROR] Failed to execute goal uk.co.automatictester:jmeter- 
              lightning-maven-plugin:1.2.0:lightning (default) on project 
              jmeter-lightning-maven-plugin-example: MojoExecutionException 
             -> [Help 1]

Однако проверка журнала консоли показывает, что правила были применены, и был сгенерирован вывод, однако он вернул результат на основе критериев, указанных в файле конфигурации lighting.xml.

   [DEBUG]   (f) jmeterCsv = 
   C:\Projects\lightingMaven\target\jmeter\results\TestPerformance.csv
   [DEBUG]   (f) mode = verify
   [DEBUG]   (f) testSetXml = 
   C:\Projects\lightingMaven\src\test\resources\lightning.xml
   [DEBUG] -- end configuration --
   [DEBUG] Reading CSV file - start
   [DEBUG] Reading CSV file - finish, read 1602 rows, took 63ms
   [INFO] Test name:            Test #1
   [INFO] Test type:            avgRespTimeTest
   [INFO] Test description:     Verify maximum response times
   [INFO] Transaction name:     getPursesRequest
   [INFO] Expected result:      Average response time <= 2000
   [INFO] Actual result:        Average response time = 1742
   [INFO] Transaction count:    600
   [INFO] Longest transactions: [24095, 23707, 22891, 18723, 16717]
   [INFO] Test result:          Pass
   [INFO] 
   [INFO] Test name:            Test #5
   [INFO] Test type:            passedTransactionsTest
   [INFO] Test description:     Verify number of passed tests
   [INFO] Transaction name:     getPursesRequest
   [INFO] Expected result:      Percent of failed transactions <= 50
   [INFO] Actual result:        Percent of failed transactions = 1
   [INFO] Transaction count:    600
   [INFO] Test result:          Pass
   [INFO] 
   [INFO] Test name:            Test #4
   [INFO] Test type:            nthPercRespTimeTest
   [INFO] Test description:     Verify 90th percentile
   [INFO] Transaction name:     getPursesRequest
   [INFO] Expected result:      90th percentile of transactions have 
    response time <= 8000
   [INFO] Actual result:        90th percentile of transactions have 
    response time = 2218
   [INFO] Transaction count:    600
   [INFO] Longest transactions: [24095, 23707, 22891, 18723, 16717]
   [INFO] Test result:          Pass
   [INFO] 
   [INFO] Test name:            Test #3
   [INFO] Test type:            throughputTest
   [INFO] Test description:     Verify throughput
   [INFO] Transaction name:     getPursesRequest
   [INFO] Expected result:      Throughput >= 0.1 / second
   [INFO] Actual result:        Throughput = 2 / second
   [INFO] Transaction count:    600
   [ INFO] Test result:          Pass
   [INFO] 
   [INFO] Test name:            Test #2
   [INFO] Test type:            maxRespTimeTest
   [INFO] Test description:     Verify maximum resp times
   [INFO] Transaction name:     getPursesRequest
   [INFO] Expected result:      Max response time <= 10000
   [INFO] Actual result:        Max response time = 24095
   [INFO] Transaction count:    600
   [INFO] Longest transactions: [24095, 23707, 22891, 18723, 16717]
   [INFO] Test result:          FAIL
   [INFO] 
   [INFO] ============= EXECUTION SUMMARY =============
   [INFO] Tests executed:    5
   [INFO] Tests passed:      4
   [INFO] Tests failed:      1
   [INFO] Tests errors:      0
   [INFO] Test set status:   FAIL
   [INFO] Execution time:    373ms
   [INFO] ##teamcity[buildStatisticValue key='Test #1' value='1742']
   [INFO] ##teamcity[buildStatisticValue key='Test #5' value='1']
   [INFO] ##teamcity[buildStatisticValue key='Test #4' value='2218']
   [INFO] ##teamcity[buildStatisticValue key='Test #3' value='2']
   [INFO] ##teamcity[buildStatisticValue key='Test #2' value='24095']
   [INFO] ------------------------------------------------------------------
  [INFO] BUILD FAILURE
  [INFO] -------------------------------------------------------------------
  [INFO] Total time: 05:21 min
  [INFO] Finished at: 2018-06-03T16:27:18+01:00

  [INFO] Final Memory: 18M/190M
  [INFO] -------------------------------------------------------------------

Файл конфигурации освещения xml находится ниже:

<testSet>

<avgRespTimeTest>
    <testName>Test #1</testName>
    <description>Verify maximum response times</description>
    <transactionName>getPursesRequest</transactionName>
    <maxAvgRespTime>2000</maxAvgRespTime>
  </avgRespTimeTest>

 <maxRespTimeTest>
    <testName>Test #2</testName>
    <description>Verify maximum resp times</description>
    <transactionName>getPursesRequest</transactionName>
    <regexp/>
    <maxAllowedRespTime>10000</maxAllowedRespTime>
 </maxRespTimeTest>


 <throughputTest>
    <testName>Test #3</testName>
    <description>Verify throughput</description>
    <transactionName>getPursesRequest</transactionName>
    <regexp/>
    <minThroughput>0.1</minThroughput>
 </throughputTest>

 <nthPercRespTimeTest>
    <testName>Test #4</testName>
    <description>Verify 90th percentile</description>
    <transactionName>getPursesRequest</transactionName>
    <regexp/>
    <percentile>90</percentile>
    <maxRespTime>8000</maxRespTime>
 </nthPercRespTimeTest>

 <passedTransactionsTest>
    <testName>Test #5</testName>
    <description>Verify number of passed tests</description>
    <transactionName>getPursesRequest</transactionName>
    <regexp/>

 <allowedPercentOfFailedTransactions>50</allowedPercentOfFailedTransactions>
 </passedTransactionsTest>
  </testSet>

1 ответ

Решение

Время вашего ответа превышает 10 секунд согласно журналу:

[INFO] Описание теста: проверить максимальное время ответа

Ожидаемый результат: максимальное время отклика <= 10000

[INFO] Фактический результат: максимальное время отклика = 24095

[INFO] Результат теста: FAIL

Если до 30 секунд все в порядке, измените максимальное время ответа

 <maxRespTimeTest>
    <testName>Test #2</testName>
    <description>Verify maximum resp times</description>
    <transactionName>getPursesRequest</transactionName>
    <regexp/>
    <maxAllowedRespTime>30000</maxAllowedRespTime>
 </maxRespTimeTest>

Если не видите, как сократить время вашего API

Другие вопросы по тегам