run

Execute tests specified by the project, and store the results in the project’s run log database.

Synopsis

provengo run [--dry] [--run-source PATH] <path-to-project>

Description

Execute test scenarios directly on the tested system, using scenarios defined by the Provengo project. Test scenarios come from a run source, which is specified by the optional Run Source parameter (--run-source/-s). Execution results are stored in the project’s test execution database.

In addition to executing scenarios, the Provengo tool can run various Lifecycle Scripts for set-up, tear-down, etc.

Run Source

Several run sources are available:

:random

The default mode. Randomly selects a single run from the model. This source is useful while developing the model, or when trying out some code changes. Often coupled with --dry to prevent actuations from actually happening.

:log

Re-runs a previous run from the run log database. The run id must be specified, using the --run-id parameter.

filename.json

A run file. These are commonly generated by the sample and ensemble run modes, or are downloaded from an execution report. It it possible to run only a specific run from the file, using --run-id and the run’s number (1-based).

Examples

Run a random test

These type of runs are often useful when you start working on a model, and want to quickly check how it behaves.

The following lines are all equivalent

provengo run --run-source :random path/to/project (1)
provengo run -s :random path/to/project (2)
provengo run path/to/project (3)
1 Specifying the run source to be a random run.
2 Specifying the run source to be a random run using abbreviated syntax.
3 Not specifying the run source, so it defaults to :random.

Same as above, but skip actuations. Useful when you want to see what would happen if you ran the tests, but not actually have that happen.

provengo run --dry path/to/project

Run Tests from a File

Execute all tests stored in customer-area-checks.json.

provengo run -s customer-area-checks.json path/to/project

Execute test number 42 from file customer-area-checks.json. The number of the first run is 1.

provengo run -s customer-area-checks.json --run-id 42 path/to/project

Re-Run a Test from the Log

Each run in the log has an id. This id is shown in the Test Log Report (see report run mode). The following snippet re-runs test number 42.

provengo run -s :log --run-id 42 path/to/project
Using the :log run source requires specifying a --run-id.

Parameters

-s/--run-source RUN_SOURCE

Where to bring the runs from. Either :random, :log, or a run filename. See Run Source.

--random-seed RANDOM_SEED

Seed number for random number generation.

--dry

Do not actuate external systems.

--run-id RUN_ID

Specify a specific run in the current run source. For :log it’s the run id, for files it the 1-based index of the run.

-o/--output-file OUTPUT_FILE

Run result location.

-m/--max-depth MAX-DEPTH

Maximum number of events in a single test. Applies only when using the :random run source.

Lifecycle Scripts

See Scripts Page for more details.

--setup SETUP

A command to run before the tests start. Typically, used for bringing the test system up.

--before-test BEFORE_TEST

A command to run before each test.

--after-success AFTER_SUCCESS

A command to run after a successful test.

--after-failure AFTER_FAILURE

A command to run after a test failed test. Typically, cleans up and resets the test system.

--teardown TEARDOWN

A command to run after all tests are executed. Typically, cleans up and frees resources.

Selenium Related Parameters

--selenium-server SELENIUM_SERVER

URL of a selenium server for driving web UIs.

--action-delay ACTION_DELAY

Delay between Selenium actions, in milliseconds.

--selenium-browser

Browser to use for Selenium tests. One of chrome (default), firefox, edge, safari.

--show-sessions

Show Selenium sessions. If this flag is not set we run in 'headless' mode.

--max-windows

Maximize browser windows when opened.

Safari browsers do not support headless mode - they must run with a visible window. Thus, when using a Safari browser, the controlled windows are shown, regardless of the --show-sessions switch.
--tn5250 TN5250_SERVER

URL of a tn5250 Provengo’s terminal for driving AS400/IBM System I.