File: README.md

package info (click to toggle)
python-pycotap 1.3.1-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 124 kB
  • sloc: python: 436; makefile: 39; sh: 5
file content (170 lines) | stat: -rw-r--r-- 5,504 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
# pycotap: Tiny Python TAP Test Runner

[![Build](https://github.com/remko/pycotap/actions/workflows/build.yml/badge.svg)](https://github.com/remko/pycotap/actions/workflows/build.yml)
[![Coverage](https://remko.github.io/pycotap/ci/coverage/coverage.svg)](https://remko.github.io/pycotap/ci/coverage)
[![PyPI
version](https://badge.fury.io/py/pycotap.svg)](https://badge.fury.io/py/pycotap)

`pycotap` is a simple Python test runner for `unittest` that outputs
[Test Anything Protocol](http://testanything.org) results to standard
output (similar to what [`tape`](https://www.npmjs.com/package/tape)
does for JavaScript).

Contrary to other TAP runners for Python, `pycotap` ...

- ... prints TAP (and *only* TAP) to standard output instead of to a
  separate file, allowing you to pipe it directly to TAP pretty printers
  and processors (such as the ones listed on the [`tape`
  page](https://www.npmjs.com/package/tape#pretty-reporters)). By piping
  it to other consumers, you can avoid the need to add specific test
  runners to your test code. Since the TAP results are printed as they
  come in, the consumers can directly display results while the tests
  are run.
- ... only contains a TAP reporter, so no parsers, no frameworks, no
  dependencies, ...
- ... is configurable: you can choose how you want the test output and
  test result diagnostics to end up in your TAP output (as TAP
  diagnostics, YAML blocks, or attachments). The defaults are optimized
  for a [Jenkins](http://jenkins-ci.org) based flow.

> Nice work with pycotap! I took a "kitchen sink" approach with tappy so
> I'm glad someone made a no dependency TAP unittest runner. :) -- [Matt
> Layman](http://www.mattlayman.com), author of
> [tappy](http://tappy.readthedocs.org/en/latest/)

## Installation

You can install the package directly from
[PIP](https://pypi.python.org):

    pip install pycotap

Alternatively, you can build and install the package yourself:

    python setup.py install

Since the module just consists of one file, you can also just drop the
file into your project somewhere.

## Usage

Create a test suite, and run it with `-mpycotap` flag.

For example, given the following test suite in `test_example.py`:

``` python
import unittest

class MyTests(unittest.TestCase):
  def test_that_it_passes(self):
    self.assertEqual(0, 0)

  @unittest.skip("not finished yet")
  def test_that_it_skips(self): 
    raise Exception("Does not happen")

  def test_that_it_fails(self):
    self.assertEqual(1, 0)
```

Running the test prints the TAP results to standard output:

    $ python -mpycotap test_example
    not ok 1 __main__.MyTests.test_that_it_fails
    ok 2 __main__.MyTests.test_that_it_passes
    ok 3 __main__.MyTests.test_that_it_skips # Skipped: not finished yet
    1..3

Alternatively, you can pipe the test to any TAP pretty printer, such as
[faucet](https://github.com/substack/faucet) or
[tap-dot](https://github.com/scottcorgan/tap-dot):

    $ python -mpycotap test_example  | faucet
    ⨯ __main__.MyTests.test_that_it_fails
    ✓ __main__.MyTests.test_that_it_passes
    ✓ __main__.MyTests.test_that_it_skips # Skipped: not finished yet
    ⨯ fail  1


    $ python -mpycotap test_example  | tap-dot 
    x  ..  

      3 tests
      2 passed
      1 failed  

      Failed Tests:   There was 1 failure
        x __main__.MyTests.test_that_it_fails

### Bring your own `__main__`

You can create a `TAPTestRunner` yourself (e.g. to pass custom
parameters), and use it to drive your own main function.

For example, the following can be added to the test example suite above
to create a runnable Python script:

``` python
if __name__ == '__main__':
  from pycotap import TAPTestRunner
  suite = unittest.TestLoader().loadTestsFromTestCase(MyTests)
  TAPTestRunner().run(suite)
```

This script can now be run:

    $ python ./test_example.py 
    not ok 1 __main__.MyTests.test_that_it_fails
    ok 2 __main__.MyTests.test_that_it_passes
    ok 3 __main__.MyTests.test_that_it_skips # Skipped: not finished yet
    1..3

## API

### `TAPTestRunner([message_log], [test_output_log])`

- `message_log` (Optional; Default: `LogMode.LogToYAML`):  
  What to do with test messages (e.g. assertion failure details). See
  `LogMode` for possible values.
- `test_output_log` (Optional; Default: `LogMode.LogToDiagnostics`):  
  What to do with output printed by the tests. See `LogMode` for
  possible values.

### `LogMode`

Enumeration of different destinations to log information. Possible
values:

- `LogMode.LogToError`: Log all output to standard error. This means no
  output information will end up in the TAP stream, and so will not be
  processed by any processors.
- `LogMode.LogToDiagnostics`: Put output in a diagnostics message after
  the test result. This means all output will end up in the TAP stream.
  How this is displayed depends on the processor.
- `LogMode.LogToYAML`: Put output in a YAML block.
- `LogMode.LogToAttachment`: Put output in a downloadable attachment in
  a YAML block. This is an extension supported by e.g.
  [`tap4j`](http://tap4j.org).

## Changelog

### 1.3.0 (2023-04-28)

- Fix problem with garbage output (thanks [wjt](https://github.com/wjt))

### 1.1.0 (2015-07-29)

- Don't print message for expected failures
- Fix problem with unexpected success

### 1.0.1 (2015-07-28)

- Fix problem with tests that cache `sys.std*` output streams

### 1.0.0 (2015-01-24)

- Initial stable version

### 0.1.0 (2015-01-21)

- Initial version