Command-Line ToolCommand-line tool is named bzt and invoked like bzt <options> [configs]. Possible options are:
Configuration Files ProcessingTaurus tool consumes configuration files as input format (start learning its syntax here), it automatically detects YAML and JSON formats. Internally, all configuration files are merged into single configuration object (see merged.config artifact), and each following config overrides/appends previous. There are some special config locations that allows having per-machine and per-user configs, that will be loaded for every tool run. In general, configs load sequence is:
Note that per-user config will not be copied into artifact directories, so those files are recommended to put API keys and tokens to improve security. Also, it is convenient place to set paths to tools and your favorite preferences. There is special shorthand for JMeter JMX test plans: if a config filename ends with .jmx, an execution for JMeter with existing script will be generated. This allows using Taurus just like bzt test1.jmx test2.jmx. A helper tool to validate YAML: https://wiki.ess3.net/yaml/ Command-Line Options OverrideAny configuration option can be overridden from command line by using -o switch. Like this: bzt stress.json -o modules.jmeter.path=alternate/jmeter/bin/jmeter -o provisioning=cloud Rule for composing the override path is simple: it is built from dictionary keys and array indexes, separated by dot (.). If the array index is -1 then list is appended. Consider the following Taurus configuration: execution: - concurrency: 100 hold-for: 60s scenario: sample scenarios: sample: timeout: 500ms keepalive: true requests: - http://blazedemo.com/ The following override example creates the data-sources list (as it isn't specified in config) and sets the first element to data.csv: bzt -o scenarios.sample.data-sources.0=data.csv config.yaml Note that Taurus parses overridden values as YAML. This means that you can override all types of values: numbers, strings, booleans and even lists and objects. Also, YAML is a superset of JSON, so you can use JSON syntax too. Example: # overriding JMeter property with a floating-point number bzt -o modules.jmeter.properties.pi=3.141592 script.yaml # overriding requests list in scenario # (note that you have to take whole override value in quotes because quotes and brackets have special meaning in shell) bzt -o scenarios.my-scenario.requests="['http://example.com/', 'http://blazedemo.com/']" script.yaml # overriding objects bzt -o scenarios.my-scenario="{default-address: 'http://blazedemo.com/', requests: ['/', '/reserve.php']}" script.yaml And if you need to pass a string with quotations, you have to add an escaped level of quotes to it: # this will set JMeter property `name` to value `"string with quotes"`. bzt -o modules.jmeter.properties.name='"\"string with quotes\""' script.yaml If you need to recursively override a value by giving only child node of the key: # this will set all properties of 'default-address' under `scenario` to value `newValue`. # (note that the replace works only on dictionaries and list of dictionaries) bzt -o scenarios.*default-address='newValue' script.yaml AliasesThere is a way to create some config chunks and apply them from command-line like this: bzt -gui-mode -scenario1 Those aliases then searched in the config, in the section cli-aliases and applied over the configuration. Example: cli-aliases: gui-mode: modules: jmeter: gui: true scenario1: scenarios: my-scen: script: jmx2.jmx URL ShorthandsThere is a way to run a quick test on a URL (or a number of URLs) with a default load generator simply by using the target URL as a command-line argument. bzt http://blazedemo.com/ This command will launch a quick test targeting https://blazedemo.com/. You can combine it with other CLI options and aliases, such as -report, -cloud and others. ArtifactsEach tool start creates artifacts directory under base dir (see settings.artifacts-dir command-line option). This directory is used to collect all files that were used with execution: configs (except personal), logs, generated scripts and everything else. Some of important artifacts are:
Exit codesTaurus exit code signifies the way Taurus was ended.
Notice: Don't interrupt graceful shutdown after hitting Ctrl+C once, let the tool finish its cleanup. The tool is made to be obedient, so if you will insist on interrupting by pressing Ctrl+C for the second time, it will exit immediately. This will leave background processes unterminated, remote APIs will not be informed of the interrupt and, with high probability, some puppy or kitten might start crying. So let the tool shutdown gracefully, be patient. |
On this page:
Quick Links: |