All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.lazerycode.jmeter.mojo.RunJMeterServerMojo Maven / Gradle / Ivy

package com.lazerycode.jmeter.mojo;

import com.lazerycode.jmeter.configuration.JMeterArgumentsArray;
import com.lazerycode.jmeter.json.TestConfigurationWrapper;
import com.lazerycode.jmeter.testrunner.JMeterProcessBuilder;
import org.apache.maven.plugin.MojoExecutionException;
import org.apache.maven.plugins.annotations.LifecyclePhase;
import org.apache.maven.plugins.annotations.Mojo;
import org.apache.maven.plugins.annotations.Parameter;

import java.io.BufferedReader;
import java.io.File;
import java.io.IOException;
import java.io.InputStreamReader;

/**
 * Goal that runs JMeter in server mode.
* This goal runs within Lifecycle phase {@link LifecyclePhase#INTEGRATION_TEST}. * * @author Philippe Mouawad * @since 2.5.0 */ @Mojo(name = "remote-server", defaultPhase = LifecyclePhase.INTEGRATION_TEST) public class RunJMeterServerMojo extends AbstractJMeterMojo { /** * Run the process in the background. * This process will continue to run once the maven build has completed unless you manually find it and kill it! */ @Parameter(defaultValue = "false", property = "background") private boolean runInBackground; /** * Port JMeter Server will listen on */ @Parameter(defaultValue = "1099", property = "serverPort") private Integer serverPort; /** * Exported RMI host name */ @Parameter(defaultValue = "localhost", property = "rmiHostname") private String exportedRmiHostname; /** * Disable SSL */ @Parameter(defaultValue = "false", property = "rmiSSLDisable") private Boolean disableSSL; public static final String CLI_CONFIG_EXECUTION_ID = "default-cli"; /** * Load the JMeter server * * @throws MojoExecutionException MojoExecutionException */ @Override public void doExecute() throws MojoExecutionException { getLog().info(" "); getLog().info(LINE_SEPARATOR); getLog().info(" S T A R T I N G J M E T E R S E R V E R "); getLog().info(LINE_SEPARATOR); getLog().info(String.format(" Host: %s", exportedRmiHostname)); getLog().info(String.format(" Port: %s", serverPort)); if (this.mojoExecution.getExecutionId().equals(CLI_CONFIG_EXECUTION_ID)) { testConfig = new TestConfigurationWrapper(new File(testConfigFile), CLI_CONFIG_EXECUTION_ID); } else { testConfig = new TestConfigurationWrapper(new File(testConfigFile), selectedConfiguration); } startJMeterServer(initializeJMeterArgumentsArray()); } private JMeterArgumentsArray initializeJMeterArgumentsArray() throws MojoExecutionException { return new JMeterArgumentsArray(false, testConfig.getCurrentTestConfiguration().getJmeterDirectoryPath()) .setProxyConfig(proxyConfig) .addACustomPropertiesFiles(customPropertiesFiles) .setLogRootOverride(overrideRootLogLevel) .setLogsDirectory(logsDirectory.getAbsolutePath()) .setServerMode(exportedRmiHostname, serverPort); } private void startJMeterServer(JMeterArgumentsArray testArgs) throws MojoExecutionException { jMeterProcessJVMSettings.setHeadlessDefaultIfRequired() .addArgument(String.format("-Djava.rmi.server.hostname=%s", exportedRmiHostname)) .addArgument(String.format("-Dserver.rmi.ssl.disable=%s", disableSSL)) .addArgument(String.format("-Dserver_port=%s", serverPort)); JMeterProcessBuilder jmeterProcessBuilder = new JMeterProcessBuilder(jMeterProcessJVMSettings, testConfig.getCurrentTestConfiguration().getRuntimeJarName()) .setWorkingDirectory(new File(testConfig.getCurrentTestConfiguration().getJmeterDirectoryPath(), "bin")) .addArguments(testArgs.buildArgumentsArray()); try { final Process process = jmeterProcessBuilder.build().start(); if (runInBackground) { getLog().info(" "); getLog().info(" Starting JMeter server process in the background..."); //TODO log process using process.pid() when Java 9 is the minimum supported version } else { Runtime.getRuntime().addShutdownHook(new Thread(() -> { getLog().info("Shutdown detected, destroying JMeter server process..."); getLog().info(" "); process.destroy(); })); try (InputStreamReader isr = new InputStreamReader(process.getInputStream()); BufferedReader br = new BufferedReader(isr)) { String line; while ((line = br.readLine()) != null) { if (suppressJMeterOutput) { getLog().debug(line); } else { getLog().info(line); } } int jMeterExitCode = process.waitFor(); if (jMeterExitCode != 0) { throw new MojoExecutionException("Starting JMeter server in background failed with exit code: " + jMeterExitCode); } } } } catch (InterruptedException ex) { getLog().info(" "); getLog().info("System Exit detected! Stopping JMeter server process..."); getLog().info(" "); Thread.currentThread().interrupt(); } catch (IOException ioException) { getLog().error(String.format( "Error starting JMeter with args %s, in working directory: %s", testArgs.buildArgumentsArray(), testConfig.getCurrentTestConfiguration().getJmeterDirectoryPath() ), ioException); } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy