Skip to main content

easily run python unit tests

Project description

Pyt

Pyt is a lightweight wrapper around Python's unittest module that adds some nice features and enhancements over the stock unittest module.

Quickstart

Pyt overrides unittest's built-in pathfinding to be smarter and less verbose, so you can match tests using prefix matching which makes running a test like:

$ python -m unittest tests.foo_test.BarTestCase.test_che

as simple as:

$ pyt foo.Bar.che

But it's even less verbose if you want it to be, pyt can reach into the modules and classes to do its matching, so you don't even need to specify the module and class if you don't want to:

$ pyt che

More examples

To run all the Happy tests:

$ pyt Happy

To run all the newmodule tests:

$ pyt newmodule

To run more than one test:

$ pyt test1 test2 ...

To run every test pyt can find:

$ pyt

And the way I like to run all tests in the current directory:

$ pyt -vb

Which can also be written:

$ pyt --verbose --buffer

Flags

To see everything pyt can do

$ pyt --help

--warnings

This will convert warnings into errors.

$ pyt --warnings

--rerun

If your last testrun had failing tests this will rerun only the tests that failed.

$pyt --rerun

Things to be aware of

pyt uses Python's PEP 8 style conventions

pyt uses Python's code styling conventions to decide what is the module and class, so, given input like this:

$ pyt foo.bar.Baz.che

pyt will consider foo.bar to be the module, Baz to be a class (because it starts with a capital letter), and che to be a method (since it comes after the class).

Likewise, pyt uses unittest conventions, so a test module should end with _test (eg, foo.bar_test) or start with test (eg, test_foo.py) and a TestCase class should extend unittest.TestCase, and test methods should start with test_ (eg, test_che).

Vague input can cause pyt to run more tests than you expect

So if you have something like this:

project/
  __init__.py
  user.py
  foo/
    __init__.py
    user.py
  tests/
    __init__.py
    user_test.py
    foo/
      __init__.py
      user_test.py

And you want to run tests for foo.user and you run:

$ pyt user

it will run both tests/user_test and tests.foo.user_test, the solution is to just be more verbose when you have to be:

$ pyt foo.user

Environment Variables

If you are running the tests within pyt, you might notice there is an environment variable PYT_TEST_COUNT that contains the count of how many tests pyt found to run.

Installation

Use pip:

$ pip install pyt

You can also get it directly from the repo:

$ pip install --upgrade git+https://github.com/Jaymon/pyt#egg=pyt

Testing

Testing on MacOS:

$ python -m unittest discover

Or, if you're really brave, you can use pyt to test itself:

$ python -m pyt tests -df

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

pyt-1.4.0.tar.gz (23.6 kB view details)

Uploaded Source

Built Distribution

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

pyt-1.4.0-py3-none-any.whl (19.8 kB view details)

Uploaded Python 3

File details

Details for the file pyt-1.4.0.tar.gz.

File metadata

  • Download URL: pyt-1.4.0.tar.gz
  • Upload date:
  • Size: 23.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.14

File hashes

Hashes for pyt-1.4.0.tar.gz
Algorithm Hash digest
SHA256 09a12322f7027953b1195ea657b2b82f3c4d0b38df622bdaa6c8ff29674be216
MD5 dfbffaa124a00e67973657b1b7a56d90
BLAKE2b-256 a6ab8dc7ce297f520debde730c203b23050f7b309eeed2a740a20756193a4fe4

See more details on using hashes here.

File details

Details for the file pyt-1.4.0-py3-none-any.whl.

File metadata

  • Download URL: pyt-1.4.0-py3-none-any.whl
  • Upload date:
  • Size: 19.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.14

File hashes

Hashes for pyt-1.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 67f2705a81c02039eb11f5fde898e56c2add39b7909b326db36b2fc04e547393
MD5 bbb382e12fd2cffbf832f15bd06bd936
BLAKE2b-256 a29072dbe159af112544bf7194e1e0eccb3f5011328cd0503237eb1914d9b21c

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