Skip to main content

TUI runner for `pytest` tests

Project description

pytest-tui-run

TUI test runner for pytest.

pytest-tui-run in action

Motivation

Do you like running pytest from the terminal, but find it difficult to run a subset of tests? Do you like VS Code's test tree view, but hate using the mouse? Then pytest-tui-run is for you: it combines the best of both worlds by showing you the collected test tree, but allows you to use your keyboard to select and run tests. Even better, it comes with vim-like keybindings by default, which are fully configurable.

Alternatives

There are similar projects, but none with the same scope.

  • pytest-explorer. TUI for exploring pytest tests. No tree view.
  • pytest-tui. TUI for exploring pytest results. No test running.
  • VS Code Testing View. GUI for running tests in a tree view. Plugins for multiple languages and test frameworks. Mouse centric and works only in VS Code.
  • Neotest plugin for Neovim. TUI for running tests in a tree view. Plugins for multiple languages and test frameworks. Works only in Neovim.

Philosophy

Don't reinvent the wheel: everything that can be delegated to pytest, is delegated to pytest. This is to keep the plugin as lightweight as possible to minimize the burden of maintaining. In practice this means that the plugin mostly just modifies the user-given pytest arguments, and then runs pytest with those arguments.

Installation

The package is distributed through PyPI, so simply use your favorite package manager. For example using pip:

pip install pytest-tui-run

Usage

This is a pytest plugin, so you can start it from the terminal by

pytest --tui-run

Just give it the arguments you would normally give to plain pytest. Another option is to start the app directly:

pytest-tui-run

There are two ways to run the (selected) tests:

Run tests in TUI

Press r to run the (selected) tests directly in the TUI. This shows you the output and marks the test results in the tree.

Run tests in CLI

Press R to run the (selected) tests in CLI. This exits the TUI and prints you the proper pytest command to run.

Configuration

The default configuration includes all the available configuration options. A schema is included for validation. Both of these are included with the package to ensure compatible versions. To get started, run

pytest --tui-run --init-config

This will copy the default config to your config directory (usually ~/.config/pytest-tui-run/) and create a symlink to the schema.

You may use your favorite validation tool, but a schema directive for Taplo (in VS Code the Even Better TOML plugin) is included in the config file by default. In other words, if you have a Taplo-compatible editor, you should get schema validation out of the box, assuming you have properly symlinked the schema file.

Contributing

Contributions are welcome. See CONTRIBUTING.md for details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pytest_tui_run-0.1.0rc3.tar.gz (26.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pytest_tui_run-0.1.0rc3-py3-none-any.whl (32.8 kB view details)

Uploaded Python 3

File details

Details for the file pytest_tui_run-0.1.0rc3.tar.gz.

File metadata

  • Download URL: pytest_tui_run-0.1.0rc3.tar.gz
  • Upload date:
  • Size: 26.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.19 {"installer":{"name":"uv","version":"0.11.19","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"13","id":"trixie","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for pytest_tui_run-0.1.0rc3.tar.gz
Algorithm Hash digest
SHA256 694c325e145bb5f7eb98f5e1fc93d163c626a62f8c6e3e383e6ded5d65abe9eb
MD5 1e896e6805633d76687c2d1354ce7865
BLAKE2b-256 a8c8bbad9602b3f2813717fc33b30e567b0e0460afe1c1bc41a55d68ad1cfa2d

See more details on using hashes here.

File details

Details for the file pytest_tui_run-0.1.0rc3-py3-none-any.whl.

File metadata

  • Download URL: pytest_tui_run-0.1.0rc3-py3-none-any.whl
  • Upload date:
  • Size: 32.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.19 {"installer":{"name":"uv","version":"0.11.19","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"13","id":"trixie","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for pytest_tui_run-0.1.0rc3-py3-none-any.whl
Algorithm Hash digest
SHA256 a03da94447ea777b1e9c09398328dfe40645702151961294208f399ea0c7d3f4
MD5 14b4817054766b11afbc5a5137b88eb4
BLAKE2b-256 fb37d164a2310dd22999c05e611c1d1bc43ed6a9dd9494b2cb2799ba9b921ce5

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page