Skip to content

Command line usage

Use ui5-test-runner --help to display the list of options. The mapping between v1 options and v2 can be found here.

Check additional information below.

Parameter Mode Description Default Value
-V, --version output the version number
--capabilities ๐Ÿงช Capabilities tester for browser
-u, --url <url...> ๐Ÿ”— URL of the testsuite / page to test
-c, --cwd <path> ๐Ÿ’ป๐Ÿ”—๐Ÿงช Set working directory current working directory
--config <json> ๐Ÿ’ป๐Ÿ”—๐Ÿงช Configuration file (relative to cwd) "ui5-test-runner.json"
--port <port> ๐Ÿ’ป๐Ÿ”—๐Ÿงช Port to use (0 to use any free one) 0
-r, --report-dir <path> ๐Ÿ’ป๐Ÿ”—๐Ÿงช Directory to output test reports (relative to cwd) "report"
-pt, --page-timeout <timeout> ๐Ÿ’ป๐Ÿ”—๐Ÿงช๐Ÿ“ก Limit the page execution time, fails the page if it takes longer than the timeout (0 means no timeout) 0
-f, --fail-fast [flag] ๐Ÿ’ป๐Ÿ”—๐Ÿงช๐Ÿ“ก Stop the execution after the first failing page false
-fo, --fail-opa-fast [flag] ๐Ÿ’ป๐Ÿ”—๐Ÿ“ก Stop the OPA page execution after the first failing test false
-k, --keep-alive [flag] ๐Ÿ’ป๐Ÿ”—๐Ÿงช Keep the server alive false
-l, --log-server [flag] ๐Ÿ’ป๐Ÿ”—๐Ÿงช๐Ÿ“ก Log inner server traces false
-p, --parallel <count> ๐Ÿ’ป๐Ÿ”—๐Ÿงช Number of parallel tests executions 2
-b, --browser <command> ๐Ÿ’ป๐Ÿ”—๐Ÿงช๐Ÿ“ก Browser instantiation command (relative to cwd or use $/ for provided ones) "$/puppeteer.js"
--browser-args <argument...> ๐Ÿ’ป๐Ÿ”—๐Ÿงช๐Ÿ“ก Browser instantiation command parameters (use -- instead)
--alternate-npm-path <path> ๐Ÿ’ป๐Ÿ”—๐Ÿ“ก Alternate NPM path to look for packages (priority: local, alternate, global)
--no-npm-install ๐Ÿ’ป๐Ÿ”—๐Ÿงช๐Ÿ“ก Prevent any NPM install (execution may fail if a dependency is missing)
-bt, --browser-close-timeout <timeout> ๐Ÿ’ป๐Ÿ”—๐Ÿงช๐Ÿ“ก Maximum waiting time for browser close 2000
-br, --browser-retry <count> ๐Ÿ’ป๐Ÿ”—๐Ÿงช๐Ÿ“ก Browser instantiation retries : if the command fails unexpectedly, it is re-executed (0 means no retry) 1
-oi, --output-interval <interval> ๐Ÿ’ป๐Ÿ”—๐Ÿงช๐Ÿ“ก Interval for reporting progress on non interactive output (CI/CD) (0 means no output) 30000
--offline [flag] ๐Ÿ’ป๐Ÿ”—๐Ÿงช๐Ÿ“ก Limit network usage (implies --no-npm-install) false
--env <name=value...> ๐Ÿ’ป๐Ÿ”—๐Ÿงช๐Ÿ“ก Set environment variable
--callback-host <host> ๐Ÿ’ป๐Ÿ”—๐Ÿงช๐Ÿ“ก [๐Ÿ’ฃ use carefully] Hostname for callbacks "localhost"
--webapp <path> ๐Ÿ’ป๐Ÿ”— Base folder of the web application (relative to cwd) "webapp"
-pf, --page-filter <regexp> ๐Ÿ’ป๐Ÿ”—๐Ÿ“ก Filter out pages not matching the regexp
-pp, --page-params <params> ๐Ÿ’ป๐Ÿ”—๐Ÿ“ก Add parameters to page URL
--page-close-timeout <timeout> ๐Ÿ’ป๐Ÿ”—๐Ÿ“ก Maximum waiting time for page close 250
-t, --global-timeout <timeout> ๐Ÿ’ป๐Ÿ”—๐Ÿ“ก Limit the pages execution time, fail the page if it takes longer than the timeout (0 means no timeout) 0
--screenshot [flag] ๐Ÿ’ป๐Ÿ”—๐Ÿ“ก Take screenshots during the tests execution (if supported by the browser) true
--no-screenshot ๐Ÿ’ป๐Ÿ”—๐Ÿ“ก Disable screenshots during the tests execution (but not on failure, see --screenshot-on-failure)
--screenshot-on-failure <flag> ๐Ÿ’ป๐Ÿ”—๐Ÿ“ก Take a screenshot when a test fails (even if --screenshot is false) true
-st, --screenshot-timeout <timeout> ๐Ÿ’ป๐Ÿ”—๐Ÿ“ก Maximum waiting time for browser screenshot 5000
-so, --split-opa [flag] ๐Ÿ’ป๐Ÿ”—๐Ÿ“ก Split OPA tests using QUnit modules false
-rg, --report-generator <path...> ๐Ÿ’ป๐Ÿ”—๐Ÿ“ก Report generator paths (relative to cwd or use $/ for provided ones) ["$/report.js"]
--progress-page <path> ๐Ÿ’ป๐Ÿ”—๐Ÿ“ก Progress page path (relative to cwd or use $/ for provided ones) "$/report/default.html"
--coverage [flag] ๐Ÿ’ป๐Ÿ”—๐Ÿ“ก Enable or disable code coverage
--no-coverage ๐Ÿ’ป๐Ÿ”—๐Ÿ“ก Disable code coverage
-cs, --coverage-settings <path> ๐Ÿ’ป๐Ÿ”—๐Ÿ“ก Path to a custom .nycrc.json file providing settings for instrumentation (relative to cwd or use $/ for provided ones) "$/.nycrc.json"
-ctd, --coverage-temp-dir <path> ๐Ÿ’ป๐Ÿ”— Directory to output raw coverage information to (relative to cwd) ".nyc_output"
-crd, --coverage-report-dir <path> ๐Ÿ’ป๐Ÿ”— Directory to store the coverage report files (relative to cwd) "coverage"
-cr, --coverage-reporters <reporter...> ๐Ÿ’ป๐Ÿ”—๐Ÿ“ก List of nyc reporters to use (text is always used) ["lcov","cobertura"]
-ccb, --coverage-check-branches <percent> ๐Ÿ’ป๐Ÿ”—๐Ÿ“ก What % of branches must be covered 0
-ccf, --coverage-check-functions <percent> ๐Ÿ’ป๐Ÿ”—๐Ÿ“ก What % of functions must be covered 0
-ccl, --coverage-check-lines <percent> ๐Ÿ’ป๐Ÿ”—๐Ÿ“ก What % of lines must be covered 0
-ccs, --coverage-check-statements <percent> ๐Ÿ’ป๐Ÿ”—๐Ÿ“ก What % of statements must be covered 0
-crs, --coverage-remote-scanner <path> ๐Ÿ’ป๐Ÿ”—๐Ÿ“ก Scan for files when all coverage is requested "$/scan-ui5.js"
-s, --serve-only [flag] ๐Ÿ’ป๐Ÿ”— Serve only false
-w, --watch [flag] ๐Ÿ’ป๐Ÿ”— Monitor the webapp folder (or the one specified with --watch-folder) and re-execute tests on change false
--watch-folder <path> ๐Ÿ’ป๐Ÿ”— Folder to monitor with watch (enables --watch if not specified)
--start <command> ๐Ÿ’ป๐Ÿ”— Start command (might be an NPM script or a shell command)
--start-wait-url <command> ๐Ÿ’ป๐Ÿ”— URL to wait for (๐Ÿ”— defaulted to first url)
--start-wait-method <method> ๐Ÿ’ป๐Ÿ”— HTTP method to check the waited URL "GET"
--start-timeout <timeout> ๐Ÿ’ป๐Ÿ”— Maximum waiting time for the start command (based on when the first URL becomes available) 5000
--end <script> ๐Ÿ’ป๐Ÿ”— End script (will receive path to job.js)
--end-timeout <timeout> ๐Ÿ’ป๐Ÿ”— Maximum waiting time for the end script 5000
--ui5 <url> ๐Ÿ’ป๐Ÿ“ก UI5 url "https://ui5.sap.com"
--disable-ui5 [flag] ๐Ÿ’ป๐Ÿ“ก Disable UI5 mapping (also disable libs) false
--libs <lib...> ๐Ÿ’ป๐Ÿ“ก Library mapping (<relative>=<path> or <path>)
--mappings <mapping...> ๐Ÿ’ป๐Ÿ“ก Custom mapping (<match>=<file|url>(<config>))
--cache <path> ๐Ÿ’ป๐Ÿ“ก Cache UI5 resources locally in the given folder (empty to disable)
--preload <library...> ๐Ÿ’ป๐Ÿ“ก Preload UI5 libraries in the cache folder (only if --cache is used)
--testsuite <path> ๐Ÿ’ป Path of the testsuite file (relative to webapp, URL parameters are supported) "test/testsuite.qunit.html"
-cp, --coverage-proxy [flag] ๐Ÿ”— [โš ๏ธ experimental] use internal proxy to instrument remote files false
-cpi, --coverage-proxy-include <regexp> ๐Ÿ”— [โš ๏ธ experimental] urls to instrument for coverage ".*"
-cpe, --coverage-proxy-exclude <regexp> ๐Ÿ”— [โš ๏ธ experimental] urls to ignore for coverage "/((test-)?resources\|tests?)/"
--batch <specification...> Batch specification
--batch-id <id> Batch id (used for naming report folder)
--batch-label <label> Batch label (used while reporting on execution)
--if <condition> Condition runner execution
-h, --help display help for command

Meaning of parameter values :

  • [value] : value is optional (usually boolean)
  • <value> : value is expected
  • <value...> : more than one value can be set
  • <timeout> : expressed either as a single numeric (ms) or with the following suffixes :
  • <number>ms
  • <number>s or <number>sec for seconds
  • <number>m or <number>min for minutes

Options availability depends on the mode :

  • ๐Ÿ’ป when serving and testing (legacy mode)
  • ๐Ÿ”— when testing remote pages (--url)
  • ๐Ÿงช when testing browser capabilities (--capabilities)
  • ๐Ÿ“ก when using batch mode, the parameter is transmitted from main command to batch item

For browser arguments, it is recommended to use -- and pass them after. In the configuration file, use browserArgs.