Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Scenarios documentation #49

Merged
merged 25 commits into from
Jul 14, 2020
Merged
Show file tree
Hide file tree
Changes from 24 commits
Commits
Show all changes
25 commits
Select commit Hold shift + click to select a range
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
75 changes: 71 additions & 4 deletions src/data/markdown/docs/01 guides/02 Using k6/05 Options.md
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ Options allow you to configure how k6 will behave during test execution.
| [Config](#config) | Specify the config file in JSON format to read the options values |
na-- marked this conversation as resolved.
Show resolved Hide resolved
| [Discard Response Bodies](#discard-response-bodies) | Specify if response bodies should be discarded |
| [Duration](#duration) | A string specifying the total duration a test run should be run for |
na-- marked this conversation as resolved.
Show resolved Hide resolved
| [Execution Segment](#execution-segment) | Limit execution to a segment of the total test |
| [Extension Options](#extension-options) | An object used to set configuration options for third-party collectors |
| [Hosts](#hosts) | An object with overrides to DNS resolution |
| [HTTP Debug](#http-debug) | Log all HTTP requests and responses |
Expand All @@ -33,6 +34,7 @@ Options allow you to configure how k6 will behave during test execution.
| [Paused](#paused) | A boolean specifying whether the test should start in a paused state |
| [Results Output](#results-output) | Specify the results output |
| [RPS](#rps) | The maximum number of requests to make per second |
| [Scenarios](#scenarios) | Define advanced execution scenarios |
| [Setup Timeout](#setup-timeout) | Specify how long the `setup()` function is allow to run before it's terminated |
| [Skip TLS Verification](#skip-tls-verification) | A boolean specifying whether should ignore TLS verifications |
| [Stages](#stages) | A list of objects that specify the target number of VUs to ramp up or down |
Expand Down Expand Up @@ -316,6 +318,34 @@ export let options = {
</div>


<h3 id="execution-segment">Execution Segment</h3>

> _New in v0.27.0_

These options specify how to partition the test run and which segment to run.
If defined, k6 will scale the number of VUs and iterations to be run for that
segment, which is useful in distributed execution. Available in `k6 run` and
`k6 cloud` commands.

| Env | CLI | Code / Config file | Default |
|-----|--------------------------------|----------------------------|---------|
| N/A | `--execution-segment` | `executionSegment` | `"0:1"` |
| N/A | `--execution-segment-sequence` | `executionSegmentSequence` | `"0,1"` |

For example, to run 25% of a test, you would specify `--execution-segment '25%'`,
which would be equivalent to `--execution-segment '0:1/4'`, i.e. run the first
1/4 of the test.
To ensure that each instance executes a specific segment, also specify the full
segment sequence, e.g. `--execution-segment-sequence '0,1/4,1/2,1'`.
This way one instance could run with `--execution-segment '0:1/4'`, another with
`--execution-segment '1/4:1/2'`, etc. and there would be no overlap between them.

In v0.27.0 this distinction is not very important, but it will be required
in future versions when support for test data partitioning is added.

<!-- TODO: Add more examples, link to a standalone page? -->


<h3 id="hosts">Hosts</h3>

An object with overrides to DNS resolution, similar to what you can do with `/etc/hosts` on
Expand Down Expand Up @@ -388,8 +418,8 @@ $ k6 run --include-system-env-vars ~/script.js
A number specifying a fixed number of iterations to execute of the script, as opposed to specifying
a duration of time during which the script would run in a loop.
\*Note: The number of iterations
is split between all VUs. Available in `k6 run` command (not yet supported for cloud executed
tests using the `k6 cloud` command).
is split between all VUs. Available in the `k6 run` and since v0.27.0 in the
`k6 cloud` command as well.

| Env | CLI | Code / Config file | Default |
|-----------------|----------------------|--------------------|---------|
Expand Down Expand Up @@ -636,11 +666,48 @@ export let options = {

</div>


> ### Cloud runs
>
> There are a couple of considerations with this option when running cloud tests. The option is set per load generator which means that the value you set in the options object of your test script will be multiplied by the number of load generators your test run is using. At the moment we are hosting 300 VUs per load generator instance. In practice that means that if you set the option for 100 rps, and run a test with 1000 VUs, you will spin up 4 load gen instances and effective rps limit of your test run will be 400


<h3 id="scenarios">Scenarios</h3>

Define one or more execution patterns, with various VU and iteration scheduling
settings, running different exported functions (besides `default`!), using different
environment variables, tags, and more.

See the [Scenarios](/using-k6/scenarios) article for details and more examples.

Available in `k6 run` and `k6 cloud` commands.

| Env | CLI | Code / Config file | Default |
|-----|-----|--------------------|-----------------|
| N/A | N/A | `scenarios` | `null` |

<div class="code-group" data-props='{"labels": [], "lineNumbers": [true]}'>

```js
export let options = {
scenarios: {
my_api_scenario: { // arbitrary scenario name
executor: 'ramping-vus',
startVUs: 0,
stages: [
{ duration: '5s', target: 100 },
{ duration: '5s', target: 0 },
],
gracefulRampDown: '10s',
env: { MYVAR: 'example' },
tags: { my_tag: 'example' },
}
}
};
```

</div>


<h3 id="setup-timeout">Setup Timeout</h3>

Specify how long the `setup()` function is allow to run before it's terminated and the test fails.
Expand Down Expand Up @@ -775,7 +842,7 @@ CLI. Available in `k6 run` and `k6 cloud` commands

| Env | CLI | Code / Config file | Default |
|------------------|-----------------|--------------------|--------------------------------------------------------------------------------------------------|
| `K6_SYSTEM_TAGS` | `--system-tags` | `systemTags` | `proto`, `subproto`, `status`, `method`, `url`, `name`, `group`, `check`, `error`, `tls_version` |
| `K6_SYSTEM_TAGS` | `--system-tags` | `systemTags` | `proto`, `subproto`, `status`, `method`, `url`, `name`, `group`, `check`, `error`, `tls_version`, `scenario` |

<div class="code-group" data-props='{"labels": [], "lineNumbers": [true]}'>

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -69,6 +69,7 @@ Currently, k6 automatically creates the following tags by default:
| `error` | a string with a non-HTTP error message (e.g. network or DNS error) |
| `error_code` | added in k6 v0.24.0, this is a number that is unique for different error types; a list of current error codes can be found at the [Error Codes](/javascript-api/error-codes) page |
| `tls_version` | the [TLS](/using-k6/protocols/ssl-tls) version |
| `scenario` | the name of the scenario where the metric was emitted |

If you choose, you could disable some of the above tags by using the `systemTags`
[option](/using-k6/options), just keep in mind that some data collectors (e.g. `cloud`)
Expand Down
Loading