A Python test framework, written in Rust.
Karva aims to be an efficient alternative to pytest and unittest.
While we do not yet support all of pytest's features, we aim to gradually add support for pytest alternatives as we add features.
Karva is available as karva on PyPI.
Use karva directly with uvx:
uvx karva test
uvx karva versionOr install karva with uv, or pip:
# With uv.
uv tool install karva@latest
# Add karva to your project.
uv add --dev karva
# With pip.
pip install karvaBy default, Karva will respect your .gitignore files when discovering tests in specified directories.
To run your tests, try any of the following:
# Run all tests.
karva test
# Run tests in a specific directory.
karva test tests/
# Run tests in a specific file.
karva test tests/test_example.pyHere is a small example usage
def test_pass():
assert True
def test_fail():
assert False, "This test should fail"
def test_error():
raise ValueError("This is an error")Running karva:
uv run karva test tests/Provides the following output:
test tests.test::test_pass ... ok
test tests.test::test_fail ... FAILED
test tests.test::test_error ... FAILED
diagnostics:
error[test-failure]: Test `test_fail` failed
--> tests/test.py:5:5
|
5 | def test_fail():
| ^^^^^^^^^
6 | assert False, "This test should fail"
|
info: Test failed here
--> tests/test.py:6:5
|
5 | def test_fail():
6 | assert False, "This test should fail"
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
info: Error message: This test should fail
error[test-failure]: Test `test_error` failed
--> tests/test.py:9:5
|
9 | def test_error():
| ^^^^^^^^^^
10 | raise ValueError("This is an error")
|
info: Test failed here
--> tests/test.py:10:5
|
9 | def test_error():
10 | raise ValueError("This is an error")
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
info: Error message: This is an error
test result: FAILED. 1 passed; 2 failed; 0 skipped; finished in 8ms
Contributions are welcome! See CONTRIBUTING.md for more information.
You can also join us on Discord