com.lazerycode.jmeter.mojo.CheckResultsMojo Maven / Gradle / Ivy
package com.lazerycode.jmeter.mojo;
import com.lazerycode.jmeter.json.TestConfigurationWrapper;
import com.lazerycode.jmeter.results.ResultScanner;
import com.lazerycode.jmeter.testrunner.TestFailureDecider;
import org.apache.maven.plugin.MojoExecutionException;
import org.apache.maven.plugin.MojoFailureException;
import org.apache.maven.plugins.annotations.LifecyclePhase;
import org.apache.maven.plugins.annotations.Mojo;
import org.apache.maven.plugins.annotations.Parameter;
import java.io.File;
import java.util.ArrayList;
import java.util.List;
/**
* Goal that computes successes/failures from CSV or XML results files.
* This goal runs within Lifecycle phase {@link LifecyclePhase#VERIFY}.
* Ensure you set 'scanResultsForSuccessfulRequests' and 'scanResultsForFailedRequests' to true.
*/
@Mojo(name = "results", defaultPhase = LifecyclePhase.VERIFY)
public class CheckResultsMojo extends AbstractJMeterMojo {
/**
* Sets whether build should fail if there are failed requests found in the JMeter result file.
* Failures are for example failed requests
*/
@Parameter(defaultValue = "false")
protected boolean ignoreResultFailures;
/**
* Sets whether ResultScanner should search for failed requests in the JMeter result file.
* Defaults to false
*/
@Parameter(defaultValue = "true")
protected boolean scanResultsForFailedRequests;
/**
* Sets the error rate threshold limit for build to get failed, i.e if its set to 3 then build fails only if
* the % of failed requests are above 3
* defaults to 0
*/
@Parameter(defaultValue = "0")
protected float errorRateThresholdInPercent;
/**
* Sets whether ResultScanner should search for Successful requests in the JMeter result file.
* Defaults to false
*/
@Parameter(defaultValue = "true")
protected boolean scanResultsForSuccessfulRequests;
/**
* Only search for specific failure messages when scanning results for failed requests (only applied to CSV files)
* Defaults to false
*/
@Parameter(defaultValue = "false")
protected boolean onlyFailWhenMatchingFailureMessage;
/**
* If the plugin cannot detect any requests in the results file force a build failure
* Defaults to false
*/
@Parameter(defaultValue = "false")
protected boolean failBuildIfResultFileIsEmpty;
/**
* list of case insensitive failure messages to search for.
* (Requires <onlyFailWhenMatchingFailureMessage>true</onlyFailWhenMatchingFailureMessage> to be set)
*/
@Parameter
protected List failureMessages = new ArrayList<>();
/**
* Scan JMeter result files for successful, and failed requests/
*
* @throws MojoExecutionException Exception
* @throws MojoFailureException Exception
*/
@Override
public void doExecute() throws MojoExecutionException, MojoFailureException {
if (!ignoreResultFailures && !scanResultsForFailedRequests) {
getLog().warn(String.format(
"current value of scanResultsForFailedRequests(%s) is incompatible with ignoreResultFailures(%s), setting scanResultsForFailedRequests to true",
scanResultsForFailedRequests,
ignoreResultFailures
));
scanResultsForFailedRequests = true;
}
if (scanResultsForSuccessfulRequests || scanResultsForFailedRequests) {
getLog().info(" ");
getLog().info(LINE_SEPARATOR);
getLog().info("S C A N N I N G F O R R E S U L T S");
getLog().info(LINE_SEPARATOR);
getLog().info(" ");
TestConfigurationWrapper testConfig = new TestConfigurationWrapper(new File(testConfigFile), selectedConfiguration);
String resultFormat = testConfig.getCurrentTestConfiguration().getResultsOutputIsCSVFormat() ? "CSV" : "JTL";
getLog().info(String.format("Will scan results using format: %s", resultFormat));
ResultScanner resultScanner = new ResultScanner(
scanResultsForSuccessfulRequests,
scanResultsForFailedRequests,
testConfig.getCurrentTestConfiguration().getResultsOutputIsCSVFormat(),
onlyFailWhenMatchingFailureMessage,
failureMessages
);
for (String resultFileLocation : testConfig.getCurrentTestConfiguration().getResultFilesLocations()) {
resultScanner.parseResultFile(new File(resultFileLocation));
}
getLog().info(" ");
getLog().info(LINE_SEPARATOR);
getLog().info("P E R F O R M A N C E T E S T R E S U L T S");
getLog().info(LINE_SEPARATOR);
getLog().info(" ");
getLog().info(String.format("Result (.%s) files scanned: %s", resultFormat.toLowerCase(), testConfig.getCurrentTestConfiguration().getResultFilesLocations().size()));
getLog().info(String.format("Successful requests: %s", resultScanner.getSuccessCount()));
getLog().info(String.format("Failed requests: %s", resultScanner.getFailureCount()));
TestFailureDecider decider = new TestFailureDecider(ignoreResultFailures, errorRateThresholdInPercent, resultScanner);
decider.runChecks();
getLog().info(String.format("Failures: %s%% (%s%% accepted)", decider.getErrorPercentage(), decider.getErrorPercentageThreshold()));
getLog().info(" ");
if (decider.failBuild()) {
throw new MojoFailureException(String.format(
"Failing build because error percentage %s is above accepted threshold %s. JMeter logs are available at: '%s'",
logsDirectory.getAbsolutePath(),
decider.getErrorPercentage(),
decider.getErrorPercentageThreshold()
));
}
if (resultScanner.getTotalCount() == 0 && failBuildIfResultFileIsEmpty) {
throw new MojoFailureException("Failing build because no requests were found in the results file!");
}
} else {
getLog().info(" ");
getLog().info("Results of Performance Test(s) have not been scanned.");
getLog().info(" ");
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy