Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/gkbrk/testsimple-py
Python testing framework inspired by Perl's Test::Simple
https://github.com/gkbrk/testsimple-py
perl python test
Last synced: about 2 months ago
JSON representation
Python testing framework inspired by Perl's Test::Simple
- Host: GitHub
- URL: https://github.com/gkbrk/testsimple-py
- Owner: gkbrk
- License: mpl-2.0
- Created: 2019-05-08T22:26:49.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2019-06-07T13:48:44.000Z (over 5 years ago)
- Last Synced: 2024-11-16T19:21:30.794Z (2 months ago)
- Topics: perl, python, test
- Language: Python
- Size: 6.84 KB
- Stars: 1
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
- [NAME](#NAME)
- [SYNOPSIS](#SYNOPSIS)
- [DESCRIPTION](#DESCRIPTION)
- [INTERFACE](#INTERFACE)
- [plan](#plan)
- [ok](#ok)
- [done\_testing](#done_testing)
- [diag](#diag)
- [RUNNING THE TESTS](#RUNNING-THE-TESTS)# NAME
testsimple - Python testing framework inspired by Perl's Test::Simple
# SYNOPSIS
```
from testsimple import *plan(tests=1)
ok(42 > 10, "Math still works")
```# DESCRIPTION
This module tries to replicate the Test::Simple API. It produces output
in the TAP protocol.# INTERFACE
## plan
Declares the plan for the tests. While setting the number of tests
manually might seem cumbersome, it comes in handy when the test gets in
an inconsistent state and passes too more or less tests than intended.```
plan(tests=2)ok(True)
ok(True)
```## ok
**ok** is the main function of this module. It works as an assertion.
```
ok(10 > 1)
ok("Test")
ok(not None, "This should pass")ok(False, "This should fail")
```## done\_testing
**done\_testing** can be placed at the bottom of your test script. The
testsimple module keeps track of the tests you run, so it can generate
the plan for you automatically. This is useful if you're lazy or if your
test is very dynamic.```
import random
from testsimple import *for _ in range(random.randint(1, 20)):
ok(True)done_testing()
```## diag
Produces a diagnostic output. This is usually hidden during test runs,
but the test harness can optionally show it to the user. This
information can be useful if the tests are failing and you want to get
details.```
diag("Testing fetch_user with", username)
```# RUNNING THE TESTS
You can run the tests using any TAP-compatible test harness. An easy one
to use is *Prove*. All you need to do is put each test script in a
folder called *t*. After that, if you run the *prove* command in the
root directory of the project, it will run each test and print the
results. You can pass flags and configure the behaviour, such as running
tests in parallel or printing diagnostic output.