us.abstracta.jmeter.javadsl.JmeterDsl Maven / Gradle / Ivy
Show all versions of jmeter-java-dsl Show documentation
package us.abstracta.jmeter.javadsl;
import java.time.Duration;
import java.util.Arrays;
import java.util.Collections;
import java.util.function.Function;
import us.abstracta.jmeter.javadsl.core.DslTestElement;
import us.abstracta.jmeter.javadsl.core.DslTestPlan;
import us.abstracta.jmeter.javadsl.core.DslTestPlan.TestPlanChild;
import us.abstracta.jmeter.javadsl.core.assertions.DslJsonAssertion;
import us.abstracta.jmeter.javadsl.core.assertions.DslResponseAssertion;
import us.abstracta.jmeter.javadsl.core.configs.DslCounter;
import us.abstracta.jmeter.javadsl.core.configs.DslCsvDataSet;
import us.abstracta.jmeter.javadsl.core.configs.DslVariables;
import us.abstracta.jmeter.javadsl.core.controllers.DslForEachController;
import us.abstracta.jmeter.javadsl.core.controllers.DslIfController;
import us.abstracta.jmeter.javadsl.core.controllers.DslOnceOnlyController;
import us.abstracta.jmeter.javadsl.core.controllers.DslRuntimeController;
import us.abstracta.jmeter.javadsl.core.controllers.DslSimpleController;
import us.abstracta.jmeter.javadsl.core.controllers.DslTransactionController;
import us.abstracta.jmeter.javadsl.core.controllers.DslWeightedSwitchController;
import us.abstracta.jmeter.javadsl.core.controllers.DslWhileController;
import us.abstracta.jmeter.javadsl.core.controllers.ForLoopController;
import us.abstracta.jmeter.javadsl.core.controllers.PercentController;
import us.abstracta.jmeter.javadsl.core.engines.AutoStoppedTestException;
import us.abstracta.jmeter.javadsl.core.listeners.AutoStopListener;
import us.abstracta.jmeter.javadsl.core.listeners.DslViewResultsTree;
import us.abstracta.jmeter.javadsl.core.listeners.GraphiteBackendListener;
import us.abstracta.jmeter.javadsl.core.listeners.HtmlReporter;
import us.abstracta.jmeter.javadsl.core.listeners.InfluxDbBackendListener;
import us.abstracta.jmeter.javadsl.core.listeners.JtlWriter;
import us.abstracta.jmeter.javadsl.core.listeners.ResponseFileSaver;
import us.abstracta.jmeter.javadsl.core.postprocessors.DslBoundaryExtractor;
import us.abstracta.jmeter.javadsl.core.postprocessors.DslDebugPostProcessor;
import us.abstracta.jmeter.javadsl.core.postprocessors.DslJsonExtractor;
import us.abstracta.jmeter.javadsl.core.postprocessors.DslJsr223PostProcessor;
import us.abstracta.jmeter.javadsl.core.postprocessors.DslJsr223PostProcessor.PostProcessorScript;
import us.abstracta.jmeter.javadsl.core.postprocessors.DslRegexExtractor;
import us.abstracta.jmeter.javadsl.core.preprocessors.DslJsr223PreProcessor;
import us.abstracta.jmeter.javadsl.core.preprocessors.DslJsr223PreProcessor.PreProcessorScript;
import us.abstracta.jmeter.javadsl.core.preprocessors.DslJsr223PreProcessor.PreProcessorVars;
import us.abstracta.jmeter.javadsl.core.samplers.DslDummySampler;
import us.abstracta.jmeter.javadsl.core.samplers.DslFlowControlAction;
import us.abstracta.jmeter.javadsl.core.threadgroups.BaseThreadGroup.ThreadGroupChild;
import us.abstracta.jmeter.javadsl.core.threadgroups.DslDefaultThreadGroup;
import us.abstracta.jmeter.javadsl.core.threadgroups.DslSetupThreadGroup;
import us.abstracta.jmeter.javadsl.core.threadgroups.DslTeardownThreadGroup;
import us.abstracta.jmeter.javadsl.core.threadgroups.RpsThreadGroup;
import us.abstracta.jmeter.javadsl.core.timers.DslConstantTimer;
import us.abstracta.jmeter.javadsl.core.timers.DslSynchronizingTimer;
import us.abstracta.jmeter.javadsl.core.timers.DslThroughputTimer;
import us.abstracta.jmeter.javadsl.core.timers.DslUniformRandomTimer;
import us.abstracta.jmeter.javadsl.core.util.PropertyScriptBuilder.PropertyScript;
import us.abstracta.jmeter.javadsl.http.DslAuthManager;
import us.abstracta.jmeter.javadsl.http.DslCacheManager;
import us.abstracta.jmeter.javadsl.http.DslCookieManager;
import us.abstracta.jmeter.javadsl.http.DslHttpDefaults;
import us.abstracta.jmeter.javadsl.http.DslHttpSampler;
import us.abstracta.jmeter.javadsl.http.HttpHeaders;
import us.abstracta.jmeter.javadsl.java.DslJsr223Sampler;
import us.abstracta.jmeter.javadsl.java.DslJsr223Sampler.SamplerScript;
import us.abstracta.jmeter.javadsl.util.TestResource;
/**
* This is the main class to be imported from any code using JMeter DSL.
*
* This class contains factory methods to create {@link DslTestElement} instances that allow
* specifying test plans and associated test elements (samplers, thread groups, listeners, etc.). If
* you want to support new test elements, then you either add them here (if they are considered to
* be part of the core of JMeter), or implement another similar class containing only the specifics
* of the protocol, repository, or grouping of test elements that you want to build (eg, one might
* implement an Http2JMeterDsl class with only http2 test elements' factory methods).
*
* When implement new factory methods consider adding only as parameters the main properties of the
* test elements (the ones that makes sense to specify in most of the cases). For the rest of
* parameters (the optional ones), prefer them to be specified as methods of the implemented
* {@link DslTestElement} for such case, in a similar fashion as Builder Pattern.
*
* @since 0.1
*/
public class JmeterDsl {
private JmeterDsl() {
}
/**
* Builds a new test plan.
*
* @param children specifies the list of test elements that compose the test plan.
* @return the test plan instance.
* @see DslTestPlan
*/
public static DslTestPlan testPlan(TestPlanChild... children) {
return new DslTestPlan(Arrays.asList(children));
}
/**
* Builds a new thread group with a given number of threads & iterations.
*
* @param threads specifies the number of threads to simulate concurrent virtual users.
* @param iterations specifies the number of iterations that each virtual user will run of
* children elements until it stops.
*
* If you specify -1, then threads will iterate until test plan execution is
* interrupted (you manually stop the running process, there is an error and
* thread group is configured to stop on error, or some other explicit
* termination condition).
*
* Setting this property to -1 is in general not advised, since you
* might inadvertently end up running a test plan without limits consuming
* unnecessary computing power. Prefer specifying a big value as a safe limit
* for iterations or duration instead.
* @param children contains the test elements that each thread will execute in each iteration.
* @return the thread group instance.
* @see DslDefaultThreadGroup
*/
public static DslDefaultThreadGroup threadGroup(int threads, int iterations,
ThreadGroupChild... children) {
return threadGroup(null, threads, iterations, children);
}
/**
* Same as {@link #threadGroup(int, int, ThreadGroupChild...)} but allowing to set a name on the
* thread group.
*
* Setting a proper name allows to properly identify the requests generated in each thread group.
*
* @see #threadGroup(int, int, ThreadGroupChild...)
*/
public static DslDefaultThreadGroup threadGroup(String name, int threads, int iterations,
ThreadGroupChild... children) {
return new DslDefaultThreadGroup(name, threads, iterations, Arrays.asList(children));
}
/**
* Builds a new thread group with a given number of threads & their duration.
*
* @param threads to simulate concurrent virtual users.
* @param duration to keep each thread running for this period of time. Take into consideration
* that JMeter supports specifying duration in seconds, so if you specify a
* smaller granularity (like milliseconds) it will be rounded up to seconds.
* @param children contains the test elements that each thread will execute until specified
* duration is reached.
* @return the thread group instance.
* @see ThreadGroup
* @since 0.5
*/
public static DslDefaultThreadGroup threadGroup(int threads, Duration duration,
ThreadGroupChild... children) {
return threadGroup(null, threads, duration, children);
}
/**
* Same as {@link #threadGroup(int, Duration, ThreadGroupChild...)} but allowing to set a name on
* the thread group.
*
* Setting a proper name allows to properly identify the requests generated in each thread group.
*
* @see #threadGroup(int, Duration, ThreadGroupChild...)
* @since 0.5
*/
public static DslDefaultThreadGroup threadGroup(String name, int threads, Duration duration,
ThreadGroupChild... children) {
return new DslDefaultThreadGroup(name, threads, duration, Arrays.asList(children));
}
/**
* Builds a new thread group without any thread configuration.
*
* This method should be used as starting point for creating complex test thread profiles (like
* spike, or incremental tests) in combination with holdFor, rampTo and rampToAndHold
* {@link DslDefaultThreadGroup} methods.
*
*
* Eg:
*
{@code
* threadGroup()
* .rampTo(10, Duration.ofSeconds(10))
* .rampTo(5, Duration.ofSeconds(10))
* .rampToAndHold(20, Duration.ofSeconds(5), Duration.ofSeconds(10))
* .rampTo(0, Duration.ofSeconds(5))
* .children(...)
* }
*
* For complex thread profiles that can't be mapped to JMeter built-in thread group element, the
* DSL uses Ultimate Thread Group
* plugin.
*
* @return the thread group instance.
* @since 0.18
*/
public static DslDefaultThreadGroup threadGroup() {
return new DslDefaultThreadGroup(null);
}
/**
* Same as {@link #threadGroup()} but allowing to set a name on the thread group.
*
* Setting a proper name allows to properly identify the requests generated in each thread group.
*
* @see #threadGroup()
* @since 0.18
*/
public static DslDefaultThreadGroup threadGroup(String name) {
return new DslDefaultThreadGroup(name);
}
/**
* Builds a thread group that allows running logic before other thread groups.
*
* This is usually used to run some setup logic before the actual test plan logic. In particular
* logic that needs to be run within the context of JMeter test (eg: requires setting some JMeter
* property) or needs to be run from same machines as the test plan.
*
* Check {@link DslSetupThreadGroup} for more details and configuration options.
*
* @param children test elements to be run before any other thread group.
* @return the setup thread group for further customization or just usage in test plan
* @see DslSetupThreadGroup
* @since 0.33
*/
public static DslSetupThreadGroup setupThreadGroup(ThreadGroupChild... children) {
return new DslSetupThreadGroup(null, Arrays.asList(children));
}
/**
* Same as {@link #setupThreadGroup(ThreadGroupChild...)} but allowing to set a name on the thread
* group.
*
* Setting a proper name allows to properly identify the requests generated in each thread group.
*
* @see DslSetupThreadGroup
* @since 0.35
*/
public static DslSetupThreadGroup setupThreadGroup(String name, ThreadGroupChild... children) {
return new DslSetupThreadGroup(name, Arrays.asList(children));
}
/**
* Builds a setup thread group which allows tuning settings before setting its children.
*
* This method allows for example setting the number of iterations and threads to be used by the
* thread group, before setting children elements.
*
* @see DslSetupThreadGroup
* @since 0.35
*/
public static DslSetupThreadGroup setupThreadGroup() {
return new DslSetupThreadGroup(null, Collections.emptyList());
}
/**
* Same as {@link #setupThreadGroup()} but allowing to set a name on the thread group.
*
* Setting a proper name allows to properly identify the requests generated in each thread group.
*
* @see DslSetupThreadGroup
* @since 0.35
*/
public static DslSetupThreadGroup setupThreadGroup(String name) {
return new DslSetupThreadGroup(name, Collections.emptyList());
}
/**
* Builds a thread group that allows running logic after other thread groups.
*
* This is usually used to run some clean up logic after the actual test plan logic. In particular
* logic that needs to be run within the context of JMeter test (eg: requires setting some JMeter
* property) or needs to be run from same machines as the test plan.
*
* Check {@link DslTeardownThreadGroup} for more details and configuration options.
*
* @param children test elements to be run after any other thread group.
* @return the teardown thread group for further customization or just usage in test plan
* @see DslTeardownThreadGroup
* @since 0.33
*/
public static DslTeardownThreadGroup teardownThreadGroup(ThreadGroupChild... children) {
return new DslTeardownThreadGroup(null, Arrays.asList(children));
}
/**
* Same as {@link #teardownThreadGroup(ThreadGroupChild...)} but allowing to set a name on the
* thread group.
*
* Setting a proper name allows to properly identify the requests generated in each thread group.
*
* @see DslTeardownThreadGroup
* @since 0.35
*/
public static DslTeardownThreadGroup teardownThreadGroup(String name,
ThreadGroupChild... children) {
return new DslTeardownThreadGroup(name, Arrays.asList(children));
}
/**
* Builds a teardown thread group which allows tuning settings before setting its children.
*
* This method allows for example setting the number of iterations and threads to be used by the
* thread group, before setting children elements.
*
* @see DslTeardownThreadGroup
* @since 0.35
*/
public static DslTeardownThreadGroup teardownThreadGroup() {
return new DslTeardownThreadGroup(null, Collections.emptyList());
}
/**
* Same as {@link #teardownThreadGroup()} but allowing to set a name on the thread group.
*
* Setting a proper name allows to properly identify the requests generated in each thread group.
*
* @see DslTeardownThreadGroup
* @since 0.35
*/
public static DslTeardownThreadGroup teardownThreadGroup(String name) {
return new DslTeardownThreadGroup(name, Collections.emptyList());
}
/**
* Builds a thread group that dynamically adapts thread count and pauses to match a given RPS.
*
* Internally this element uses
* Concurrency Thread Group
* in combination with Throughput Shaping Timer.
*
* Eg:
*
{@code
* rpsThreadGroup()
* .maxThreads(500)
* .rampTo(20, Duration.ofSeconds(10))
* .rampTo(10, Duration.ofSeconds(10))
* .rampToAndHold(1000, Duration.ofSeconds(5), Duration.ofSeconds(10))
* .rampTo(0, Duration.ofSeconds(5))
* .children(...)
* }
*
* @return the thread group instance.
* @see RpsThreadGroup
* @since 0.26
*/
public static RpsThreadGroup rpsThreadGroup() {
return new RpsThreadGroup(null);
}
/**
* Same as {@link #rpsThreadGroup()} but allowing to set a name on the thread group.
*
* Setting a proper name allows to properly identify the requests generated in each thread group.
*
* @see #rpsThreadGroup()
* @since 0.26
*/
public static RpsThreadGroup rpsThreadGroup(String name) {
return new RpsThreadGroup(name);
}
/**
* Builds a new transaction controller with the given name.
*
* @param name specifies the name to identify the transaction.
* @param children contains the test elements that will be contained within the transaction.
* @return the transaction instance.
* @see DslTransactionController
* @since 0.14
*/
public static DslTransactionController transaction(String name, ThreadGroupChild... children) {
return new DslTransactionController(name, Arrays.asList(children));
}
/**
* Builds a new simple controller with the given name.
*
* Simple controllers are good for defining test plan scopes, without having to create a
* transaction (which generates a sample result). For example, to apply configs, assertions,
* timers, listeners, post- and pre-processors to only part of the test plan (certain samplers).
*
* Additionally, they are a handy way of creating methods that return certain part of a test plan
* (inside a simple controller) and then directly inject the method returned controller in an
* existing test plan.
*
* @param children contains the test elements that will be contained within the controller.
* @return the controller instance.
* @see DslSimpleController
* @since 1.21
*/
public static DslSimpleController simpleController(ThreadGroupChild... children) {
return simpleController(null, children);
}
/**
* Same as {@link #simpleController(ThreadGroupChild...)} but allowing to set a name.
*
* In this scenario, the name has no functional usage during test plan execution, but it can ease
* JMX test plan review as to keep sections of the test plan well identified.
*
* @see #simpleController(ThreadGroupChild...)
*/
public static DslSimpleController simpleController(String name, ThreadGroupChild... children) {
return new DslSimpleController(name, Arrays.asList(children));
}
/**
* Builds an If Controller that allows to conditionally run specified children.
*
* @param condition contains an expression that when evaluated to true tells the controller to run
* specified children.
* @param children contains the test plan elements to execute when the condition is true.
* @return the controller instance for further configuration and usage.
* @see DslIfController
* @since 0.27
*/
public static DslIfController ifController(String condition, ThreadGroupChild... children) {
return new DslIfController(condition, Arrays.asList(children));
}
/**
* Same as {@link #ifController(String, ThreadGroupChild...)} but allowing to use Java type safety
* and code completion when specifying the condition.
*
* WARNING: This only works when using embedded jmeter engine.
* Check the user guide
* for details on some alternative.
*
* Take into consideration that the provided script is invoked from as may threads as defined in
* thread group. So make sure that provided logic is thread safe.
*
* @see PropertyScript
* @see #ifController(String, ThreadGroupChild...)
* @since 0.27
*/
public static DslIfController ifController(PropertyScript condition,
ThreadGroupChild... children) {
return new DslIfController(condition, Arrays.asList(children));
}
/**
* Same as {@link #ifController(PropertyScript, ThreadGroupChild...)} but with support for running
* at scale in a remote engine.
*
* Check the user guide
* for details on additional steps required to run them at scale in a remote engine.
*
* @see PropertyScript
* @see #ifController(PropertyScript, ThreadGroupChild...)
* @since 1.14
*/
public static DslIfController ifController(
Class extends PropertyScript> conditionClass,
ThreadGroupChild... children) {
return new DslIfController(conditionClass, Arrays.asList(children));
}
/**
* Builds a While Controller that allows to run specific part of the test plan while a given
* condition is met in one thread iteration.
*
* JMeter generates {@code __jm__while__idx} variable containing the iteration number (0 indexed),
* which can be helpful in some scenarios.
*
* @param condition contains an expression that will be evaluated to identify when to stop
* looping.
* @param children contains the test plan elements to execute while the condition is true.
* @return the controller instance for further configuration and usage.
* @see DslWhileController
* @since 0.27
*/
public static DslWhileController whileController(String condition, ThreadGroupChild... children) {
return whileController(null, condition, children);
}
/**
* Same as {@link #whileController(String, ThreadGroupChild...)} but allowing to set a name which
* defines autogenerated variable created by JMeter containing iteration index.
*
* @param name specifies the name to assign to the controller. This variable affects the
* JMeter autogenerated variable {@code __jm____idx} which holds
* the loop iteration number (starting at 0).
* @param condition contains an expression that will be evaluated to identify when to stop
* looping.
* @param children contains the test plan elements to execute while the condition is true.
* @return the controller instance for further configuration and usage.
* @see DslWhileController
* @see #whileController(String, ThreadGroupChild...)
* @since 0.27
*/
public static DslWhileController whileController(String name, String condition,
ThreadGroupChild... children) {
return new DslWhileController(name, condition, Arrays.asList(children));
}
/**
* Same as {@link #whileController(String, ThreadGroupChild...)} but allowing to use Java type
* safety and code completion when specifying the condition.
*
* WARNING: This only works when using embedded jmeter engine.
* Check the user guide
* for details on some alternative.
*
* Take into consideration that the provided script is invoked from as may threads as defined in
* thread group. So, make sure that provided logic is thread safe.
*
* JMeter generates {@code __jm__while__idx} variable containing the iteration number (0 indexed),
* which can be helpful in some scenarios.
*
* @param condition contains java code that will be evaluated to identify when to stop looping.
* @param children contains the test plan elements to execute while the condition is true.
* @return the controller instance for further configuration and usage.
* @see PropertyScript
* @see #whileController(String, ThreadGroupChild...)
* @since 0.27
*/
public static DslWhileController whileController(PropertyScript condition,
ThreadGroupChild... children) {
return whileController(null, condition, children);
}
/**
* Same as {@link #whileController(PropertyScript, ThreadGroupChild...)} but allowing to set a
* name which defines autogenerated variable created by JMeter containing iteration index.
*
* @param name specifies the name to assign to the controller. This variable affects the
* JMeter autogenerated variable {@code __jm____idx} which holds
* the loop iteration number (starting at 0).
* @param condition contains java code that will be evaluated to identify when to stop looping.
* @param children contains the test plan elements to execute while the condition is true.
* @return the controller instance for further configuration and usage.
* @see PropertyScript
* @see #whileController(PropertyScript, ThreadGroupChild...)
* @since 0.27
*/
public static DslWhileController whileController(String name, PropertyScript condition,
ThreadGroupChild... children) {
return new DslWhileController(name, condition, Arrays.asList(children));
}
/**
* Same as {@link #whileController(PropertyScript, ThreadGroupChild...)} but with support for
* running at scale in a remote engine.
*
* Check the user guide
* for details on additional steps required to run them at scale in a remote engine.
*
* @see PropertyScript
* @see #whileController(PropertyScript, ThreadGroupChild...)
* @since 1.14
*/
public static DslWhileController whileController(
Class extends PropertyScript> conditionClass,
ThreadGroupChild... children) {
return whileController(null, conditionClass, children);
}
/**
* Same as {@link #whileController(Class, ThreadGroupChild...)} but allowing to set a name which
* defines autogenerated variable created by JMeter containing iteration index.
*
* @param name specifies the name to assign to the controller. This variable affects the JMeter
* autogenerated variable {@code __jm____idx} which holds the loop
* iteration number (starting at 0).
* @see PropertyScript
* @see #whileController(PropertyScript, ThreadGroupChild...)
* @since 1.14
*/
public static DslWhileController whileController(String name,
Class extends PropertyScript> conditionClass, ThreadGroupChild... children) {
return new DslWhileController(name, conditionClass, Arrays.asList(children));
}
/**
* Builds a Loop Controller that allows to run specific number of times the given children in each
* thread group iteration.
*
* Eg: if a thread group iterates 3 times and the Loop Controller is configured to 5, then the
* children elements will run {@code 3*5=15} times for each thread.
*
* JMeter generates {@code __jm__for__idx} variable containing the iteration number (0 indexed),
* which can be helpful in some scenarios.
*
* @param count specifies the number of times to execute the children elements in each thread
* group iteration.
* @param children contains the test plan elements to execute the given number of times in each
* thread group iteration.
* @return the controller instance for further configuration and usage.
* @see ForLoopController
* @since 0.27
*/
public static ForLoopController forLoopController(int count, ThreadGroupChild... children) {
return new ForLoopController(null, String.valueOf(count), Arrays.asList(children));
}
/**
* Same as {@link #forLoopController(int, ThreadGroupChild...)} but allowing to set a name which
* defines autogenerated variable created by JMeter containing iteration index.
*
* @param name specifies the name to assign to the controller. This variable affects the
* JMeter autogenerated variable {@code __jm____idx} which holds
* the loop iteration number (starting at 0).
* @param count specifies the number of times to execute the children elements in each thread
* group iteration.
* @param children contains the test plan elements to execute the given number of times in each
* thread group iteration.
* @return the controller instance for further configuration and usage.
* @see ForLoopController
* @see #forLoopController(int, ThreadGroupChild...)
* @since 0.27
*/
public static ForLoopController forLoopController(String name, int count,
ThreadGroupChild... children) {
return new ForLoopController(name, String.valueOf(count), Arrays.asList(children));
}
/**
* Same as {@link #forLoopController(int, ThreadGroupChild...)} but allowing to use JMeter
* expressions for number of loops
*
* This method allows, for example, to extract from a previous response the number of times to
* execute some part of the test plan and use it in forLoop with something like
{@code
* "${LOOPS_COUNT}"}
.
*
* @param count specifies a JMeter expression which evaluates to a number specifying the number
* of times to execute the children elements in each thread group iteration..
* @param children contains the test plan elements to execute the given number of times in each
* thread group iteration.
* @return the controller instance for further configuration and usage.
* @see #forLoopController(int, ThreadGroupChild...)
* @since 0.46
*/
public static ForLoopController forLoopController(String count, ThreadGroupChild... children) {
return new ForLoopController(null, count, Arrays.asList(children));
}
/**
* Same as {@link #forLoopController(String, ThreadGroupChild...)} but allowing to set a name
* which defines autogenerated variable created by JMeter containing iteration index.
*
* @param name specifies the name to assign to the controller. This variable affects the
* JMeter autogenerated variable {@code __jm____idx} which holds
* the loop iteration number (starting at 0).
* @param count specifies a JMeter expression which evaluates to a number specifying the number
* of times to execute the children elements in each thread group iteration..
* @param children contains the test plan elements to execute the given number of times in each
* thread group iteration.
* @return the controller instance for further configuration and usage.
* @see ForLoopController
* @see #forLoopController(int, ThreadGroupChild...)
* @since 0.46
*/
public static ForLoopController forLoopController(String name, String count,
ThreadGroupChild... children) {
return new ForLoopController(name, count, Arrays.asList(children));
}
/**
* Builds a For each controller that iterates over a set of variables and runs a given set of
* children for each variable in the set.
*
* This is usually used in combination with extractors that return more than one variable (like
* regex extractor with -1 index), to iterate over generated variables.
*
* JMeter generates {@code __jm____idx} variable containing the iteration number
* (0 indexed), which can be helpful in some scenarios.
*
* @param varsPrefix specifies the variable prefix of the set of variables to iterate over.
* This will be suffixed by underscore and the iteration index number (eg:
* my_var_0) to get the actual variable and store its value in a variable
* with name specified by iterationVarName.
* @param iterationVarName specifies the name of the variable to store the value assigned to the
* variable of current iteration. eg: the value of my_var_0 when first
* iteration and my_var is set as varsPrefix.
* @param children contains the test plan elements to execute for the given set of
* variables.
* @return the controller instance for further configuration and usage.
* @see DslForEachController
* @since 0.44
*/
public static DslForEachController forEachController(String varsPrefix, String iterationVarName,
ThreadGroupChild... children) {
return new DslForEachController(iterationVarName, varsPrefix, iterationVarName,
Arrays.asList(children));
}
/**
* Same as {@link #forEachController(String, String, ThreadGroupChild...)} but allowing to set a
* name which defines autogenerated variable created by JMeter containing iteration index.
*
* @param name specifies the name to assign to the controller. This variable affects
* the JMeter autogenerated variable {@code __jm____idx}
* which holds the loop iteration number (starting at 0).
* @param varsPrefix specifies the variable prefix of the set of variables to iterate over.
* This will be suffixed by underscore and the iteration index number (eg:
* my_var_0) to get the actual variable and store its value in a variable
* with name specified by iterationVarName.
* @param iterationVarName specifies the name of the variable to store the value assigned to the
* variable of current iteration. eg: the value of my_var_0 when first
* iteration and my_var is set as varsPrefix.
* @param children contains the test plan elements to execute the given number of times in
* each thread group iteration.
* @return the controller instance for further configuration and usage.
* @see DslForEachController
* @see #forEachController(String, String, ThreadGroupChild...)
* @since 0.44
*/
public static DslForEachController forEachController(String name, String varsPrefix,
String iterationVarName, ThreadGroupChild... children) {
return new DslForEachController(name, varsPrefix, iterationVarName, Arrays.asList(children));
}
/**
* Builds a Once Only Controller that allows running a part of a test plan only once and only on
* the first iteration of each thread group.
*
* Eg: if a thread group iterates 3 times and contains few samplers inside the Once Only
* Controller, then children elements will run 1 time for each thread.
*
* @param children contains the test plan elements to execute only one time on first iteration of
* each thread group.
* @return the controller instance for further configuration and usage.
* @see DslOnceOnlyController
* @since 0.34
*/
public static DslOnceOnlyController onceOnlyController(ThreadGroupChild... children) {
return new DslOnceOnlyController(Arrays.asList(children));
}
/**
* Builds a Runtime Controller that stops executing child elements when a period of time expires.
*
* This can be very useful to implement some time based logic like refreshing a token after
* certain time while doing http requests (runtimeController + whileController).
*
* The controller executes each child sequentially until there are no more children to execute or
* the time has expired.
*
* Child elements execution is not interrupted, the controller just checks on each child execution
* ending if the time has expired, and if so, don't execute the rest of its child elements.
*
* @param duration defines de duration after which no further child elements will be executed (on
* each iteration). Take into consideration that JMeter supports specifying
* duration in seconds, so if you specify a smaller granularity (like
* milliseconds) it will be rounded up to seconds.
* @param children contains the child elements to execute.
* @return the controller instance for further configuration and usage.
* @see DslRuntimeController
* @since 1.1
*/
public static DslRuntimeController runtimeController(Duration duration,
ThreadGroupChild... children) {
return new DslRuntimeController(String.valueOf(duration.getSeconds()), Arrays.asList(children));
}
/**
* Same as {@link #runtimeController(Duration, ThreadGroupChild...)} but allowing to use JMeter
* expressions for the duration.
*
* @param seconds defines a JMeter expression that evaluates to a number of seconds the runtime
* controller will execute child elements for.
* @param children contains the child elements to execute.
* @return the controller instance for further configuration and usage.
* @see #runtimeController(Duration, ThreadGroupChild...)
* @see DslRuntimeController
* @since 1.1
*/
public static DslRuntimeController runtimeController(String seconds,
ThreadGroupChild... children) {
return new DslRuntimeController(seconds, Arrays.asList(children));
}
/**
* Builds a Percent Controller to execute children only a given percent of times.
*
* Internally, this uses a JMeter Throughput Controller with executions percentage configuration.
*
* @param percent defines a number between 0 and 100 that defines the percentage of times to
* execute given children elements.
* @param children holds test plan elements to execute when for the given percent of times.
* @return the controller instance for further configuration and usage.
* @see PercentController
* @since 0.25
*/
public static PercentController percentController(float percent, ThreadGroupChild... children) {
return new PercentController(String.valueOf(percent), Arrays.asList(children));
}
/**
* Same as {@link #percentController(float, ThreadGroupChild...)} but allowing using JMeter
* expressions (eg: ${PERCENT_VAR}) in percent parameter.
*
* This might be useful to set percents according to different profiles, for example, using
* different percents in production vs staging tests
*
* @param percent defines a JMeter expression that evaluates to a number between 0 and 100 that
* defines the percentage of times to execute given children elements.
* @param children holds test plan elements to execute when for the given percent of times.
* @return the controller instance for further configuration and usage.
* @since 0.63
*/
public static PercentController percentController(String percent, ThreadGroupChild... children) {
return new PercentController(percent, Arrays.asList(children));
}
/**
* Builds a Controller which executes in each iteration choosing one child according to given
* weights.
*
* Internally this uses
* BlazeMeter Weighted Switch Controller plugin.
*
* @return the controller instance for further configuration and usage.
* @see DslWeightedSwitchController
* @since 0.53
*/
public static DslWeightedSwitchController weightedSwitchController() {
return new DslWeightedSwitchController();
}
/**
* Builds an HTTP Request sampler to sample HTTP requests.
*
* @param url specifies URL the HTTP Request sampler will hit.
* @return the HTTP Request sampler instance which can be used to define additional settings for
* the HTTP request (like method, body, headers, pre & post processors, etc.).
* @see DslHttpSampler
*/
public static DslHttpSampler httpSampler(String url) {
return httpSampler(null, url);
}
/**
* Builds an HTTP Request sampler to sample HTTP requests with a dynamically calculated URL.
*
* This method is just an abstraction that uses jexl2 function as URL.
*
* WARNING: This only works when using embedded jmeter engine.
* Check the user guide
* for details on some alternative.
*
* @param urlSupplier specifies URL the HTTP Request sampler will hit.
* @return the HTTP Request sampler instance which can be used to define additional settings for
* the HTTP request (like method, body, headers, pre & post processors, etc.).
* @see DslHttpSampler
* @since 0.10
*/
public static DslHttpSampler httpSampler(Function urlSupplier) {
return httpSampler(null, urlSupplier);
}
/**
* Same as {@link #httpSampler(String)} but allowing to set a name to the HTTP Request sampler.
*
* Setting a proper name allows to easily identify the requests generated by this sampler and
* check its particular statistics.
*
* @see #httpSampler(String)
*/
public static DslHttpSampler httpSampler(String name, String url) {
return new DslHttpSampler(name, url);
}
/**
* Same as {@link #httpSampler(Function)} but allowing to set a name to the HTTP Request sampler.
*
* Setting a proper name allows to easily identify the requests generated by this sampler and
* check its particular statistics.
*
* WARNING: This only works when using embedded jmeter engine.
* Check the user guide
* for details on some alternative.
*
* @see #httpSampler(Function)
* @since 0.10
*/
public static DslHttpSampler httpSampler(String name,
Function urlSupplier) {
return new DslHttpSampler(name, urlSupplier);
}
/**
* Same as {@link #httpSampler(Function)} but with support for running at scale in a remote
* engine.
*
* Check the user guide
* for details on additional steps required to run them at scale in a remote engine.
*
* @see #httpSampler(Function)
* @since 1.14
*/
public static DslHttpSampler httpSampler(Class extends PropertyScript> urlSolverClass) {
return httpSampler(null, urlSolverClass);
}
/**
* Same as {@link #httpSampler(Class)} but allowing to set a name to the HTTP Request sampler.
*
* Setting a proper name allows to easily identify the requests generated by this sampler and
* check its particular statistics.
*
* @see #httpSampler(Class)
* @since 1.14
*/
public static DslHttpSampler httpSampler(String name,
Class extends PropertyScript> urlSolverClass) {
return new DslHttpSampler(name, urlSolverClass);
}
/**
* Builds an HTTP header manager which allows setting HTTP headers to be used by HTTPRequest
* samplers.
*
* @return the HTTP header manager instance which allows specifying the particular HTTP headers to
* use.
* @see HttpHeaders
*/
public static HttpHeaders httpHeaders() {
return new HttpHeaders();
}
/**
* Builds an HTTP request defaults element that allows setting default values used by HTTP
* samplers.
*
* In general, prefer using Java variables or custom builder methods to abstract common logic for
* samplers which allows for easier debugging, readability and traceability. In some cases though
* it might be shorter/simpler to just use and httpDefaults element.
*
* @return the HTTP defaults test element for customization and usage.
* @since 0.39
*/
public static DslHttpDefaults httpDefaults() {
return new DslHttpDefaults();
}
/**
* Builds a Cookie manager at the test plan level which allows configuring cookies settings used
* by HTTPRequest samplers.
*
* @return the Cookie manager instance which allows configuring cookies settings.
* @see DslCookieManager
* @since 0.17
*/
public static DslCookieManager httpCookies() {
return new DslCookieManager();
}
/**
* Builds a Cache manager at the test plan level which allows configuring caching behavior used by
* HTTPRequest samplers.
*
* @return the Cache manager instance which allows configuring caching settings.
* @see DslCacheManager
* @since 0.17
*/
public static DslCacheManager httpCache() {
return new DslCacheManager();
}
/**
* Builds an Auth manager which simplifies configuration for automatic authentication of HTTP
* requests.
*
* @return the Auth manager instance which allows to specify different authentications for
* different URLs.
* @see DslAuthManager
* @since 1.5
*/
public static DslAuthManager httpAuth() {
return new DslAuthManager();
}
/**
* Builds a DslVariables that allows to easily initialize or update JMeter variables.
*
* This internally uses User Defined Variables when placed as test plan child and JSR223 Samplers
* otherwise.
*
* @return the DslVariables instance to define variables values and using it in a test plan.
* @see DslVariables
* @since 0.50
*/
public static DslVariables vars() {
return new DslVariables();
}
/**
* Builds a JSR223 Sampler which allows sampling any Java API or custom logic.
*
*
* @param script contains the script to be use while sampling. By default, this will be a groovy
* script, but you can change it by setting the language property in the returned
* post processor.
* @return the JSR223 Sampler instance
* @see DslJsr223Sampler
* @since 0.22
*/
public static DslJsr223Sampler jsr223Sampler(String script) {
return jsr223Sampler(null, script);
}
/**
* Same as {@link #jsr223Sampler(String)} but allowing to set a name on the sampler.
*
* The name is used in collected samples to easily identify their results and as logger name which
* allows configuring log level, appender, etc., for the sampler.
*
* @see #jsr223Sampler(String)
* @since 0.22
**/
public static DslJsr223Sampler jsr223Sampler(String name, String script) {
return new DslJsr223Sampler(name, script);
}
/**
* Same as {@link #jsr223Sampler(String)} but allowing to use Java type safety and code completion
* when specifying the script.
*
* WARNING: This only works when using embedded jmeter engine.
* Check the user guide
* for details on some alternative.
*
* Take into consideration that the provided script is invoked from as may threads as defined in
* thread group. So make sure that provided logic is thread safe.
*
* @see SamplerScript
* @see #jsr223Sampler(String)
* @since 0.22
*/
public static DslJsr223Sampler jsr223Sampler(SamplerScript script) {
return jsr223Sampler(null, script);
}
/**
* Same as {@link #jsr223Sampler(String, String)} but allowing to use Java type safety and code
* completion when specifying the script.
*
* WARNING: This only works when using embedded jmeter engine.
* Check the user guide
* for details on some alternative.
*
* Take into consideration that the provided script is invoked from as may threads as defined in
* thread group. So make sure that provided logic is thread safe.
*
* @see SamplerScript
* @see #jsr223Sampler(String)
* @since 0.22
*/
public static DslJsr223Sampler jsr223Sampler(String name, SamplerScript script) {
return new DslJsr223Sampler(name, script);
}
/**
* Same as {@link #jsr223Sampler(SamplerScript)} but with support for running at scale in a remote
* engine.
*
* Check the user guide
* for details on additional steps required to run them at scale in a remote engine.
*
* @see SamplerScript
* @see #jsr223Sampler(SamplerScript)
* @since 1.14
*/
public static DslJsr223Sampler jsr223Sampler(Class extends SamplerScript> scriptClass) {
return jsr223Sampler(null, scriptClass);
}
/**
* Same as {@link #jsr223Sampler(Class)} but allowing to set a name on the sampler.
*
* The name is used in collected samples to easily identify their results and as logger name which
* allows configuring log level, appender, etc., for the sampler.
*
* @see #jsr223Sampler(Class)
* @since 1.14
**/
public static DslJsr223Sampler jsr223Sampler(String name,
Class extends SamplerScript> scriptClass) {
return new DslJsr223Sampler(name, scriptClass);
}
/**
* Builds a JMeter plugin Dummy Sampler which allows emulating a sampler easing testing other
* parts of a test plan (like extractors, controllers conditions, etc).
*
* Usually you would replace an existing sampler with this one, to test some extractor or test
* plan complex behavior (like controllers conditions), and once you have verified that the rest
* of the plan works as expected, you place back the original sampler that makes actual
* interactions to a server.
*
* By default, this sampler, in contrast to the JMeter plugin Dummy Sampler, does not simulate
* response time. This helps speeding up the debug and tracing process while using it.
*
* @param responseBody specifies the response body to be included in generated sample results.
* @return the dummy sampler for further configuration and usage in test plan.
* @see DslDummySampler
* @since 0.46
*/
public static DslDummySampler dummySampler(String responseBody) {
return dummySampler(null, responseBody);
}
/**
* Same as {@link #dummySampler(String)} but allowing to set a name on the sampler.
*
* Setting the name of the sampler allows better simulation the final use case when dummy sampler
* is replaced by actual/final sampler, when sample results are reported in stats, logs, etc.
*
* @see DslDummySampler
* @see #dummySampler(String)
* @since 0.46
*/
public static DslDummySampler dummySampler(String name, String responseBody) {
return new DslDummySampler(name, responseBody);
}
/**
* Builds a JSR223 Pre Processor which allows including custom logic to modify requests.
*
* This preprocessor is very powerful, and lets you alter request parameters, jmeter context and
* implement any kind of custom logic that you may think.
*
* @param script contains the script to be executed by the preprocessor. By default, this will be
* a groovy script, but you can change it by setting the language property in the
* returned post processor.
* @return the JSR223 Pre Processor instance
* @see DslJsr223PreProcessor
* @since 0.7
*/
public static DslJsr223PreProcessor jsr223PreProcessor(String script) {
return jsr223PreProcessor(null, script);
}
/**
* Same as {@link #jsr223PreProcessor(String)} but allowing to set a name on the preprocessor.
*
* The name is used as logger name which allows configuring log level, appender, etc., for the
* preprocessor.
*
* @see #jsr223PreProcessor(String)
* @since 0.9
**/
public static DslJsr223PreProcessor jsr223PreProcessor(String name, String script) {
return new DslJsr223PreProcessor(name, script);
}
/**
* Same as {@link #jsr223PreProcessor(String)} but allowing to use Java type safety and code
* completion when specifying the script.
*
* WARNING: This only works when using embedded jmeter engine.
* Check the user guide
* for details on some alternative.
*
* Take into consideration that the provided script is invoked from as may threads as defined in
* thread group. So make sure that provided logic is thread safe.
*
* @see PreProcessorScript
* @see #jsr223PreProcessor(String)
* @since 0.10
*/
public static DslJsr223PreProcessor jsr223PreProcessor(PreProcessorScript script) {
return jsr223PreProcessor(null, script);
}
/**
* Same as {@link #jsr223PreProcessor(String, String)} but allowing to use Java type safety and
* code completion when specifying the script.
*
* WARNING: This only works when using embedded jmeter engine.
* Check the user guide
* for details on some alternative.
*
* Take into consideration that the provided script is invoked from as may threads as defined in
* thread group. So make sure that provided logic is thread safe.
*
* @see PreProcessorScript
* @see #jsr223PreProcessor(String)
* @since 0.10
*/
public static DslJsr223PreProcessor jsr223PreProcessor(String name, PreProcessorScript script) {
return new DslJsr223PreProcessor(name, script);
}
/**
* Same as {@link #jsr223PreProcessor(PreProcessorScript)} but with support for running at scale
* in a remote engine.
*
* Check the user guide
* for details on additional steps required to run them at scale in a remote engine.
*
* @see PreProcessorScript
* @see #jsr223PreProcessor(PreProcessorScript)
* @since 1.14
*/
public static DslJsr223PreProcessor jsr223PreProcessor(
Class extends PreProcessorScript> scriptClass) {
return jsr223PreProcessor(null, scriptClass);
}
/**
* Same as {@link #jsr223PreProcessor(Class)} but allowing to set a name on the sampler.
*
* The name is used in collected samples to easily identify their results and as logger name which
* allows configuring log level, appender, etc., for the sampler.
*
* @see #jsr223PreProcessor(Class)
* @since 1.14
**/
public static DslJsr223PreProcessor jsr223PreProcessor(String name,
Class extends PreProcessorScript> scriptClass) {
return new DslJsr223PreProcessor(name, scriptClass);
}
/**
* Builds a Regex Extractor which allows using regular expressions to extract different parts of a
* sample result (request or response).
*
* This method provides a simple default implementation with required settings, but more settings
* are provided by returned DslRegexExtractor.
*
* By default, when regex is not matched, no variable will be created or modified. On the other
* hand when the regex matches it will by default store the first capturing group (part of
* expression between parenthesis) of the first match for the regular expression.
*
* @param variableName is the name of the variable to be used to store the extracted value to.
* Additional variables {@code _g} will be created for
* each regular expression capturing group (segment of regex between
* parenthesis), being the group 0 the entire match of the regex. {@code
* _g} variable contains the number of matched capturing groups
* (not counting the group 0).
* @param regex regular expression used to extract part of request or response.
* @return the Regex Extractor which can be used to define additional settings to use when
* extracting (like defining match number, template, etc.).
* @see DslRegexExtractor
* @since 0.8
*/
public static DslRegexExtractor regexExtractor(String variableName, String regex) {
return new DslRegexExtractor(variableName, regex);
}
/**
* Builds a Boundary Extractor which allows using left and right boundary texts to extract
* different parts of a sample result (request or response).
*
* This method provides a simple default implementation with required settings, but more settings
* are provided by returned DslBoundaryExtractor.
*
* By default, when no match is found, no variable will be created or modified. On the other hand,
* when a match is found, it will by default store the first match.
*
* @param variableName is the name of the variable to be used to store the extracted value to.
* @param leftBoundary specifies text preceding the text to be extracted.
* @param rightBoundary specifies text following the text to be extracted.
* @return the Boundary Extractor which can be used to define additional settings to use when
* extracting (like defining match number, targetField, etc.).
* @see DslBoundaryExtractor
* @since 0.28
*/
public static DslBoundaryExtractor boundaryExtractor(String variableName, String leftBoundary,
String rightBoundary) {
return new DslBoundaryExtractor(variableName, leftBoundary, rightBoundary);
}
/**
* Builds an Extractor which allows using JMESPath or JSONPath to extract part of a JSON
* response.
*
* This method provides a simple default implementation with required settings, but more settings
* are provided by returned DslJsonExtractor.
*
* By default, uses JMESPath for queries and when no match is found, no variable will be created
* or modified. On the other hand, when a match is found, it will by default store the first
* match.
*
* @param variableName is the name of the variable to be used to store the extracted value to.
* @param query specifies JMESPath (or JSONPath, if queryLanguage specifies so) to extract
* the value.
* @return the JSON Extractor which can be used to define additional settings to use when
* extracting (like defining match number, scope, etc.).
* @see DslJsonExtractor
* @since 0.28
*/
public static DslJsonExtractor jsonExtractor(String variableName, String query) {
return new DslJsonExtractor(variableName, query);
}
/**
* Builds a Debug post processor which is helpful to collect debugging information from test plans
* executions.
*
* This element is particularly helpful to collect JMeter variables and debug extractors during or
* after a test plan execution.
*
* Created Debug post processor is configured by default to only include JMeter variables, which
* covers most common usages and keeps memory and disk usage low.
*
* @return the post processor for further configuration and usage in test plan.
* @see DslDebugPostProcessor
* @since 0.47
*/
public static DslDebugPostProcessor debugPostProcessor() {
return new DslDebugPostProcessor();
}
/**
* Builds a JSR223 Post Processor which allows including custom logic to process sample results.
*
* This post processor is very powerful, and lets you alter sample results, jmeter context and
* implement any kind of custom logic that you may think.
*
* @param script contains the script to be executed by the post processor. By default, this will
* be a groovy script, but you can change it by setting the language property in the
* returned post processor.
* @return the JSR223 Post Processor instance
* @see DslJsr223PostProcessor
* @since 0.6
*/
public static DslJsr223PostProcessor jsr223PostProcessor(String script) {
return jsr223PostProcessor(null, script);
}
/**
* Same as {@link #jsr223PostProcessor(String)} but allowing to set a name on the post processor.
*
* The name is used as logger name which allows configuring log level, appender, etc., for the
* post processor.
*
* @see #jsr223PostProcessor(String)
* @since 0.9
*/
public static DslJsr223PostProcessor jsr223PostProcessor(String name, String script) {
return new DslJsr223PostProcessor(name, script);
}
/**
* Same as {@link #jsr223PostProcessor(String)} but allowing to use Java type safety and code
* completion when specifying the script.
*
* WARNING: This only works when using embedded jmeter engine.
* Check the user guide
* for details on some alternative.
*
* Take into consideration that the provided script is invoked from as may threads as defined in
* thread group. So make sure that provided logic is thread safe.
*
* @see PostProcessorScript
* @see #jsr223PostProcessor(String)
* @since 0.10
*/
public static DslJsr223PostProcessor jsr223PostProcessor(PostProcessorScript script) {
return jsr223PostProcessor(null, script);
}
/**
* Same as {@link #jsr223PostProcessor(String, String)} but allowing to use Java type safety and
* code completion when specifying the script.
*
* WARNING: This only works when using embedded jmeter engine.
* Check the user guide
* for details on some alternative.
*
* Take into consideration that the provided script is invoked from as may threads as defined in
* thread group. So make sure that provided logic is thread safe.
*
* @see PostProcessorScript
* @see #jsr223PostProcessor(String, String)
* @since 0.10
*/
public static DslJsr223PostProcessor jsr223PostProcessor(String name,
PostProcessorScript script) {
return new DslJsr223PostProcessor(name, script);
}
/**
* Same as {@link #jsr223PostProcessor(PostProcessorScript)} but with support for running at scale
* in a remote engine.
*
* Check the user guide
* for details on additional steps required to run them at scale in a remote engine.
*
* @see PostProcessorScript
* @see #jsr223PostProcessor(PostProcessorScript)
* @since 1.14
*/
public static DslJsr223PostProcessor jsr223PostProcessor(
Class extends PostProcessorScript> scriptClass) {
return jsr223PostProcessor(null, scriptClass);
}
/**
* Same as {@link #jsr223PostProcessor(Class)} but allowing to set a name on the sampler.
*
* The name is used in collected samples to easily identify their results and as logger name which
* allows configuring log level, appender, etc., for the sampler.
*
* @see #jsr223PostProcessor(Class)
* @since 1.14
**/
public static DslJsr223PostProcessor jsr223PostProcessor(String name,
Class extends PostProcessorScript> scriptClass) {
return new DslJsr223PostProcessor(name, scriptClass);
}
/**
* Builds a Response Assertion to be able to check that obtained sample result is the expected
* one.
*
* JMeter by default uses repose codes (eg: 4xx and 5xx HTTP response codes are error codes) to
* determine if a request was success or not, but in some cases this might not be enough or
* correct. In some cases applications might not behave in this way, for example, they might
* return a 200 HTTP status code but with an error message in the body, or the response might be a
* success one, but the information contained within the response is not the expected one to
* continue executing the test. In such scenarios you can use response assertions to properly
* verify your assumptions before continuing with next request in the test plan.
*
* By default, response assertion will use the response body of the main sample result (not sub
* samples as redirects, or embedded resources) to check the specified criteria (substring match,
* entire string equality, contained regex or entire regex match) against.
*
* @return the created Response Assertion which should be modified to apply the proper criteria.
* Check {@link DslResponseAssertion} for all available options.
* @see DslResponseAssertion
* @since 0.11
*/
public static DslResponseAssertion responseAssertion() {
return new DslResponseAssertion(null);
}
/**
* Same as {@link #responseAssertion()} but allowing to set a name on the assertion, which can be
* later used to identify assertion results and differentiate it from other assertions.
*
* @param name is the name to be assigned to the assertion
* @return the created Response Assertion which should be modified to apply the proper criteria.
* Check {@link DslResponseAssertion} for all available options.
* @see #responseAssertion(String)
* @since 0.11
*/
public static DslResponseAssertion responseAssertion(String name) {
return new DslResponseAssertion(name);
}
/**
* Builds an Assertion element to check that obtained sampler result JSON is the expected one.
*
* This method simplifies checking JSON responses over {@link #responseAssertion()} alternative.
*
* By default, uses JMESPath for queries and just checks for existence of specified element. Check
* {@link DslJsonAssertion} for additional options.
*
* @param jsonQuery specifies JMESPath (or JSONPath, if queryLanguage specifies so) to check the
* existence of given element in sample result response. the value.
* @return the Assertion which can be used to configure further settings (like query Language,
* check if value in path matches regex, etc.) and used in a test plan.
* @see DslJsonAssertion
* @since 1.15
*/
public static DslJsonAssertion jsonAssertion(String jsonQuery) {
return jsonAssertion(null, jsonQuery);
}
/**
* Same as {@link #jsonAssertion(String)} but allowing to set a name on the assertion, which can
* be later used to identify assertion results and differentiate it from other assertions.
*
* @see #jsonAssertion(String)
* @see DslJsonAssertion
* @since 1.15
*/
public static DslJsonAssertion jsonAssertion(String name, String jsonQuery) {
return new DslJsonAssertion(name, jsonQuery);
}
/**
* Builds an AutoStopListener that allows to stop a test plan execution if some condition over
* collected metrics is met.
*
* This element is useful to avoid waisting resources (for instance execution costs associated to
* remote engine execution time) and time when a test plan execution is not getting an expected
* behavior.
*
* When a condition is met, the test plan is stopped and a {@link AutoStoppedTestException} is
* thrown, containing as message an indicator for the auto stop listener name and the condition
* that triggered the stop.
*
* As with other listeners, the location of the listener within the plan determines which samples
* will be taken into consideration by the listener (eg: if listener is placed as a child of a
* sampler, then only that sampler will be evaluated).
*
* Note: This element does not use AutoStop listener plugin, but is inspired on it. One important
* difference is that this element by default evaluates conditions on every sample and does not
* reset aggregations for every second. If you need to configure similar behavior as AutoStop
* listener plugin, then you can use
* {@link
* us.abstracta.jmeter.javadsl.core.listeners.AutoStopListener.AggregatedConditionBuilder#every}
* and
* {@link us.abstracta.jmeter.javadsl.core.listeners.AutoStopListener.AutoStopCondition#holdsFor}
*
* @return the listener for further configuration or usage in test plan.
* @throws AutoStoppedTestException when test plan is stopped by a met condition.
* @see AutoStopListener
* @since 1.19
*/
public static AutoStopListener autoStop() {
return autoStop(null);
}
/**
* Same as {@link #autoStop()} but allowing to set a name on the listener, which can help identify
* which autoStop listener stopped a test plan if multiple ones are configured.
*
* @see #autoStop()
* @see AutoStopListener
* @since 1.19
*/
public static AutoStopListener autoStop(String name) {
return new AutoStopListener(name);
}
/**
* Builds a Simple Data Writer to write all collected results to a JTL file.
*
* This is just a handy short way of generating JTL files using as filename the template:
*
{@code .jtl}
*
* If you need to have a predictable name, consider using {@link #jtlWriter(String, String)}
* instead.
*
* @param directory specifies the directory path where jtl files will be generated in. If the
* directory does not exist, then it will be created.
* @return the JtlWriter instance.
* @see #jtlWriter(String, String)
* @see JtlWriter
*/
public static JtlWriter jtlWriter(String directory) {
return new JtlWriter(directory, null);
}
/**
* Builds a Simple Data Writer to write all collected results to a JTL file.
*
* This is particularly helpful when you need to control de file name to do later post-processing
* on the file (eg: use CI build ID in the file name).
*
* @param directory specifies the directory path where jtl file will be generated. If the
* directory does not exist, then it will be created.
* @param fileName the name to be used for the file. File names should be unique, otherwise
* the new results will be appended to existing file.
* @return the JtlWriter instance.
* @since 1.0
*/
public static JtlWriter jtlWriter(String directory, String fileName) {
return new JtlWriter(directory, fileName);
}
/**
* Builds a Response File Saver to generate a file for each response of a sample.
*
* @param fileNamePrefix the prefix to be used when generating the files. This should contain the
* directory location where the files should be generated and can contain a
* file name prefix for all file names (eg: target/response-files/response-
* ).
* @return the ResponseFileSaver instance.
* @see ResponseFileSaver
* @since 0.13
*/
public static ResponseFileSaver responseFileSaver(String fileNamePrefix) {
return new ResponseFileSaver(fileNamePrefix);
}
/**
* Builds a Backend Listener configured to use InfluxDB to send all results for easy tracing,
* historic, comparison and live test results.
*
* @param influxDbUrl is the URL to connect to the InfluxDB instance where test results should be
* sent.
* @return the Backend Listener instance which can be used to set additional settings like title,
* token & queueSize.
* @see InfluxDbBackendListener
* @since 0.4
*/
public static InfluxDbBackendListener influxDbListener(String influxDbUrl) {
return new InfluxDbBackendListener(influxDbUrl);
}
/**
* Builds a Backend Listener configured to use Graphite to send all results for easy tracing,
* historic, comparison, and live test results.
*
* Warning: DSL graphite listener uses Pickle sender, and port 2004, by default since it
* is more performant. This behavior differs from the one provided by the JMeter element which
* uses text plain instead by default.
*
* @param graphiteUrl is the URL to connect to the Graphite instance where test results should be
* sent. You can specify the host (eg: mygraphite) or the host + port (eg:
* mygraphite:2004).
* @return the Backend Listener instance which can be used to set additional settings like title,
* token & queueSize.
* @since 1.25
*/
public static GraphiteBackendListener graphiteListener(String graphiteUrl) {
return new GraphiteBackendListener(graphiteUrl);
}
/**
* Builds an HTML Reporter which allows easily generating HTML reports for test plans.
*
* This is just a handy short way of generating html reports following naming template
*
{@code }
*
* If you need to have a predictable report name, consider using
* {@link #htmlReporter(String, String)} instead.
*
* @param reportsDirectory specifies the directory where HTML reports are generated. If the
* reportsDirectory does not exist, then it will be created.
* @return the HTML Reporter instance
* @see #htmlReporter(String, String)
* @see HtmlReporter
* @since 0.6
*/
public static HtmlReporter htmlReporter(String reportsDirectory) {
return new HtmlReporter(reportsDirectory, null);
}
/**
* Builds an HTML Reporter which allows easily generating HTML reports for test plans.
*
* This is particularly helpful when you need to control de report directory name to do later
* post-processing on it (eg: use CI build ID in the report directory name).
*
* @param reportsDirectory specifies the directory where HTML reports are generated. If the
* reportsDirectory does not exist, then it will be created.
* @param name the name to be used for the report directory. Names should be
* unique, otherwise the report generation will fail after test plan
* execution.
* @return the HTML Reporter instance
* @see HtmlReporter
* @since 1.0
*/
public static HtmlReporter htmlReporter(String reportsDirectory, String name) {
return new HtmlReporter(reportsDirectory, name);
}
/**
* Builds a View Results Tree element to show live results in a pop-up window while the test
* runs.
*
* This element is helpful when debugging a test plan to verify each sample result, and general
* structure of results.
*
* @return the View Results Tree element.
* @see DslViewResultsTree
* @since 0.19
*/
public static DslViewResultsTree resultsTreeVisualizer() {
return new DslViewResultsTree();
}
/**
* Builds a Flow Control Action that pauses the current thread for the given duration.
*
* This is an alternative to timers, which eases adding just one pause instead of applying a pause
* to all elements in the scope of a timer.
*
* @param duration specifies the duration for the pause.
* @return the test element for usage in a test plan
* @since 1.25
*/
public static DslFlowControlAction threadPause(Duration duration) {
return threadPause(String.valueOf(duration.toMillis()));
}
/**
* Sames as {@link #threadPause(Duration)} but allowing to use JMeter expressions for the
* duration.
*
* For example, you can set a delay depending on the amount of time taken in last sample with
* something like
{@code ${__groovy(5000 - prev.time)}}
.
*
* @param duration specifies a JMeter expression that evaluates to the number of milliseconds to
* pause the thread.
* @return the test element for usage in a test plan
* @since 1.25
*/
public static DslFlowControlAction threadPause(String duration) {
return DslFlowControlAction.pauseThread(duration);
}
/**
* Builds a Constant Timer which pauses the thread with for a given duration.
*
* @param duration specifies the duration for the timer to wait.
* @return the timer for usage in test plan.
* @since 1.0
*/
public static DslConstantTimer constantTimer(Duration duration) {
return constantTimer(String.valueOf(duration.toMillis()));
}
/**
* Sames as {@link #constantTimer(Duration)} but allowing tu use a JMeter expression.
*
* For example, you can set a delay depending on the amount of time taken in last sample with
* something like
{@code ${__groovy(5000 - prev.time)}}
.
*
* @param duration specifies a JMeter expression that evaluates to the number of milliseconds to
* pause the thread.
* @return the timer for usage in test plan.
* @since 1.25
*/
public static DslConstantTimer constantTimer(String duration) {
return new DslConstantTimer(duration);
}
/**
* Builds a Uniform Random Timer which pauses the thread with a random time with uniform
* distribution.
*
*
* The timer uses the minimum and maximum durations to define the range of values to be used in
* the uniformly distributed selected value. These values differ from the parameters used in
* JMeter Uniform Random Timer element to make it simpler for general users to use. The generated
* JMeter test element uses as "constant delay offset" the minimum value, and as "maximum random
* delay" (maximum - minimum) value.
*
*
*
* EXAMPLE: wait at least 3 seconds and maximum of 10 seconds
* {@code uniformRandomTimer(Duration.ofSeconds(3), Duration.ofSeconds(10))}
*
*
* @param minimum is used to set the constant delay of the Uniform Random Timer.
* @param maximum is used to set the maximum time the timer will be paused and will be used to
* obtain the random delay from the result of (maximum - minimum).
* @return The Uniform Random Timer instance
* @see DslUniformRandomTimer
* @since 1.0
*/
public static DslUniformRandomTimer uniformRandomTimer(Duration minimum, Duration maximum) {
return new DslUniformRandomTimer(minimum, maximum);
}
/**
* Builds a Constant Throughput Timer which paces samplers to limit the throughput.
*
* The timer adds variable pauses to test plan execution to limit the throughput by checking time
* between timer executions.
*
* @param throughputPerMinute specifies the target samples per minute.
* @return the timer for usage in test plan.
* @see DslThroughputTimer
* @since 1.5
*/
public static DslThroughputTimer throughputTimer(double throughputPerMinute) {
return new DslThroughputTimer(throughputPerMinute);
}
/**
* Builds a Synchronizing Timer that allows synchronizing samples to be sent all at once.
*
* This timer is useful when you need to send requests in simultaneous batches, as a way to asure
* the system under test gets the requests all at the same time.
*
* @return the timer for usage in a test plan.
* @see DslSynchronizingTimer
* @since 1.17
*/
public static DslSynchronizingTimer synchronizingTimer() {
return new DslSynchronizingTimer();
}
/**
* Builds a CSV Data Set which allows loading from a CSV file variables to be used in test plan.
*
* This allows to store for example in a CSV file one line for each user credentials, and then in
* the test plan be able to use all the credentials to test with different users.
*
* By default, the CSV data set will read comma separated values, use first row as name of the
* generated variables, restart from beginning when csv entries are exhausted and will read a new
* line of CSV for each thread and iteration.
*
* E.g: If you have a csv with 2 entries and a test plan with two threads, iterating 2 times each,
* you might get (since threads run in parallel, the assignment is not deterministic) following
* assignment of rows:
*
*
* thread 1, row 1
* thread 2, row 2
* thread 2, row 1
* thread 1, row 2
*
*
* @param csvFile path to the CSV file to read the data from.
* @return the CSV Data Set instance for further configuration and usage.
* @see DslCsvDataSet
* @since 0.24
*/
public static DslCsvDataSet csvDataSet(String csvFile) {
return new DslCsvDataSet(csvFile);
}
/**
* Same as {@link #csvDataSet(String)} but easing usage of test resources.
*
* @param resource test resource to use as input file for the CSV data set.
* @return the CSV Data Set instance for further configuration and usage.
* @see #csvDataSet(String)
* @since 0.54
*/
public static DslCsvDataSet csvDataSet(TestResource resource) {
return new DslCsvDataSet(resource.filePath());
}
/**
* Builds a counter for easy usage of auto incremental numbers in test plans.
*
* This element is handy when generating uto incremental ids, positions in a list, etc.
*
* @param name specifies the variable name used for holding the counter value.
* @return the counter for further configuration and usage.
* @since 1.10
*/
public static DslCounter counter(String name) {
return new DslCounter(name);
}
/**
* Allows easy usage of test resources like the ones in {@code src/test/resource} in maven
* projects.
*
* @param resourcePath path to locate the resource. For example, in a maven project to create a
* resource to file {@code "src/test/resources/csvs/my-csv.csv"} you need to
* use {@code testResource("csvs/my-csv.csv")}.
* @return the test resource.
* @throws IllegalArgumentException when no file can be located for provided resource path
* @see TestResource
* @since 0.54
*/
public static TestResource testResource(String resourcePath) throws IllegalArgumentException {
return new TestResource(resourcePath);
}
}