Execution SettingsExecution objects represent actual underlying tool executions. You can launch unlimited number of JMeter's, Gatling Tool's, etc. Executions are configured under top-level config key execution. Specifying single execution config is equivalent to specifying array of executions with single element, for example: execution: scenario: scenario_name is equivalent for execution: - scenario: scenario_name However, users are encouraged to use array notation always to leverage the arrays auto-join capability when combining multiple config files into one. See config merge rules for more details on this. There are load profile and scenario settings that are common for all execution types, and each executor type can also have its own settings. Executor TypesTaurus tool may use different underlying tools as executors for scenarios. Currently, supported tools are:
Default executor is jmeter and can be changed under general settings section. settings: default-executor: jmeter You may contribute your efforts in supporting requests-scenarios for your favorite tool by discussing this on GitHub Issues. Load ProfileExecution has several options to set load profile settings. Support for options is specific to executor type. Available settings are:
execution: - concurrency: 10 ramp-up: 15s hold-for: 2m iterations: 1000 throughput: 20 scenario: scenario_name ScenarioScenario is a sequence of steps that is used to build script for underlying tool (e.g. generate JMX file for JMeter). It is described in special scenarios top-level config element. There are three examples of scenario syntax: scenarios: get-requests: # normal form: scenario is dictionary requests: - http://localhost/1 - http://localhost/2 only-script: script: gatling_script.scala # short form: just script execution: - concurrency: 10 hold-for: 1m scenario: get-requests - executor: gatling concurrency: 5 iterations: 10 scenario: only-script - hold-for: 20s scenario: my_jmx_file.jmx # shortest form: only script file name Another way to execute something is asking for script: scenarios: with_script: script: some_special_file SoapUI IntegrationYou can specify SoapUI projects in place of script. The executor will convert them into Taurus scenarios and handle with correspond executor. Example: execution: - concurrency: 10 executor: jmeter hold-for: 5m scenario: soapui-project scenarios: soapui-project: script: project.xml test-case: TestIndex You can read more on that here. Startup ScheduleBy default, Taurus runs items under execution in parallel. To switch it into sequential mode, run it with -sequential command-line option. This is an alias for this setting: modules: local: sequential: true # false by default There is advanced way to limit number of executors, worked simultaneously. For that you should use capacity parameter of local with needed limit: modules: local: capacity: 3 # no limit by default It means "don't start the 4th executor until one of the previous 3 has finished" Note: sequential is equivalent to capacity: 1. Please do not use both sequential and capacity at the same time to prevent ambiguity in your configuration. You can run different executions at different times with delay option: execution: - concurrency: 10 hold-for: 20s scenario: main - concurrency: 20 hold-for: 15s scenario: main delay: 10s scenarios: main: requests: - http://blazedemo.com/ By this way, the first execution works 10 seconds, then two executions will work 10 seconds together, then the first will stop and the second will complete its work in 5 seconds. Another way to schedule is usage of start-at: execution: - concurrency: 10 hold-for: 20s start-at: '2020-03-25 23:15' # must be string scenario: sample scenarios: sample: requests: - http://blazedemo.com/ Supported time formats are:
Additional FilesWhen your execution requires additional files (e.g. JARs, certificates etc.) and you plan to send tests to the Сloud, you may use files option of execution and list paths for files there. Environment VariablesIn addition to global env vars, you can specify execution-specific environment variables. This is done by specifying key-value pairs under env option of execution: execution: - concurrency: 10 hold-for: 20s scenario: main env: base_url: http://foo.bar/ |
On this page:
Quick Links: |