Reference
Command Line

Command Line

TSTyche ships with the tstyche command and a set of useful options.

Usage

When called without arguments, the tstyche command runs all test files matched by the testFileMatch patterns. To select particular files, pass one or more arguments:

# Run all tests
tstyche
 
# Only run the test files with matching path
tstyche ./path/to/first.test.ts

Only the files matched by the testFileMatch patterns can be selected. The search strings are matched with the portion of the path relative to the current directory. The matching is case insensitive.

If glob patterns (opens in a new tab) are supported in your shell, you can use them as well.

Options

Options passed through the command line override the ones from the configuration file.

An option does not take a value, if its type is not specified. Otherwise, the parsing logic of the option value depends on its type:

  • boolean is interpreted as true, if the value is omitted or set to true; or as false, if set to false,
  • string is simply a string,
  • list can hold one or several values separated by commas: --target 4.9 or --target 4.9,latest.

Relative paths are resolved relative to the current directory.

Use the --showConfig command line option to inspect the resolved configuration.

--config

  • Type: string

The path to a TSTyche configuration file.

tstyche --config ./config/tstyche.json

--failFast

  • Type: boolean

Stop running tests after the first failure.

--help

Print the list of command line options with brief descriptions and exit.

--install

Install specified versions of the typescript package and exit.

--install must be used together with the target configuration option or the --target command line option. The versions specified via the --target command line option are added, if it is provided; otherwise the versions listed in the target array in the configuration file are added.

# Install TypeScript 4.9.5
tstyche --install --target 4.9
 
# Install the specified versions of TypeScript
tstyche --install --target '5.5, latest'

--list

Print the list of supported versions of the typescript package and exit.

--listFiles

Print the list of the selected test files and exit.

--only

  • Type: string

Only run tests with matching name. The given string is matched against the name of every test() or describe() entry. The matching is case insensitive.

--only does not override the .skip run mode flag. If both --only and --skip filters select a test, it gets skipped.

tstyche --only external

--prune

Remove all installed versions the typescript package and exit.

--plugins

  • Type: list of strings

The list of plugins to use.

The following can be specified:

  • name of a package: "tstyche-plugin",
  • or a path: "./custom-plugin.js".
tstyche --plugins tstyche-plugin,./custom-plugin.js

To learn more, see the Plugins page.

--reporters

  • Type: list of strings

The list of reporters to use.

The following can be specified:

  • built-in reporter: "list" or "summary",
  • name of the package: "tstyche-reporter",
  • or a path: "./custom-reporter.js".
tstyche --reporters list,tstyche-reporter,./custom-reporter.js

To learn more, see the Reporters page.

--showConfig

Print the resolved configuration and exit.

--skip

  • Type: string

Skip tests with matching name. The given string is matched against the name of every test() or describe() entry. The matching is case insensitive.

--skip overrides the .only run mode flag. If both --skip and --only filters select a test, it gets skipped.

tstyche --skip internal

--target

  • Type: list of strings

The list of TypeScript versions to be tested on.

The following can be specified:

  • current is the version of TypeScript currently installed in the project,
  • minor releases, like 5.2 or 4.9, resolves to the latest version in the serries (for example, 4.9 resolves to version 4.9.5),
  • patch releases, like 5.3.2 or 4.8.4,
  • beta, latest, next or rc distribution tags (opens in a new tab) of the typescript package.
# Run tests using TypeScript 4.9.5
tstyche --target 4.9
 
# Run tests using the latest version of TypeScript
tstyche --target latest
 
# Test on all specified versions of TypeScript
tstyche --target '5.0, 5.3.2, next'

Ranges

Version ranges allow testing on a range of TypeScript versions. The range must be specified using an operator and a minor version.

Supported operators:

  • >, greater than,
  • >=, greater than or equal,
  • <, less than,
  • <=, less than or equal.

For example, the range >=5.5 gets expanded to: 5.5, 5.6, 5.7 and so on. In the future this list will include newly released versions as well.

To set an upper bound, the intersection of two ranges can be used: >=5.0 <5.3. Here only 5.0, 5.1 and 5.2 are be included.

# Ranges and versions can be combined
tstyche --target '>=5.0 <5.3, 5.4.2, >5.5'

Use the --list command line option to inspect the list of supported versions.

--tsconfig

  • Type: string

The look up strategy to be used to find the TSConfig file.

The following can be specified:

  • findup, find the nearest tsconfig.json that includes a particular test file,
  • ignore, do not look for any tsconfig.json and use the defaults,
  • or, if a path is specified, simply load tsconfig.json from that path.
tstyche --tsconfig ./tsconfig.test.json

If TSConfig file is not found or does not include a test file in question, the default compiler options are set.

--update

Fetch the typescript package metadata from the registry and exit.

The list of available TypeScript versions is updated every two hours. Use this option, if you want to force the update.

--version

Print the TSTyche version number and exit.

--watch

Watch for changes and rerun related test files. Current implementation is watching the TSTyche configuration file and the test files for changes.

Files are watched recursively using the fs.watch() (opens in a new tab) method that relies on file system events. In some cases this feature is not available (opens in a new tab). For example, it does not work on network file systems. Also note that recursive watch support was added for the Linux systems only since Node.js 20.