Georg Brandl | 83e51f4 | 2012-10-10 16:45:11 +0200 | [diff] [blame] | 1 | :keepdoctest: |
| 2 | |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 3 | :mod:`doctest` --- Test interactive Python examples |
| 4 | =================================================== |
| 5 | |
| 6 | .. module:: doctest |
| 7 | :synopsis: Test pieces of code within docstrings. |
Terry Jan Reedy | fa089b9 | 2016-06-11 15:02:54 -0400 | [diff] [blame^] | 8 | |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 9 | .. moduleauthor:: Tim Peters <tim@python.org> |
| 10 | .. sectionauthor:: Tim Peters <tim@python.org> |
| 11 | .. sectionauthor:: Moshe Zadka <moshez@debian.org> |
| 12 | .. sectionauthor:: Edward Loper <edloper@users.sourceforge.net> |
| 13 | |
Terry Jan Reedy | fa089b9 | 2016-06-11 15:02:54 -0400 | [diff] [blame^] | 14 | **Source code:** :source:`Lib/doctest.py` |
| 15 | |
| 16 | -------------- |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 17 | |
| 18 | The :mod:`doctest` module searches for pieces of text that look like interactive |
| 19 | Python sessions, and then executes those sessions to verify that they work |
| 20 | exactly as shown. There are several common ways to use doctest: |
| 21 | |
| 22 | * To check that a module's docstrings are up-to-date by verifying that all |
| 23 | interactive examples still work as documented. |
| 24 | |
| 25 | * To perform regression testing by verifying that interactive examples from a |
| 26 | test file or a test object work as expected. |
| 27 | |
| 28 | * To write tutorial documentation for a package, liberally illustrated with |
| 29 | input-output examples. Depending on whether the examples or the expository text |
| 30 | are emphasized, this has the flavor of "literate testing" or "executable |
| 31 | documentation". |
| 32 | |
| 33 | Here's a complete but small example module:: |
| 34 | |
| 35 | """ |
| 36 | This is the "example" module. |
| 37 | |
| 38 | The example module supplies one function, factorial(). For example, |
| 39 | |
| 40 | >>> factorial(5) |
| 41 | 120 |
| 42 | """ |
| 43 | |
| 44 | def factorial(n): |
| 45 | """Return the factorial of n, an exact integer >= 0. |
| 46 | |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 47 | >>> [factorial(n) for n in range(6)] |
| 48 | [1, 1, 2, 6, 24, 120] |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 49 | >>> factorial(30) |
Georg Brandl | 5c10664 | 2007-11-29 17:41:05 +0000 | [diff] [blame] | 50 | 265252859812191058636308480000000 |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 51 | >>> factorial(-1) |
| 52 | Traceback (most recent call last): |
| 53 | ... |
| 54 | ValueError: n must be >= 0 |
| 55 | |
| 56 | Factorials of floats are OK, but the float must be an exact integer: |
| 57 | >>> factorial(30.1) |
| 58 | Traceback (most recent call last): |
| 59 | ... |
| 60 | ValueError: n must be exact integer |
| 61 | >>> factorial(30.0) |
Georg Brandl | 5c10664 | 2007-11-29 17:41:05 +0000 | [diff] [blame] | 62 | 265252859812191058636308480000000 |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 63 | |
| 64 | It must also not be ridiculously large: |
| 65 | >>> factorial(1e100) |
| 66 | Traceback (most recent call last): |
| 67 | ... |
| 68 | OverflowError: n too large |
| 69 | """ |
| 70 | |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 71 | import math |
| 72 | if not n >= 0: |
| 73 | raise ValueError("n must be >= 0") |
| 74 | if math.floor(n) != n: |
| 75 | raise ValueError("n must be exact integer") |
| 76 | if n+1 == n: # catch a value like 1e300 |
| 77 | raise OverflowError("n too large") |
| 78 | result = 1 |
| 79 | factor = 2 |
| 80 | while factor <= n: |
| 81 | result *= factor |
| 82 | factor += 1 |
| 83 | return result |
| 84 | |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 85 | |
| 86 | if __name__ == "__main__": |
Guido van Rossum | 04110fb | 2007-08-24 16:32:05 +0000 | [diff] [blame] | 87 | import doctest |
| 88 | doctest.testmod() |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 89 | |
| 90 | If you run :file:`example.py` directly from the command line, :mod:`doctest` |
| 91 | works its magic:: |
| 92 | |
| 93 | $ python example.py |
| 94 | $ |
| 95 | |
| 96 | There's no output! That's normal, and it means all the examples worked. Pass |
Éric Araujo | 713d303 | 2010-11-18 16:38:46 +0000 | [diff] [blame] | 97 | ``-v`` to the script, and :mod:`doctest` prints a detailed log of what |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 98 | it's trying, and prints a summary at the end:: |
| 99 | |
| 100 | $ python example.py -v |
| 101 | Trying: |
| 102 | factorial(5) |
| 103 | Expecting: |
| 104 | 120 |
| 105 | ok |
| 106 | Trying: |
| 107 | [factorial(n) for n in range(6)] |
| 108 | Expecting: |
| 109 | [1, 1, 2, 6, 24, 120] |
| 110 | ok |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 111 | |
| 112 | And so on, eventually ending with:: |
| 113 | |
| 114 | Trying: |
| 115 | factorial(1e100) |
| 116 | Expecting: |
| 117 | Traceback (most recent call last): |
| 118 | ... |
| 119 | OverflowError: n too large |
| 120 | ok |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 121 | 2 items passed all tests: |
| 122 | 1 tests in __main__ |
| 123 | 8 tests in __main__.factorial |
Guido van Rossum | 04110fb | 2007-08-24 16:32:05 +0000 | [diff] [blame] | 124 | 9 tests in 2 items. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 125 | 9 passed and 0 failed. |
| 126 | Test passed. |
| 127 | $ |
| 128 | |
| 129 | That's all you need to know to start making productive use of :mod:`doctest`! |
| 130 | Jump in. The following sections provide full details. Note that there are many |
| 131 | examples of doctests in the standard Python test suite and libraries. |
| 132 | Especially useful examples can be found in the standard test file |
| 133 | :file:`Lib/test/test_doctest.py`. |
| 134 | |
| 135 | |
| 136 | .. _doctest-simple-testmod: |
| 137 | |
| 138 | Simple Usage: Checking Examples in Docstrings |
| 139 | --------------------------------------------- |
| 140 | |
| 141 | The simplest way to start using doctest (but not necessarily the way you'll |
| 142 | continue to do it) is to end each module :mod:`M` with:: |
| 143 | |
Guido van Rossum | 04110fb | 2007-08-24 16:32:05 +0000 | [diff] [blame] | 144 | if __name__ == "__main__": |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 145 | import doctest |
| 146 | doctest.testmod() |
| 147 | |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 148 | :mod:`doctest` then examines docstrings in module :mod:`M`. |
| 149 | |
| 150 | Running the module as a script causes the examples in the docstrings to get |
| 151 | executed and verified:: |
| 152 | |
| 153 | python M.py |
| 154 | |
| 155 | This won't display anything unless an example fails, in which case the failing |
| 156 | example(s) and the cause(s) of the failure(s) are printed to stdout, and the |
| 157 | final line of output is ``***Test Failed*** N failures.``, where *N* is the |
| 158 | number of examples that failed. |
| 159 | |
Éric Araujo | 713d303 | 2010-11-18 16:38:46 +0000 | [diff] [blame] | 160 | Run it with the ``-v`` switch instead:: |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 161 | |
| 162 | python M.py -v |
| 163 | |
| 164 | and a detailed report of all examples tried is printed to standard output, along |
| 165 | with assorted summaries at the end. |
| 166 | |
| 167 | You can force verbose mode by passing ``verbose=True`` to :func:`testmod`, or |
| 168 | prohibit it by passing ``verbose=False``. In either of those cases, |
Éric Araujo | 713d303 | 2010-11-18 16:38:46 +0000 | [diff] [blame] | 169 | ``sys.argv`` is not examined by :func:`testmod` (so passing ``-v`` or not |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 170 | has no effect). |
| 171 | |
Georg Brandl | 3183585 | 2008-05-12 17:38:56 +0000 | [diff] [blame] | 172 | There is also a command line shortcut for running :func:`testmod`. You can |
| 173 | instruct the Python interpreter to run the doctest module directly from the |
| 174 | standard library and pass the module name(s) on the command line:: |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 175 | |
| 176 | python -m doctest -v example.py |
| 177 | |
| 178 | This will import :file:`example.py` as a standalone module and run |
| 179 | :func:`testmod` on it. Note that this may not work correctly if the file is |
| 180 | part of a package and imports other submodules from that package. |
| 181 | |
| 182 | For more information on :func:`testmod`, see section :ref:`doctest-basic-api`. |
| 183 | |
| 184 | |
| 185 | .. _doctest-simple-testfile: |
| 186 | |
| 187 | Simple Usage: Checking Examples in a Text File |
| 188 | ---------------------------------------------- |
| 189 | |
| 190 | Another simple application of doctest is testing interactive examples in a text |
| 191 | file. This can be done with the :func:`testfile` function:: |
| 192 | |
| 193 | import doctest |
| 194 | doctest.testfile("example.txt") |
| 195 | |
| 196 | That short script executes and verifies any interactive Python examples |
| 197 | contained in the file :file:`example.txt`. The file content is treated as if it |
| 198 | were a single giant docstring; the file doesn't need to contain a Python |
| 199 | program! For example, perhaps :file:`example.txt` contains this:: |
| 200 | |
| 201 | The ``example`` module |
| 202 | ====================== |
| 203 | |
| 204 | Using ``factorial`` |
| 205 | ------------------- |
| 206 | |
| 207 | This is an example text file in reStructuredText format. First import |
| 208 | ``factorial`` from the ``example`` module: |
| 209 | |
| 210 | >>> from example import factorial |
| 211 | |
| 212 | Now use it: |
| 213 | |
| 214 | >>> factorial(6) |
| 215 | 120 |
| 216 | |
| 217 | Running ``doctest.testfile("example.txt")`` then finds the error in this |
| 218 | documentation:: |
| 219 | |
| 220 | File "./example.txt", line 14, in example.txt |
| 221 | Failed example: |
| 222 | factorial(6) |
| 223 | Expected: |
| 224 | 120 |
| 225 | Got: |
| 226 | 720 |
| 227 | |
| 228 | As with :func:`testmod`, :func:`testfile` won't display anything unless an |
| 229 | example fails. If an example does fail, then the failing example(s) and the |
| 230 | cause(s) of the failure(s) are printed to stdout, using the same format as |
| 231 | :func:`testmod`. |
| 232 | |
| 233 | By default, :func:`testfile` looks for files in the calling module's directory. |
| 234 | See section :ref:`doctest-basic-api` for a description of the optional arguments |
| 235 | that can be used to tell it to look for files in other locations. |
| 236 | |
| 237 | Like :func:`testmod`, :func:`testfile`'s verbosity can be set with the |
Éric Araujo | 713d303 | 2010-11-18 16:38:46 +0000 | [diff] [blame] | 238 | ``-v`` command-line switch or with the optional keyword argument |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 239 | *verbose*. |
| 240 | |
Georg Brandl | 3183585 | 2008-05-12 17:38:56 +0000 | [diff] [blame] | 241 | There is also a command line shortcut for running :func:`testfile`. You can |
| 242 | instruct the Python interpreter to run the doctest module directly from the |
| 243 | standard library and pass the file name(s) on the command line:: |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 244 | |
| 245 | python -m doctest -v example.txt |
| 246 | |
| 247 | Because the file name does not end with :file:`.py`, :mod:`doctest` infers that |
| 248 | it must be run with :func:`testfile`, not :func:`testmod`. |
| 249 | |
| 250 | For more information on :func:`testfile`, see section :ref:`doctest-basic-api`. |
| 251 | |
| 252 | |
| 253 | .. _doctest-how-it-works: |
| 254 | |
| 255 | How It Works |
| 256 | ------------ |
| 257 | |
| 258 | This section examines in detail how doctest works: which docstrings it looks at, |
| 259 | how it finds interactive examples, what execution context it uses, how it |
| 260 | handles exceptions, and how option flags can be used to control its behavior. |
| 261 | This is the information that you need to know to write doctest examples; for |
| 262 | information about actually running doctest on these examples, see the following |
| 263 | sections. |
| 264 | |
| 265 | |
| 266 | .. _doctest-which-docstrings: |
| 267 | |
| 268 | Which Docstrings Are Examined? |
| 269 | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ |
| 270 | |
| 271 | The module docstring, and all function, class and method docstrings are |
| 272 | searched. Objects imported into the module are not searched. |
| 273 | |
| 274 | In addition, if ``M.__test__`` exists and "is true", it must be a dict, and each |
| 275 | entry maps a (string) name to a function object, class object, or string. |
| 276 | Function and class object docstrings found from ``M.__test__`` are searched, and |
| 277 | strings are treated as if they were docstrings. In output, a key ``K`` in |
| 278 | ``M.__test__`` appears with name :: |
| 279 | |
| 280 | <name of M>.__test__.K |
| 281 | |
| 282 | Any classes found are recursively searched similarly, to test docstrings in |
| 283 | their contained methods and nested classes. |
| 284 | |
Zachary Ware | a4b7a75 | 2013-11-24 01:19:09 -0600 | [diff] [blame] | 285 | .. impl-detail:: |
| 286 | Prior to version 3.4, extension modules written in C were not fully |
| 287 | searched by doctest. |
| 288 | |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 289 | |
| 290 | .. _doctest-finding-examples: |
| 291 | |
| 292 | How are Docstring Examples Recognized? |
| 293 | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ |
| 294 | |
R. David Murray | 9691e59 | 2010-06-15 23:46:40 +0000 | [diff] [blame] | 295 | In most cases a copy-and-paste of an interactive console session works fine, |
| 296 | but doctest isn't trying to do an exact emulation of any specific Python shell. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 297 | |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 298 | :: |
| 299 | |
| 300 | >>> # comments are ignored |
| 301 | >>> x = 12 |
| 302 | >>> x |
| 303 | 12 |
| 304 | >>> if x == 13: |
Georg Brandl | 6911e3c | 2007-09-04 07:15:32 +0000 | [diff] [blame] | 305 | ... print("yes") |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 306 | ... else: |
Georg Brandl | 6911e3c | 2007-09-04 07:15:32 +0000 | [diff] [blame] | 307 | ... print("no") |
| 308 | ... print("NO") |
| 309 | ... print("NO!!!") |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 310 | ... |
| 311 | no |
| 312 | NO |
| 313 | NO!!! |
| 314 | >>> |
| 315 | |
| 316 | Any expected output must immediately follow the final ``'>>> '`` or ``'... '`` |
| 317 | line containing the code, and the expected output (if any) extends to the next |
| 318 | ``'>>> '`` or all-whitespace line. |
| 319 | |
| 320 | The fine print: |
| 321 | |
| 322 | * Expected output cannot contain an all-whitespace line, since such a line is |
| 323 | taken to signal the end of expected output. If expected output does contain a |
| 324 | blank line, put ``<BLANKLINE>`` in your doctest example each place a blank line |
| 325 | is expected. |
| 326 | |
R. David Murray | 9691e59 | 2010-06-15 23:46:40 +0000 | [diff] [blame] | 327 | * All hard tab characters are expanded to spaces, using 8-column tab stops. |
| 328 | Tabs in output generated by the tested code are not modified. Because any |
| 329 | hard tabs in the sample output *are* expanded, this means that if the code |
| 330 | output includes hard tabs, the only way the doctest can pass is if the |
Chris Jerdonek | 3650ea2 | 2012-10-10 06:52:08 -0700 | [diff] [blame] | 331 | :const:`NORMALIZE_WHITESPACE` option or :ref:`directive <doctest-directives>` |
| 332 | is in effect. |
R. David Murray | 9691e59 | 2010-06-15 23:46:40 +0000 | [diff] [blame] | 333 | Alternatively, the test can be rewritten to capture the output and compare it |
| 334 | to an expected value as part of the test. This handling of tabs in the |
| 335 | source was arrived at through trial and error, and has proven to be the least |
| 336 | error prone way of handling them. It is possible to use a different |
| 337 | algorithm for handling tabs by writing a custom :class:`DocTestParser` class. |
| 338 | |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 339 | * Output to stdout is captured, but not output to stderr (exception tracebacks |
| 340 | are captured via a different means). |
| 341 | |
| 342 | * If you continue a line via backslashing in an interactive session, or for any |
| 343 | other reason use a backslash, you should use a raw docstring, which will |
| 344 | preserve your backslashes exactly as you type them:: |
| 345 | |
| 346 | >>> def f(x): |
| 347 | ... r'''Backslashes in a raw docstring: m\n''' |
Georg Brandl | 6911e3c | 2007-09-04 07:15:32 +0000 | [diff] [blame] | 348 | >>> print(f.__doc__) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 349 | Backslashes in a raw docstring: m\n |
| 350 | |
| 351 | Otherwise, the backslash will be interpreted as part of the string. For example, |
Ezio Melotti | 694f233 | 2012-09-20 09:47:03 +0300 | [diff] [blame] | 352 | the ``\n`` above would be interpreted as a newline character. Alternatively, you |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 353 | can double each backslash in the doctest version (and not use a raw string):: |
| 354 | |
| 355 | >>> def f(x): |
| 356 | ... '''Backslashes in a raw docstring: m\\n''' |
Georg Brandl | 6911e3c | 2007-09-04 07:15:32 +0000 | [diff] [blame] | 357 | >>> print(f.__doc__) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 358 | Backslashes in a raw docstring: m\n |
| 359 | |
| 360 | * The starting column doesn't matter:: |
| 361 | |
| 362 | >>> assert "Easy!" |
| 363 | >>> import math |
| 364 | >>> math.floor(1.9) |
R. David Murray | 7c5714f | 2009-11-23 03:13:23 +0000 | [diff] [blame] | 365 | 1 |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 366 | |
| 367 | and as many leading whitespace characters are stripped from the expected output |
| 368 | as appeared in the initial ``'>>> '`` line that started the example. |
| 369 | |
| 370 | |
| 371 | .. _doctest-execution-context: |
| 372 | |
| 373 | What's the Execution Context? |
| 374 | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ |
| 375 | |
| 376 | By default, each time :mod:`doctest` finds a docstring to test, it uses a |
| 377 | *shallow copy* of :mod:`M`'s globals, so that running tests doesn't change the |
| 378 | module's real globals, and so that one test in :mod:`M` can't leave behind |
| 379 | crumbs that accidentally allow another test to work. This means examples can |
| 380 | freely use any names defined at top-level in :mod:`M`, and names defined earlier |
| 381 | in the docstring being run. Examples cannot see names defined in other |
| 382 | docstrings. |
| 383 | |
| 384 | You can force use of your own dict as the execution context by passing |
| 385 | ``globs=your_dict`` to :func:`testmod` or :func:`testfile` instead. |
| 386 | |
| 387 | |
| 388 | .. _doctest-exceptions: |
| 389 | |
| 390 | What About Exceptions? |
| 391 | ^^^^^^^^^^^^^^^^^^^^^^ |
| 392 | |
| 393 | No problem, provided that the traceback is the only output produced by the |
| 394 | example: just paste in the traceback. [#]_ Since tracebacks contain details |
| 395 | that are likely to change rapidly (for example, exact file paths and line |
| 396 | numbers), this is one case where doctest works hard to be flexible in what it |
| 397 | accepts. |
| 398 | |
| 399 | Simple example:: |
| 400 | |
| 401 | >>> [1, 2, 3].remove(42) |
| 402 | Traceback (most recent call last): |
| 403 | File "<stdin>", line 1, in ? |
| 404 | ValueError: list.remove(x): x not in list |
| 405 | |
| 406 | That doctest succeeds if :exc:`ValueError` is raised, with the ``list.remove(x): |
| 407 | x not in list`` detail as shown. |
| 408 | |
| 409 | The expected output for an exception must start with a traceback header, which |
| 410 | may be either of the following two lines, indented the same as the first line of |
| 411 | the example:: |
| 412 | |
| 413 | Traceback (most recent call last): |
| 414 | Traceback (innermost last): |
| 415 | |
| 416 | The traceback header is followed by an optional traceback stack, whose contents |
| 417 | are ignored by doctest. The traceback stack is typically omitted, or copied |
| 418 | verbatim from an interactive session. |
| 419 | |
| 420 | The traceback stack is followed by the most interesting part: the line(s) |
| 421 | containing the exception type and detail. This is usually the last line of a |
| 422 | traceback, but can extend across multiple lines if the exception has a |
| 423 | multi-line detail:: |
| 424 | |
| 425 | >>> raise ValueError('multi\n line\ndetail') |
| 426 | Traceback (most recent call last): |
| 427 | File "<stdin>", line 1, in ? |
| 428 | ValueError: multi |
| 429 | line |
| 430 | detail |
| 431 | |
| 432 | The last three lines (starting with :exc:`ValueError`) are compared against the |
| 433 | exception's type and detail, and the rest are ignored. |
| 434 | |
| 435 | Best practice is to omit the traceback stack, unless it adds significant |
| 436 | documentation value to the example. So the last example is probably better as:: |
| 437 | |
| 438 | >>> raise ValueError('multi\n line\ndetail') |
| 439 | Traceback (most recent call last): |
| 440 | ... |
| 441 | ValueError: multi |
| 442 | line |
| 443 | detail |
| 444 | |
| 445 | Note that tracebacks are treated very specially. In particular, in the |
| 446 | rewritten example, the use of ``...`` is independent of doctest's |
| 447 | :const:`ELLIPSIS` option. The ellipsis in that example could be left out, or |
| 448 | could just as well be three (or three hundred) commas or digits, or an indented |
| 449 | transcript of a Monty Python skit. |
| 450 | |
| 451 | Some details you should read once, but won't need to remember: |
| 452 | |
| 453 | * Doctest can't guess whether your expected output came from an exception |
| 454 | traceback or from ordinary printing. So, e.g., an example that expects |
| 455 | ``ValueError: 42 is prime`` will pass whether :exc:`ValueError` is actually |
| 456 | raised or if the example merely prints that traceback text. In practice, |
| 457 | ordinary output rarely begins with a traceback header line, so this doesn't |
| 458 | create real problems. |
| 459 | |
| 460 | * Each line of the traceback stack (if present) must be indented further than |
| 461 | the first line of the example, *or* start with a non-alphanumeric character. |
| 462 | The first line following the traceback header indented the same and starting |
| 463 | with an alphanumeric is taken to be the start of the exception detail. Of |
| 464 | course this does the right thing for genuine tracebacks. |
| 465 | |
Nick Coghlan | 5e76e94 | 2010-06-12 13:42:46 +0000 | [diff] [blame] | 466 | * When the :const:`IGNORE_EXCEPTION_DETAIL` doctest option is specified, |
| 467 | everything following the leftmost colon and any module information in the |
| 468 | exception name is ignored. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 469 | |
| 470 | * The interactive shell omits the traceback header line for some |
| 471 | :exc:`SyntaxError`\ s. But doctest uses the traceback header line to |
| 472 | distinguish exceptions from non-exceptions. So in the rare case where you need |
| 473 | to test a :exc:`SyntaxError` that omits the traceback header, you will need to |
| 474 | manually add the traceback header line to your test example. |
| 475 | |
| 476 | * For some :exc:`SyntaxError`\ s, Python displays the character position of the |
| 477 | syntax error, using a ``^`` marker:: |
| 478 | |
| 479 | >>> 1 1 |
| 480 | File "<stdin>", line 1 |
| 481 | 1 1 |
| 482 | ^ |
| 483 | SyntaxError: invalid syntax |
| 484 | |
| 485 | Since the lines showing the position of the error come before the exception type |
| 486 | and detail, they are not checked by doctest. For example, the following test |
| 487 | would pass, even though it puts the ``^`` marker in the wrong location:: |
| 488 | |
| 489 | >>> 1 1 |
| 490 | Traceback (most recent call last): |
| 491 | File "<stdin>", line 1 |
| 492 | 1 1 |
| 493 | ^ |
| 494 | SyntaxError: invalid syntax |
| 495 | |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 496 | |
Chris Jerdonek | 3650ea2 | 2012-10-10 06:52:08 -0700 | [diff] [blame] | 497 | .. _option-flags-and-directives: |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 498 | .. _doctest-options: |
| 499 | |
Chris Jerdonek | 3650ea2 | 2012-10-10 06:52:08 -0700 | [diff] [blame] | 500 | Option Flags |
| 501 | ^^^^^^^^^^^^ |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 502 | |
| 503 | A number of option flags control various aspects of doctest's behavior. |
| 504 | Symbolic names for the flags are supplied as module constants, which can be |
| 505 | or'ed together and passed to various functions. The names can also be used in |
R David Murray | 5707d50 | 2013-06-23 14:24:13 -0400 | [diff] [blame] | 506 | :ref:`doctest directives <doctest-directives>`, and may be passed to the |
| 507 | doctest command line interface via the ``-o`` option. |
| 508 | |
Georg Brandl | df48b97 | 2014-03-24 09:06:18 +0100 | [diff] [blame] | 509 | .. versionadded:: 3.4 |
| 510 | The ``-o`` command line option. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 511 | |
| 512 | The first group of options define test semantics, controlling aspects of how |
| 513 | doctest decides whether actual output matches an example's expected output: |
| 514 | |
| 515 | |
| 516 | .. data:: DONT_ACCEPT_TRUE_FOR_1 |
| 517 | |
| 518 | By default, if an expected output block contains just ``1``, an actual output |
| 519 | block containing just ``1`` or just ``True`` is considered to be a match, and |
| 520 | similarly for ``0`` versus ``False``. When :const:`DONT_ACCEPT_TRUE_FOR_1` is |
| 521 | specified, neither substitution is allowed. The default behavior caters to that |
| 522 | Python changed the return type of many functions from integer to boolean; |
| 523 | doctests expecting "little integer" output still work in these cases. This |
| 524 | option will probably go away, but not for several years. |
| 525 | |
| 526 | |
| 527 | .. data:: DONT_ACCEPT_BLANKLINE |
| 528 | |
| 529 | By default, if an expected output block contains a line containing only the |
| 530 | string ``<BLANKLINE>``, then that line will match a blank line in the actual |
| 531 | output. Because a genuinely blank line delimits the expected output, this is |
| 532 | the only way to communicate that a blank line is expected. When |
| 533 | :const:`DONT_ACCEPT_BLANKLINE` is specified, this substitution is not allowed. |
| 534 | |
| 535 | |
| 536 | .. data:: NORMALIZE_WHITESPACE |
| 537 | |
| 538 | When specified, all sequences of whitespace (blanks and newlines) are treated as |
| 539 | equal. Any sequence of whitespace within the expected output will match any |
| 540 | sequence of whitespace within the actual output. By default, whitespace must |
| 541 | match exactly. :const:`NORMALIZE_WHITESPACE` is especially useful when a line of |
| 542 | expected output is very long, and you want to wrap it across multiple lines in |
| 543 | your source. |
| 544 | |
| 545 | |
| 546 | .. data:: ELLIPSIS |
| 547 | |
| 548 | When specified, an ellipsis marker (``...``) in the expected output can match |
| 549 | any substring in the actual output. This includes substrings that span line |
| 550 | boundaries, and empty substrings, so it's best to keep usage of this simple. |
| 551 | Complicated uses can lead to the same kinds of "oops, it matched too much!" |
| 552 | surprises that ``.*`` is prone to in regular expressions. |
| 553 | |
| 554 | |
| 555 | .. data:: IGNORE_EXCEPTION_DETAIL |
| 556 | |
| 557 | When specified, an example that expects an exception passes if an exception of |
| 558 | the expected type is raised, even if the exception detail does not match. For |
| 559 | example, an example expecting ``ValueError: 42`` will pass if the actual |
| 560 | exception raised is ``ValueError: 3*14``, but will fail, e.g., if |
| 561 | :exc:`TypeError` is raised. |
| 562 | |
Nick Coghlan | 5e76e94 | 2010-06-12 13:42:46 +0000 | [diff] [blame] | 563 | It will also ignore the module name used in Python 3 doctest reports. Hence |
Chris Jerdonek | 3650ea2 | 2012-10-10 06:52:08 -0700 | [diff] [blame] | 564 | both of these variations will work with the flag specified, regardless of |
| 565 | whether the test is run under Python 2.7 or Python 3.2 (or later versions):: |
Nick Coghlan | 5e76e94 | 2010-06-12 13:42:46 +0000 | [diff] [blame] | 566 | |
Chris Jerdonek | 3fa8c59 | 2012-10-10 08:34:38 -0700 | [diff] [blame] | 567 | >>> raise CustomError('message') |
Nick Coghlan | 5e76e94 | 2010-06-12 13:42:46 +0000 | [diff] [blame] | 568 | Traceback (most recent call last): |
| 569 | CustomError: message |
| 570 | |
Chris Jerdonek | 3fa8c59 | 2012-10-10 08:34:38 -0700 | [diff] [blame] | 571 | >>> raise CustomError('message') |
Nick Coghlan | 5e76e94 | 2010-06-12 13:42:46 +0000 | [diff] [blame] | 572 | Traceback (most recent call last): |
| 573 | my_module.CustomError: message |
| 574 | |
| 575 | Note that :const:`ELLIPSIS` can also be used to ignore the |
| 576 | details of the exception message, but such a test may still fail based |
| 577 | on whether or not the module details are printed as part of the |
| 578 | exception name. Using :const:`IGNORE_EXCEPTION_DETAIL` and the details |
| 579 | from Python 2.3 is also the only clear way to write a doctest that doesn't |
| 580 | care about the exception detail yet continues to pass under Python 2.3 or |
Chris Jerdonek | 3650ea2 | 2012-10-10 06:52:08 -0700 | [diff] [blame] | 581 | earlier (those releases do not support :ref:`doctest directives |
| 582 | <doctest-directives>` and ignore them as irrelevant comments). For example:: |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 583 | |
Chris Jerdonek | 3fa8c59 | 2012-10-10 08:34:38 -0700 | [diff] [blame] | 584 | >>> (1, 2)[3] = 'moo' |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 585 | Traceback (most recent call last): |
| 586 | File "<stdin>", line 1, in ? |
| 587 | TypeError: object doesn't support item assignment |
| 588 | |
Chris Jerdonek | 3650ea2 | 2012-10-10 06:52:08 -0700 | [diff] [blame] | 589 | passes under Python 2.3 and later Python versions with the flag specified, |
| 590 | even though the detail |
Nick Coghlan | 5e76e94 | 2010-06-12 13:42:46 +0000 | [diff] [blame] | 591 | changed in Python 2.4 to say "does not" instead of "doesn't". |
| 592 | |
| 593 | .. versionchanged:: 3.2 |
Georg Brandl | 67b21b7 | 2010-08-17 15:07:14 +0000 | [diff] [blame] | 594 | :const:`IGNORE_EXCEPTION_DETAIL` now also ignores any information relating |
| 595 | to the module containing the exception under test. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 596 | |
| 597 | |
| 598 | .. data:: SKIP |
| 599 | |
| 600 | When specified, do not run the example at all. This can be useful in contexts |
| 601 | where doctest examples serve as both documentation and test cases, and an |
| 602 | example should be included for documentation purposes, but should not be |
| 603 | checked. E.g., the example's output might be random; or the example might |
| 604 | depend on resources which would be unavailable to the test driver. |
| 605 | |
| 606 | The SKIP flag can also be used for temporarily "commenting out" examples. |
| 607 | |
| 608 | |
| 609 | .. data:: COMPARISON_FLAGS |
| 610 | |
| 611 | A bitmask or'ing together all the comparison flags above. |
| 612 | |
| 613 | The second group of options controls how test failures are reported: |
| 614 | |
| 615 | |
| 616 | .. data:: REPORT_UDIFF |
| 617 | |
| 618 | When specified, failures that involve multi-line expected and actual outputs are |
| 619 | displayed using a unified diff. |
| 620 | |
| 621 | |
| 622 | .. data:: REPORT_CDIFF |
| 623 | |
| 624 | When specified, failures that involve multi-line expected and actual outputs |
| 625 | will be displayed using a context diff. |
| 626 | |
| 627 | |
| 628 | .. data:: REPORT_NDIFF |
| 629 | |
| 630 | When specified, differences are computed by ``difflib.Differ``, using the same |
| 631 | algorithm as the popular :file:`ndiff.py` utility. This is the only method that |
| 632 | marks differences within lines as well as across lines. For example, if a line |
| 633 | of expected output contains digit ``1`` where actual output contains letter |
| 634 | ``l``, a line is inserted with a caret marking the mismatching column positions. |
| 635 | |
| 636 | |
| 637 | .. data:: REPORT_ONLY_FIRST_FAILURE |
| 638 | |
| 639 | When specified, display the first failing example in each doctest, but suppress |
| 640 | output for all remaining examples. This will prevent doctest from reporting |
| 641 | correct examples that break because of earlier failures; but it might also hide |
| 642 | incorrect examples that fail independently of the first failure. When |
| 643 | :const:`REPORT_ONLY_FIRST_FAILURE` is specified, the remaining examples are |
| 644 | still run, and still count towards the total number of failures reported; only |
| 645 | the output is suppressed. |
| 646 | |
| 647 | |
R David Murray | 5a9d706 | 2012-11-21 15:09:21 -0500 | [diff] [blame] | 648 | .. data:: FAIL_FAST |
| 649 | |
| 650 | When specified, exit after the first failing example and don't attempt to run |
R David Murray | 60dd6e5 | 2012-11-22 06:22:41 -0500 | [diff] [blame] | 651 | the remaining examples. Thus, the number of failures reported will be at most |
| 652 | 1. This flag may be useful during debugging, since examples after the first |
R David Murray | 5a9d706 | 2012-11-21 15:09:21 -0500 | [diff] [blame] | 653 | failure won't even produce debugging output. |
| 654 | |
R David Murray | 5707d50 | 2013-06-23 14:24:13 -0400 | [diff] [blame] | 655 | The doctest command line accepts the option ``-f`` as a shorthand for ``-o |
| 656 | FAIL_FAST``. |
| 657 | |
R David Murray | 5a9d706 | 2012-11-21 15:09:21 -0500 | [diff] [blame] | 658 | .. versionadded:: 3.4 |
| 659 | |
| 660 | |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 661 | .. data:: REPORTING_FLAGS |
| 662 | |
| 663 | A bitmask or'ing together all the reporting flags above. |
| 664 | |
Chris Jerdonek | 3650ea2 | 2012-10-10 06:52:08 -0700 | [diff] [blame] | 665 | |
| 666 | There is also a way to register new option flag names, though this isn't |
| 667 | useful unless you intend to extend :mod:`doctest` internals via subclassing: |
| 668 | |
| 669 | |
| 670 | .. function:: register_optionflag(name) |
| 671 | |
| 672 | Create a new option flag with a given name, and return the new flag's integer |
| 673 | value. :func:`register_optionflag` can be used when subclassing |
| 674 | :class:`OutputChecker` or :class:`DocTestRunner` to create new options that are |
| 675 | supported by your subclasses. :func:`register_optionflag` should always be |
| 676 | called using the following idiom:: |
| 677 | |
| 678 | MY_FLAG = register_optionflag('MY_FLAG') |
| 679 | |
| 680 | |
| 681 | .. _doctest-directives: |
| 682 | |
| 683 | Directives |
| 684 | ^^^^^^^^^^ |
| 685 | |
| 686 | Doctest directives may be used to modify the :ref:`option flags |
| 687 | <doctest-options>` for an individual example. Doctest directives are |
| 688 | special Python comments following an example's source code: |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 689 | |
| 690 | .. productionlist:: doctest |
| 691 | directive: "#" "doctest:" `directive_options` |
| 692 | directive_options: `directive_option` ("," `directive_option`)\* |
| 693 | directive_option: `on_or_off` `directive_option_name` |
| 694 | on_or_off: "+" \| "-" |
| 695 | directive_option_name: "DONT_ACCEPT_BLANKLINE" \| "NORMALIZE_WHITESPACE" \| ... |
| 696 | |
| 697 | Whitespace is not allowed between the ``+`` or ``-`` and the directive option |
| 698 | name. The directive option name can be any of the option flag names explained |
| 699 | above. |
| 700 | |
| 701 | An example's doctest directives modify doctest's behavior for that single |
| 702 | example. Use ``+`` to enable the named behavior, or ``-`` to disable it. |
| 703 | |
Georg Brandl | 83e51f4 | 2012-10-10 16:45:11 +0200 | [diff] [blame] | 704 | For example, this test passes:: |
Nick Coghlan | 8f80e0a | 2012-10-03 12:21:44 +0530 | [diff] [blame] | 705 | |
Georg Brandl | 83e51f4 | 2012-10-10 16:45:11 +0200 | [diff] [blame] | 706 | >>> print(list(range(20))) # doctest: +NORMALIZE_WHITESPACE |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 707 | [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, |
| 708 | 10, 11, 12, 13, 14, 15, 16, 17, 18, 19] |
| 709 | |
| 710 | Without the directive it would fail, both because the actual output doesn't have |
| 711 | two blanks before the single-digit list elements, and because the actual output |
| 712 | is on a single line. This test also passes, and also requires a directive to do |
Georg Brandl | 83e51f4 | 2012-10-10 16:45:11 +0200 | [diff] [blame] | 713 | so:: |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 714 | |
Georg Brandl | 8f80a5b | 2010-03-21 09:25:54 +0000 | [diff] [blame] | 715 | >>> print(list(range(20))) # doctest: +ELLIPSIS |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 716 | [0, 1, ..., 18, 19] |
| 717 | |
Nick Coghlan | 0b26ccf | 2012-10-03 13:52:48 +0530 | [diff] [blame] | 718 | Multiple directives can be used on a single physical line, separated by |
Georg Brandl | 83e51f4 | 2012-10-10 16:45:11 +0200 | [diff] [blame] | 719 | commas:: |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 720 | |
Georg Brandl | 8f80a5b | 2010-03-21 09:25:54 +0000 | [diff] [blame] | 721 | >>> print(list(range(20))) # doctest: +ELLIPSIS, +NORMALIZE_WHITESPACE |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 722 | [0, 1, ..., 18, 19] |
| 723 | |
| 724 | If multiple directive comments are used for a single example, then they are |
Georg Brandl | 83e51f4 | 2012-10-10 16:45:11 +0200 | [diff] [blame] | 725 | combined:: |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 726 | |
Georg Brandl | 8f80a5b | 2010-03-21 09:25:54 +0000 | [diff] [blame] | 727 | >>> print(list(range(20))) # doctest: +ELLIPSIS |
| 728 | ... # doctest: +NORMALIZE_WHITESPACE |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 729 | [0, 1, ..., 18, 19] |
| 730 | |
| 731 | As the previous example shows, you can add ``...`` lines to your example |
| 732 | containing only directives. This can be useful when an example is too long for |
Georg Brandl | 83e51f4 | 2012-10-10 16:45:11 +0200 | [diff] [blame] | 733 | a directive to comfortably fit on the same line:: |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 734 | |
Georg Brandl | 8f80a5b | 2010-03-21 09:25:54 +0000 | [diff] [blame] | 735 | >>> print(list(range(5)) + list(range(10, 20)) + list(range(30, 40))) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 736 | ... # doctest: +ELLIPSIS |
Georg Brandl | 8f80a5b | 2010-03-21 09:25:54 +0000 | [diff] [blame] | 737 | [0, ..., 4, 10, ..., 19, 30, ..., 39] |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 738 | |
| 739 | Note that since all options are disabled by default, and directives apply only |
| 740 | to the example they appear in, enabling options (via ``+`` in a directive) is |
| 741 | usually the only meaningful choice. However, option flags can also be passed to |
| 742 | functions that run doctests, establishing different defaults. In such cases, |
| 743 | disabling an option via ``-`` in a directive can be useful. |
| 744 | |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 745 | |
| 746 | .. _doctest-warnings: |
| 747 | |
| 748 | Warnings |
| 749 | ^^^^^^^^ |
| 750 | |
| 751 | :mod:`doctest` is serious about requiring exact matches in expected output. If |
| 752 | even a single character doesn't match, the test fails. This will probably |
| 753 | surprise you a few times, as you learn exactly what Python does and doesn't |
| 754 | guarantee about output. For example, when printing a dict, Python doesn't |
| 755 | guarantee that the key-value pairs will be printed in any particular order, so a |
Christian Heimes | 5b5e81c | 2007-12-31 16:14:33 +0000 | [diff] [blame] | 756 | test like :: |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 757 | |
| 758 | >>> foo() |
| 759 | {"Hermione": "hippogryph", "Harry": "broomstick"} |
| 760 | |
| 761 | is vulnerable! One workaround is to do :: |
| 762 | |
| 763 | >>> foo() == {"Hermione": "hippogryph", "Harry": "broomstick"} |
| 764 | True |
| 765 | |
| 766 | instead. Another is to do :: |
| 767 | |
Ezio Melotti | 8f7649e | 2009-09-13 04:48:45 +0000 | [diff] [blame] | 768 | >>> d = sorted(foo().items()) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 769 | >>> d |
| 770 | [('Harry', 'broomstick'), ('Hermione', 'hippogryph')] |
| 771 | |
| 772 | There are others, but you get the idea. |
| 773 | |
| 774 | Another bad idea is to print things that embed an object address, like :: |
| 775 | |
| 776 | >>> id(1.0) # certain to fail some of the time |
| 777 | 7948648 |
| 778 | >>> class C: pass |
| 779 | >>> C() # the default repr() for instances embeds an address |
| 780 | <__main__.C instance at 0x00AC18F0> |
| 781 | |
Georg Brandl | 23a87de | 2012-10-10 16:56:15 +0200 | [diff] [blame] | 782 | The :const:`ELLIPSIS` directive gives a nice approach for the last example:: |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 783 | |
| 784 | >>> C() #doctest: +ELLIPSIS |
| 785 | <__main__.C instance at 0x...> |
| 786 | |
| 787 | Floating-point numbers are also subject to small output variations across |
| 788 | platforms, because Python defers to the platform C library for float formatting, |
| 789 | and C libraries vary widely in quality here. :: |
| 790 | |
| 791 | >>> 1./7 # risky |
| 792 | 0.14285714285714285 |
Georg Brandl | 6911e3c | 2007-09-04 07:15:32 +0000 | [diff] [blame] | 793 | >>> print(1./7) # safer |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 794 | 0.142857142857 |
Georg Brandl | 6911e3c | 2007-09-04 07:15:32 +0000 | [diff] [blame] | 795 | >>> print(round(1./7, 6)) # much safer |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 796 | 0.142857 |
| 797 | |
| 798 | Numbers of the form ``I/2.**J`` are safe across all platforms, and I often |
| 799 | contrive doctest examples to produce numbers of that form:: |
| 800 | |
| 801 | >>> 3./4 # utterly safe |
| 802 | 0.75 |
| 803 | |
| 804 | Simple fractions are also easier for people to understand, and that makes for |
| 805 | better documentation. |
| 806 | |
| 807 | |
| 808 | .. _doctest-basic-api: |
| 809 | |
| 810 | Basic API |
| 811 | --------- |
| 812 | |
| 813 | The functions :func:`testmod` and :func:`testfile` provide a simple interface to |
| 814 | doctest that should be sufficient for most basic uses. For a less formal |
| 815 | introduction to these two functions, see sections :ref:`doctest-simple-testmod` |
| 816 | and :ref:`doctest-simple-testfile`. |
| 817 | |
| 818 | |
Georg Brandl | c2a4f4f | 2009-04-10 09:03:43 +0000 | [diff] [blame] | 819 | .. function:: testfile(filename, module_relative=True, name=None, package=None, globs=None, verbose=None, report=True, optionflags=0, extraglobs=None, raise_on_error=False, parser=DocTestParser(), encoding=None) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 820 | |
| 821 | All arguments except *filename* are optional, and should be specified in keyword |
| 822 | form. |
| 823 | |
| 824 | Test examples in the file named *filename*. Return ``(failure_count, |
| 825 | test_count)``. |
| 826 | |
| 827 | Optional argument *module_relative* specifies how the filename should be |
| 828 | interpreted: |
| 829 | |
| 830 | * If *module_relative* is ``True`` (the default), then *filename* specifies an |
| 831 | OS-independent module-relative path. By default, this path is relative to the |
| 832 | calling module's directory; but if the *package* argument is specified, then it |
| 833 | is relative to that package. To ensure OS-independence, *filename* should use |
| 834 | ``/`` characters to separate path segments, and may not be an absolute path |
| 835 | (i.e., it may not begin with ``/``). |
| 836 | |
| 837 | * If *module_relative* is ``False``, then *filename* specifies an OS-specific |
| 838 | path. The path may be absolute or relative; relative paths are resolved with |
| 839 | respect to the current working directory. |
| 840 | |
| 841 | Optional argument *name* gives the name of the test; by default, or if ``None``, |
| 842 | ``os.path.basename(filename)`` is used. |
| 843 | |
| 844 | Optional argument *package* is a Python package or the name of a Python package |
| 845 | whose directory should be used as the base directory for a module-relative |
| 846 | filename. If no package is specified, then the calling module's directory is |
| 847 | used as the base directory for module-relative filenames. It is an error to |
| 848 | specify *package* if *module_relative* is ``False``. |
| 849 | |
| 850 | Optional argument *globs* gives a dict to be used as the globals when executing |
| 851 | examples. A new shallow copy of this dict is created for the doctest, so its |
| 852 | examples start with a clean slate. By default, or if ``None``, a new empty dict |
| 853 | is used. |
| 854 | |
| 855 | Optional argument *extraglobs* gives a dict merged into the globals used to |
| 856 | execute examples. This works like :meth:`dict.update`: if *globs* and |
| 857 | *extraglobs* have a common key, the associated value in *extraglobs* appears in |
| 858 | the combined dict. By default, or if ``None``, no extra globals are used. This |
| 859 | is an advanced feature that allows parameterization of doctests. For example, a |
| 860 | doctest can be written for a base class, using a generic name for the class, |
| 861 | then reused to test any number of subclasses by passing an *extraglobs* dict |
| 862 | mapping the generic name to the subclass to be tested. |
| 863 | |
| 864 | Optional argument *verbose* prints lots of stuff if true, and prints only |
| 865 | failures if false; by default, or if ``None``, it's true if and only if ``'-v'`` |
| 866 | is in ``sys.argv``. |
| 867 | |
| 868 | Optional argument *report* prints a summary at the end when true, else prints |
| 869 | nothing at the end. In verbose mode, the summary is detailed, else the summary |
| 870 | is very brief (in fact, empty if all tests passed). |
| 871 | |
Georg Brandl | 7fa4a8f | 2014-10-06 16:56:43 +0200 | [diff] [blame] | 872 | Optional argument *optionflags* (default value 0) takes the bitwise-or of |
| 873 | option flags. See section :ref:`doctest-options`. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 874 | |
| 875 | Optional argument *raise_on_error* defaults to false. If true, an exception is |
| 876 | raised upon the first failure or unexpected exception in an example. This |
| 877 | allows failures to be post-mortem debugged. Default behavior is to continue |
| 878 | running examples. |
| 879 | |
| 880 | Optional argument *parser* specifies a :class:`DocTestParser` (or subclass) that |
| 881 | should be used to extract tests from the files. It defaults to a normal parser |
| 882 | (i.e., ``DocTestParser()``). |
| 883 | |
| 884 | Optional argument *encoding* specifies an encoding that should be used to |
| 885 | convert the file to unicode. |
| 886 | |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 887 | |
Georg Brandl | c2a4f4f | 2009-04-10 09:03:43 +0000 | [diff] [blame] | 888 | .. function:: testmod(m=None, name=None, globs=None, verbose=None, report=True, optionflags=0, extraglobs=None, raise_on_error=False, exclude_empty=False) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 889 | |
| 890 | All arguments are optional, and all except for *m* should be specified in |
| 891 | keyword form. |
| 892 | |
| 893 | Test examples in docstrings in functions and classes reachable from module *m* |
| 894 | (or module :mod:`__main__` if *m* is not supplied or is ``None``), starting with |
| 895 | ``m.__doc__``. |
| 896 | |
| 897 | Also test examples reachable from dict ``m.__test__``, if it exists and is not |
| 898 | ``None``. ``m.__test__`` maps names (strings) to functions, classes and |
| 899 | strings; function and class docstrings are searched for examples; strings are |
| 900 | searched directly, as if they were docstrings. |
| 901 | |
| 902 | Only docstrings attached to objects belonging to module *m* are searched. |
| 903 | |
| 904 | Return ``(failure_count, test_count)``. |
| 905 | |
| 906 | Optional argument *name* gives the name of the module; by default, or if |
| 907 | ``None``, ``m.__name__`` is used. |
| 908 | |
| 909 | Optional argument *exclude_empty* defaults to false. If true, objects for which |
| 910 | no doctests are found are excluded from consideration. The default is a backward |
| 911 | compatibility hack, so that code still using :meth:`doctest.master.summarize` in |
| 912 | conjunction with :func:`testmod` continues to get output for objects with no |
| 913 | tests. The *exclude_empty* argument to the newer :class:`DocTestFinder` |
| 914 | constructor defaults to true. |
| 915 | |
| 916 | Optional arguments *extraglobs*, *verbose*, *report*, *optionflags*, |
| 917 | *raise_on_error*, and *globs* are the same as for function :func:`testfile` |
| 918 | above, except that *globs* defaults to ``m.__dict__``. |
| 919 | |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 920 | |
Georg Brandl | c2a4f4f | 2009-04-10 09:03:43 +0000 | [diff] [blame] | 921 | .. function:: run_docstring_examples(f, globs, verbose=False, name="NoName", compileflags=None, optionflags=0) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 922 | |
Ethan Furman | 2a5f9da | 2015-09-17 22:20:41 -0700 | [diff] [blame] | 923 | Test examples associated with object *f*; for example, *f* may be a string, |
| 924 | a module, a function, or a class object. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 925 | |
| 926 | A shallow copy of dictionary argument *globs* is used for the execution context. |
| 927 | |
| 928 | Optional argument *name* is used in failure messages, and defaults to |
| 929 | ``"NoName"``. |
| 930 | |
| 931 | If optional argument *verbose* is true, output is generated even if there are no |
| 932 | failures. By default, output is generated only in case of an example failure. |
| 933 | |
| 934 | Optional argument *compileflags* gives the set of flags that should be used by |
| 935 | the Python compiler when running the examples. By default, or if ``None``, |
| 936 | flags are deduced corresponding to the set of future features found in *globs*. |
| 937 | |
| 938 | Optional argument *optionflags* works as for function :func:`testfile` above. |
| 939 | |
| 940 | |
| 941 | .. _doctest-unittest-api: |
| 942 | |
| 943 | Unittest API |
| 944 | ------------ |
| 945 | |
| 946 | As your collection of doctest'ed modules grows, you'll want a way to run all |
Georg Brandl | 3183585 | 2008-05-12 17:38:56 +0000 | [diff] [blame] | 947 | their doctests systematically. :mod:`doctest` provides two functions that can |
| 948 | be used to create :mod:`unittest` test suites from modules and text files |
Georg Brandl | a851483 | 2010-07-10 12:20:38 +0000 | [diff] [blame] | 949 | containing doctests. To integrate with :mod:`unittest` test discovery, include |
| 950 | a :func:`load_tests` function in your test module:: |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 951 | |
| 952 | import unittest |
| 953 | import doctest |
Georg Brandl | a851483 | 2010-07-10 12:20:38 +0000 | [diff] [blame] | 954 | import my_module_with_doctests |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 955 | |
Georg Brandl | a851483 | 2010-07-10 12:20:38 +0000 | [diff] [blame] | 956 | def load_tests(loader, tests, ignore): |
| 957 | tests.addTests(doctest.DocTestSuite(my_module_with_doctests)) |
R. David Murray | 796343b | 2010-12-13 22:50:30 +0000 | [diff] [blame] | 958 | return tests |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 959 | |
| 960 | There are two main functions for creating :class:`unittest.TestSuite` instances |
| 961 | from text files and modules with doctests: |
| 962 | |
| 963 | |
Georg Brandl | c2a4f4f | 2009-04-10 09:03:43 +0000 | [diff] [blame] | 964 | .. function:: DocFileSuite(*paths, module_relative=True, package=None, setUp=None, tearDown=None, globs=None, optionflags=0, parser=DocTestParser(), encoding=None) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 965 | |
| 966 | Convert doctest tests from one or more text files to a |
| 967 | :class:`unittest.TestSuite`. |
| 968 | |
| 969 | The returned :class:`unittest.TestSuite` is to be run by the unittest framework |
| 970 | and runs the interactive examples in each file. If an example in any file |
| 971 | fails, then the synthesized unit test fails, and a :exc:`failureException` |
| 972 | exception is raised showing the name of the file containing the test and a |
| 973 | (sometimes approximate) line number. |
| 974 | |
| 975 | Pass one or more paths (as strings) to text files to be examined. |
| 976 | |
| 977 | Options may be provided as keyword arguments: |
| 978 | |
| 979 | Optional argument *module_relative* specifies how the filenames in *paths* |
| 980 | should be interpreted: |
| 981 | |
Benjamin Peterson | d23f822 | 2009-04-05 19:13:16 +0000 | [diff] [blame] | 982 | * If *module_relative* is ``True`` (the default), then each filename in |
| 983 | *paths* specifies an OS-independent module-relative path. By default, this |
| 984 | path is relative to the calling module's directory; but if the *package* |
| 985 | argument is specified, then it is relative to that package. To ensure |
| 986 | OS-independence, each filename should use ``/`` characters to separate path |
| 987 | segments, and may not be an absolute path (i.e., it may not begin with |
| 988 | ``/``). |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 989 | |
Benjamin Peterson | d23f822 | 2009-04-05 19:13:16 +0000 | [diff] [blame] | 990 | * If *module_relative* is ``False``, then each filename in *paths* specifies |
| 991 | an OS-specific path. The path may be absolute or relative; relative paths |
| 992 | are resolved with respect to the current working directory. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 993 | |
Benjamin Peterson | d23f822 | 2009-04-05 19:13:16 +0000 | [diff] [blame] | 994 | Optional argument *package* is a Python package or the name of a Python |
| 995 | package whose directory should be used as the base directory for |
| 996 | module-relative filenames in *paths*. If no package is specified, then the |
| 997 | calling module's directory is used as the base directory for module-relative |
| 998 | filenames. It is an error to specify *package* if *module_relative* is |
| 999 | ``False``. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1000 | |
Benjamin Peterson | d23f822 | 2009-04-05 19:13:16 +0000 | [diff] [blame] | 1001 | Optional argument *setUp* specifies a set-up function for the test suite. |
| 1002 | This is called before running the tests in each file. The *setUp* function |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1003 | will be passed a :class:`DocTest` object. The setUp function can access the |
| 1004 | test globals as the *globs* attribute of the test passed. |
| 1005 | |
Benjamin Peterson | d23f822 | 2009-04-05 19:13:16 +0000 | [diff] [blame] | 1006 | Optional argument *tearDown* specifies a tear-down function for the test |
| 1007 | suite. This is called after running the tests in each file. The *tearDown* |
| 1008 | function will be passed a :class:`DocTest` object. The setUp function can |
| 1009 | access the test globals as the *globs* attribute of the test passed. |
| 1010 | |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1011 | Optional argument *globs* is a dictionary containing the initial global |
| 1012 | variables for the tests. A new copy of this dictionary is created for each |
| 1013 | test. By default, *globs* is a new empty dictionary. |
| 1014 | |
| 1015 | Optional argument *optionflags* specifies the default doctest options for the |
| 1016 | tests, created by or-ing together individual option flags. See section |
Benjamin Peterson | d23f822 | 2009-04-05 19:13:16 +0000 | [diff] [blame] | 1017 | :ref:`doctest-options`. See function :func:`set_unittest_reportflags` below |
| 1018 | for a better way to set reporting options. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1019 | |
Benjamin Peterson | d23f822 | 2009-04-05 19:13:16 +0000 | [diff] [blame] | 1020 | Optional argument *parser* specifies a :class:`DocTestParser` (or subclass) |
| 1021 | that should be used to extract tests from the files. It defaults to a normal |
| 1022 | parser (i.e., ``DocTestParser()``). |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1023 | |
| 1024 | Optional argument *encoding* specifies an encoding that should be used to |
| 1025 | convert the file to unicode. |
| 1026 | |
Georg Brandl | 55ac8f0 | 2007-09-01 13:51:09 +0000 | [diff] [blame] | 1027 | The global ``__file__`` is added to the globals provided to doctests loaded |
| 1028 | from a text file using :func:`DocFileSuite`. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1029 | |
| 1030 | |
Georg Brandl | c2a4f4f | 2009-04-10 09:03:43 +0000 | [diff] [blame] | 1031 | .. function:: DocTestSuite(module=None, globs=None, extraglobs=None, test_finder=None, setUp=None, tearDown=None, checker=None) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1032 | |
| 1033 | Convert doctest tests for a module to a :class:`unittest.TestSuite`. |
| 1034 | |
| 1035 | The returned :class:`unittest.TestSuite` is to be run by the unittest framework |
| 1036 | and runs each doctest in the module. If any of the doctests fail, then the |
| 1037 | synthesized unit test fails, and a :exc:`failureException` exception is raised |
| 1038 | showing the name of the file containing the test and a (sometimes approximate) |
| 1039 | line number. |
| 1040 | |
| 1041 | Optional argument *module* provides the module to be tested. It can be a module |
| 1042 | object or a (possibly dotted) module name. If not specified, the module calling |
| 1043 | this function is used. |
| 1044 | |
| 1045 | Optional argument *globs* is a dictionary containing the initial global |
| 1046 | variables for the tests. A new copy of this dictionary is created for each |
| 1047 | test. By default, *globs* is a new empty dictionary. |
| 1048 | |
| 1049 | Optional argument *extraglobs* specifies an extra set of global variables, which |
| 1050 | is merged into *globs*. By default, no extra globals are used. |
| 1051 | |
| 1052 | Optional argument *test_finder* is the :class:`DocTestFinder` object (or a |
| 1053 | drop-in replacement) that is used to extract doctests from the module. |
| 1054 | |
| 1055 | Optional arguments *setUp*, *tearDown*, and *optionflags* are the same as for |
| 1056 | function :func:`DocFileSuite` above. |
| 1057 | |
Georg Brandl | 55ac8f0 | 2007-09-01 13:51:09 +0000 | [diff] [blame] | 1058 | This function uses the same search technique as :func:`testmod`. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1059 | |
R David Murray | 1976d9b | 2014-04-14 20:28:36 -0400 | [diff] [blame] | 1060 | .. versionchanged:: 3.5 |
| 1061 | :func:`DocTestSuite` returns an empty :class:`unittest.TestSuite` if *module* |
| 1062 | contains no docstrings instead of raising :exc:`ValueError`. |
R David Murray | 5abd76a | 2012-09-10 10:15:58 -0400 | [diff] [blame] | 1063 | |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1064 | |
| 1065 | Under the covers, :func:`DocTestSuite` creates a :class:`unittest.TestSuite` out |
| 1066 | of :class:`doctest.DocTestCase` instances, and :class:`DocTestCase` is a |
| 1067 | subclass of :class:`unittest.TestCase`. :class:`DocTestCase` isn't documented |
| 1068 | here (it's an internal detail), but studying its code can answer questions about |
| 1069 | the exact details of :mod:`unittest` integration. |
| 1070 | |
| 1071 | Similarly, :func:`DocFileSuite` creates a :class:`unittest.TestSuite` out of |
| 1072 | :class:`doctest.DocFileCase` instances, and :class:`DocFileCase` is a subclass |
| 1073 | of :class:`DocTestCase`. |
| 1074 | |
| 1075 | So both ways of creating a :class:`unittest.TestSuite` run instances of |
| 1076 | :class:`DocTestCase`. This is important for a subtle reason: when you run |
| 1077 | :mod:`doctest` functions yourself, you can control the :mod:`doctest` options in |
| 1078 | use directly, by passing option flags to :mod:`doctest` functions. However, if |
| 1079 | you're writing a :mod:`unittest` framework, :mod:`unittest` ultimately controls |
| 1080 | when and how tests get run. The framework author typically wants to control |
| 1081 | :mod:`doctest` reporting options (perhaps, e.g., specified by command line |
| 1082 | options), but there's no way to pass options through :mod:`unittest` to |
| 1083 | :mod:`doctest` test runners. |
| 1084 | |
| 1085 | For this reason, :mod:`doctest` also supports a notion of :mod:`doctest` |
| 1086 | reporting flags specific to :mod:`unittest` support, via this function: |
| 1087 | |
| 1088 | |
| 1089 | .. function:: set_unittest_reportflags(flags) |
| 1090 | |
| 1091 | Set the :mod:`doctest` reporting flags to use. |
| 1092 | |
Georg Brandl | 7fa4a8f | 2014-10-06 16:56:43 +0200 | [diff] [blame] | 1093 | Argument *flags* takes the bitwise-or of option flags. See section |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1094 | :ref:`doctest-options`. Only "reporting flags" can be used. |
| 1095 | |
| 1096 | This is a module-global setting, and affects all future doctests run by module |
| 1097 | :mod:`unittest`: the :meth:`runTest` method of :class:`DocTestCase` looks at |
| 1098 | the option flags specified for the test case when the :class:`DocTestCase` |
| 1099 | instance was constructed. If no reporting flags were specified (which is the |
| 1100 | typical and expected case), :mod:`doctest`'s :mod:`unittest` reporting flags are |
| 1101 | or'ed into the option flags, and the option flags so augmented are passed to the |
| 1102 | :class:`DocTestRunner` instance created to run the doctest. If any reporting |
| 1103 | flags were specified when the :class:`DocTestCase` instance was constructed, |
| 1104 | :mod:`doctest`'s :mod:`unittest` reporting flags are ignored. |
| 1105 | |
| 1106 | The value of the :mod:`unittest` reporting flags in effect before the function |
| 1107 | was called is returned by the function. |
| 1108 | |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1109 | |
| 1110 | .. _doctest-advanced-api: |
| 1111 | |
| 1112 | Advanced API |
| 1113 | ------------ |
| 1114 | |
| 1115 | The basic API is a simple wrapper that's intended to make doctest easy to use. |
| 1116 | It is fairly flexible, and should meet most users' needs; however, if you |
| 1117 | require more fine-grained control over testing, or wish to extend doctest's |
| 1118 | capabilities, then you should use the advanced API. |
| 1119 | |
| 1120 | The advanced API revolves around two container classes, which are used to store |
| 1121 | the interactive examples extracted from doctest cases: |
| 1122 | |
Ezio Melotti | 0639d5a | 2009-12-19 23:26:38 +0000 | [diff] [blame] | 1123 | * :class:`Example`: A single Python :term:`statement`, paired with its expected |
Christian Heimes | d8654cf | 2007-12-02 15:22:16 +0000 | [diff] [blame] | 1124 | output. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1125 | |
| 1126 | * :class:`DocTest`: A collection of :class:`Example`\ s, typically extracted |
| 1127 | from a single docstring or text file. |
| 1128 | |
| 1129 | Additional processing classes are defined to find, parse, and run, and check |
| 1130 | doctest examples: |
| 1131 | |
| 1132 | * :class:`DocTestFinder`: Finds all docstrings in a given module, and uses a |
| 1133 | :class:`DocTestParser` to create a :class:`DocTest` from every docstring that |
| 1134 | contains interactive examples. |
| 1135 | |
| 1136 | * :class:`DocTestParser`: Creates a :class:`DocTest` object from a string (such |
| 1137 | as an object's docstring). |
| 1138 | |
| 1139 | * :class:`DocTestRunner`: Executes the examples in a :class:`DocTest`, and uses |
| 1140 | an :class:`OutputChecker` to verify their output. |
| 1141 | |
| 1142 | * :class:`OutputChecker`: Compares the actual output from a doctest example with |
| 1143 | the expected output, and decides whether they match. |
| 1144 | |
| 1145 | The relationships among these processing classes are summarized in the following |
| 1146 | diagram:: |
| 1147 | |
| 1148 | list of: |
| 1149 | +------+ +---------+ |
| 1150 | |module| --DocTestFinder-> | DocTest | --DocTestRunner-> results |
| 1151 | +------+ | ^ +---------+ | ^ (printed) |
| 1152 | | | | Example | | | |
| 1153 | v | | ... | v | |
| 1154 | DocTestParser | Example | OutputChecker |
| 1155 | +---------+ |
| 1156 | |
| 1157 | |
| 1158 | .. _doctest-doctest: |
| 1159 | |
| 1160 | DocTest Objects |
| 1161 | ^^^^^^^^^^^^^^^ |
| 1162 | |
| 1163 | |
| 1164 | .. class:: DocTest(examples, globs, name, filename, lineno, docstring) |
| 1165 | |
| 1166 | A collection of doctest examples that should be run in a single namespace. The |
Senthil Kumaran | a6bac95 | 2011-07-04 11:28:30 -0700 | [diff] [blame] | 1167 | constructor arguments are used to initialize the attributes of the same names. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1168 | |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1169 | |
Senthil Kumaran | a6bac95 | 2011-07-04 11:28:30 -0700 | [diff] [blame] | 1170 | :class:`DocTest` defines the following attributes. They are initialized by |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1171 | the constructor, and should not be modified directly. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1172 | |
| 1173 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1174 | .. attribute:: examples |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1175 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1176 | A list of :class:`Example` objects encoding the individual interactive Python |
| 1177 | examples that should be run by this test. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1178 | |
| 1179 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1180 | .. attribute:: globs |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1181 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1182 | The namespace (aka globals) that the examples should be run in. This is a |
| 1183 | dictionary mapping names to values. Any changes to the namespace made by the |
| 1184 | examples (such as binding new variables) will be reflected in :attr:`globs` |
| 1185 | after the test is run. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1186 | |
| 1187 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1188 | .. attribute:: name |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1189 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1190 | A string name identifying the :class:`DocTest`. Typically, this is the name |
| 1191 | of the object or file that the test was extracted from. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1192 | |
| 1193 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1194 | .. attribute:: filename |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1195 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1196 | The name of the file that this :class:`DocTest` was extracted from; or |
| 1197 | ``None`` if the filename is unknown, or if the :class:`DocTest` was not |
| 1198 | extracted from a file. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1199 | |
| 1200 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1201 | .. attribute:: lineno |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1202 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1203 | The line number within :attr:`filename` where this :class:`DocTest` begins, or |
| 1204 | ``None`` if the line number is unavailable. This line number is zero-based |
| 1205 | with respect to the beginning of the file. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1206 | |
| 1207 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1208 | .. attribute:: docstring |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1209 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1210 | The string that the test was extracted from, or 'None' if the string is |
| 1211 | unavailable, or if the test was not extracted from a string. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1212 | |
| 1213 | |
| 1214 | .. _doctest-example: |
| 1215 | |
| 1216 | Example Objects |
| 1217 | ^^^^^^^^^^^^^^^ |
| 1218 | |
| 1219 | |
Georg Brandl | c2a4f4f | 2009-04-10 09:03:43 +0000 | [diff] [blame] | 1220 | .. class:: Example(source, want, exc_msg=None, lineno=0, indent=0, options=None) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1221 | |
| 1222 | A single interactive example, consisting of a Python statement and its expected |
Senthil Kumaran | a6bac95 | 2011-07-04 11:28:30 -0700 | [diff] [blame] | 1223 | output. The constructor arguments are used to initialize the attributes of |
| 1224 | the same names. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1225 | |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1226 | |
Senthil Kumaran | a6bac95 | 2011-07-04 11:28:30 -0700 | [diff] [blame] | 1227 | :class:`Example` defines the following attributes. They are initialized by |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1228 | the constructor, and should not be modified directly. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1229 | |
| 1230 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1231 | .. attribute:: source |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1232 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1233 | A string containing the example's source code. This source code consists of a |
| 1234 | single Python statement, and always ends with a newline; the constructor adds |
| 1235 | a newline when necessary. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1236 | |
| 1237 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1238 | .. attribute:: want |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1239 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1240 | The expected output from running the example's source code (either from |
| 1241 | stdout, or a traceback in case of exception). :attr:`want` ends with a |
| 1242 | newline unless no output is expected, in which case it's an empty string. The |
| 1243 | constructor adds a newline when necessary. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1244 | |
| 1245 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1246 | .. attribute:: exc_msg |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1247 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1248 | The exception message generated by the example, if the example is expected to |
| 1249 | generate an exception; or ``None`` if it is not expected to generate an |
| 1250 | exception. This exception message is compared against the return value of |
| 1251 | :func:`traceback.format_exception_only`. :attr:`exc_msg` ends with a newline |
| 1252 | unless it's ``None``. The constructor adds a newline if needed. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1253 | |
| 1254 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1255 | .. attribute:: lineno |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1256 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1257 | The line number within the string containing this example where the example |
| 1258 | begins. This line number is zero-based with respect to the beginning of the |
| 1259 | containing string. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1260 | |
| 1261 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1262 | .. attribute:: indent |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1263 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1264 | The example's indentation in the containing string, i.e., the number of space |
| 1265 | characters that precede the example's first prompt. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1266 | |
| 1267 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1268 | .. attribute:: options |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1269 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1270 | A dictionary mapping from option flags to ``True`` or ``False``, which is used |
| 1271 | to override default options for this example. Any option flags not contained |
| 1272 | in this dictionary are left at their default value (as specified by the |
| 1273 | :class:`DocTestRunner`'s :attr:`optionflags`). By default, no options are set. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1274 | |
| 1275 | |
| 1276 | .. _doctest-doctestfinder: |
| 1277 | |
| 1278 | DocTestFinder objects |
| 1279 | ^^^^^^^^^^^^^^^^^^^^^ |
| 1280 | |
| 1281 | |
Georg Brandl | c2a4f4f | 2009-04-10 09:03:43 +0000 | [diff] [blame] | 1282 | .. class:: DocTestFinder(verbose=False, parser=DocTestParser(), recurse=True, exclude_empty=True) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1283 | |
| 1284 | A processing class used to extract the :class:`DocTest`\ s that are relevant to |
| 1285 | a given object, from its docstring and the docstrings of its contained objects. |
Zachary Ware | a4b7a75 | 2013-11-24 01:19:09 -0600 | [diff] [blame] | 1286 | :class:`DocTest`\ s can be extracted from modules, classes, functions, |
| 1287 | methods, staticmethods, classmethods, and properties. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1288 | |
| 1289 | The optional argument *verbose* can be used to display the objects searched by |
| 1290 | the finder. It defaults to ``False`` (no output). |
| 1291 | |
| 1292 | The optional argument *parser* specifies the :class:`DocTestParser` object (or a |
| 1293 | drop-in replacement) that is used to extract doctests from docstrings. |
| 1294 | |
| 1295 | If the optional argument *recurse* is false, then :meth:`DocTestFinder.find` |
| 1296 | will only examine the given object, and not any contained objects. |
| 1297 | |
| 1298 | If the optional argument *exclude_empty* is false, then |
| 1299 | :meth:`DocTestFinder.find` will include tests for objects with empty docstrings. |
| 1300 | |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1301 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1302 | :class:`DocTestFinder` defines the following method: |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1303 | |
| 1304 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1305 | .. method:: find(obj[, name][, module][, globs][, extraglobs]) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1306 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1307 | Return a list of the :class:`DocTest`\ s that are defined by *obj*'s |
| 1308 | docstring, or by any of its contained objects' docstrings. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1309 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1310 | The optional argument *name* specifies the object's name; this name will be |
| 1311 | used to construct names for the returned :class:`DocTest`\ s. If *name* is |
| 1312 | not specified, then ``obj.__name__`` is used. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1313 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1314 | The optional parameter *module* is the module that contains the given object. |
| 1315 | If the module is not specified or is None, then the test finder will attempt |
| 1316 | to automatically determine the correct module. The object's module is used: |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1317 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1318 | * As a default namespace, if *globs* is not specified. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1319 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1320 | * To prevent the DocTestFinder from extracting DocTests from objects that are |
| 1321 | imported from other modules. (Contained objects with modules other than |
| 1322 | *module* are ignored.) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1323 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1324 | * To find the name of the file containing the object. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1325 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1326 | * To help find the line number of the object within its file. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1327 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1328 | If *module* is ``False``, no attempt to find the module will be made. This is |
| 1329 | obscure, of use mostly in testing doctest itself: if *module* is ``False``, or |
| 1330 | is ``None`` but cannot be found automatically, then all objects are considered |
| 1331 | to belong to the (non-existent) module, so all contained objects will |
| 1332 | (recursively) be searched for doctests. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1333 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1334 | The globals for each :class:`DocTest` is formed by combining *globs* and |
| 1335 | *extraglobs* (bindings in *extraglobs* override bindings in *globs*). A new |
| 1336 | shallow copy of the globals dictionary is created for each :class:`DocTest`. |
| 1337 | If *globs* is not specified, then it defaults to the module's *__dict__*, if |
| 1338 | specified, or ``{}`` otherwise. If *extraglobs* is not specified, then it |
| 1339 | defaults to ``{}``. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1340 | |
| 1341 | |
| 1342 | .. _doctest-doctestparser: |
| 1343 | |
| 1344 | DocTestParser objects |
| 1345 | ^^^^^^^^^^^^^^^^^^^^^ |
| 1346 | |
| 1347 | |
| 1348 | .. class:: DocTestParser() |
| 1349 | |
| 1350 | A processing class used to extract interactive examples from a string, and use |
| 1351 | them to create a :class:`DocTest` object. |
| 1352 | |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1353 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1354 | :class:`DocTestParser` defines the following methods: |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1355 | |
| 1356 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1357 | .. method:: get_doctest(string, globs, name, filename, lineno) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1358 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1359 | Extract all doctest examples from the given string, and collect them into a |
| 1360 | :class:`DocTest` object. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1361 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1362 | *globs*, *name*, *filename*, and *lineno* are attributes for the new |
| 1363 | :class:`DocTest` object. See the documentation for :class:`DocTest` for more |
| 1364 | information. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1365 | |
| 1366 | |
Georg Brandl | c2a4f4f | 2009-04-10 09:03:43 +0000 | [diff] [blame] | 1367 | .. method:: get_examples(string, name='<string>') |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1368 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1369 | Extract all doctest examples from the given string, and return them as a list |
| 1370 | of :class:`Example` objects. Line numbers are 0-based. The optional argument |
| 1371 | *name* is a name identifying this string, and is only used for error messages. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1372 | |
| 1373 | |
Georg Brandl | c2a4f4f | 2009-04-10 09:03:43 +0000 | [diff] [blame] | 1374 | .. method:: parse(string, name='<string>') |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1375 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1376 | Divide the given string into examples and intervening text, and return them as |
| 1377 | a list of alternating :class:`Example`\ s and strings. Line numbers for the |
| 1378 | :class:`Example`\ s are 0-based. The optional argument *name* is a name |
| 1379 | identifying this string, and is only used for error messages. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1380 | |
| 1381 | |
| 1382 | .. _doctest-doctestrunner: |
| 1383 | |
| 1384 | DocTestRunner objects |
| 1385 | ^^^^^^^^^^^^^^^^^^^^^ |
| 1386 | |
| 1387 | |
Georg Brandl | c2a4f4f | 2009-04-10 09:03:43 +0000 | [diff] [blame] | 1388 | .. class:: DocTestRunner(checker=None, verbose=None, optionflags=0) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1389 | |
| 1390 | A processing class used to execute and verify the interactive examples in a |
| 1391 | :class:`DocTest`. |
| 1392 | |
| 1393 | The comparison between expected outputs and actual outputs is done by an |
| 1394 | :class:`OutputChecker`. This comparison may be customized with a number of |
| 1395 | option flags; see section :ref:`doctest-options` for more information. If the |
| 1396 | option flags are insufficient, then the comparison may also be customized by |
| 1397 | passing a subclass of :class:`OutputChecker` to the constructor. |
| 1398 | |
| 1399 | The test runner's display output can be controlled in two ways. First, an output |
| 1400 | function can be passed to :meth:`TestRunner.run`; this function will be called |
| 1401 | with strings that should be displayed. It defaults to ``sys.stdout.write``. If |
| 1402 | capturing the output is not sufficient, then the display output can be also |
| 1403 | customized by subclassing DocTestRunner, and overriding the methods |
| 1404 | :meth:`report_start`, :meth:`report_success`, |
| 1405 | :meth:`report_unexpected_exception`, and :meth:`report_failure`. |
| 1406 | |
| 1407 | The optional keyword argument *checker* specifies the :class:`OutputChecker` |
| 1408 | object (or drop-in replacement) that should be used to compare the expected |
| 1409 | outputs to the actual outputs of doctest examples. |
| 1410 | |
| 1411 | The optional keyword argument *verbose* controls the :class:`DocTestRunner`'s |
| 1412 | verbosity. If *verbose* is ``True``, then information is printed about each |
| 1413 | example, as it is run. If *verbose* is ``False``, then only failures are |
| 1414 | printed. If *verbose* is unspecified, or ``None``, then verbose output is used |
Éric Araujo | 713d303 | 2010-11-18 16:38:46 +0000 | [diff] [blame] | 1415 | iff the command-line switch ``-v`` is used. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1416 | |
| 1417 | The optional keyword argument *optionflags* can be used to control how the test |
| 1418 | runner compares expected output to actual output, and how it displays failures. |
| 1419 | For more information, see section :ref:`doctest-options`. |
| 1420 | |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1421 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1422 | :class:`DocTestParser` defines the following methods: |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1423 | |
| 1424 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1425 | .. method:: report_start(out, test, example) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1426 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1427 | Report that the test runner is about to process the given example. This method |
| 1428 | is provided to allow subclasses of :class:`DocTestRunner` to customize their |
| 1429 | output; it should not be called directly. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1430 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1431 | *example* is the example about to be processed. *test* is the test |
| 1432 | *containing example*. *out* is the output function that was passed to |
| 1433 | :meth:`DocTestRunner.run`. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1434 | |
| 1435 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1436 | .. method:: report_success(out, test, example, got) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1437 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1438 | Report that the given example ran successfully. This method is provided to |
| 1439 | allow subclasses of :class:`DocTestRunner` to customize their output; it |
| 1440 | should not be called directly. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1441 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1442 | *example* is the example about to be processed. *got* is the actual output |
| 1443 | from the example. *test* is the test containing *example*. *out* is the |
| 1444 | output function that was passed to :meth:`DocTestRunner.run`. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1445 | |
| 1446 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1447 | .. method:: report_failure(out, test, example, got) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1448 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1449 | Report that the given example failed. This method is provided to allow |
| 1450 | subclasses of :class:`DocTestRunner` to customize their output; it should not |
| 1451 | be called directly. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1452 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1453 | *example* is the example about to be processed. *got* is the actual output |
| 1454 | from the example. *test* is the test containing *example*. *out* is the |
| 1455 | output function that was passed to :meth:`DocTestRunner.run`. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1456 | |
| 1457 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1458 | .. method:: report_unexpected_exception(out, test, example, exc_info) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1459 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1460 | Report that the given example raised an unexpected exception. This method is |
| 1461 | provided to allow subclasses of :class:`DocTestRunner` to customize their |
| 1462 | output; it should not be called directly. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1463 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1464 | *example* is the example about to be processed. *exc_info* is a tuple |
| 1465 | containing information about the unexpected exception (as returned by |
| 1466 | :func:`sys.exc_info`). *test* is the test containing *example*. *out* is the |
| 1467 | output function that was passed to :meth:`DocTestRunner.run`. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1468 | |
| 1469 | |
Georg Brandl | c2a4f4f | 2009-04-10 09:03:43 +0000 | [diff] [blame] | 1470 | .. method:: run(test, compileflags=None, out=None, clear_globs=True) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1471 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1472 | Run the examples in *test* (a :class:`DocTest` object), and display the |
| 1473 | results using the writer function *out*. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1474 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1475 | The examples are run in the namespace ``test.globs``. If *clear_globs* is |
| 1476 | true (the default), then this namespace will be cleared after the test runs, |
| 1477 | to help with garbage collection. If you would like to examine the namespace |
| 1478 | after the test completes, then use *clear_globs=False*. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1479 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1480 | *compileflags* gives the set of flags that should be used by the Python |
| 1481 | compiler when running the examples. If not specified, then it will default to |
| 1482 | the set of future-import flags that apply to *globs*. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1483 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1484 | The output of each example is checked using the :class:`DocTestRunner`'s |
| 1485 | output checker, and the results are formatted by the |
| 1486 | :meth:`DocTestRunner.report_\*` methods. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1487 | |
| 1488 | |
Georg Brandl | c2a4f4f | 2009-04-10 09:03:43 +0000 | [diff] [blame] | 1489 | .. method:: summarize(verbose=None) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1490 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1491 | Print a summary of all the test cases that have been run by this DocTestRunner, |
| 1492 | and return a :term:`named tuple` ``TestResults(failed, attempted)``. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1493 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1494 | The optional *verbose* argument controls how detailed the summary is. If the |
| 1495 | verbosity is not specified, then the :class:`DocTestRunner`'s verbosity is |
| 1496 | used. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1497 | |
| 1498 | .. _doctest-outputchecker: |
| 1499 | |
| 1500 | OutputChecker objects |
| 1501 | ^^^^^^^^^^^^^^^^^^^^^ |
| 1502 | |
| 1503 | |
| 1504 | .. class:: OutputChecker() |
| 1505 | |
| 1506 | A class used to check the whether the actual output from a doctest example |
| 1507 | matches the expected output. :class:`OutputChecker` defines two methods: |
| 1508 | :meth:`check_output`, which compares a given pair of outputs, and returns true |
| 1509 | if they match; and :meth:`output_difference`, which returns a string describing |
| 1510 | the differences between two outputs. |
| 1511 | |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1512 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1513 | :class:`OutputChecker` defines the following methods: |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1514 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1515 | .. method:: check_output(want, got, optionflags) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1516 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1517 | Return ``True`` iff the actual output from an example (*got*) matches the |
| 1518 | expected output (*want*). These strings are always considered to match if |
| 1519 | they are identical; but depending on what option flags the test runner is |
| 1520 | using, several non-exact match types are also possible. See section |
| 1521 | :ref:`doctest-options` for more information about option flags. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1522 | |
| 1523 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1524 | .. method:: output_difference(example, got, optionflags) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1525 | |
Benjamin Peterson | e41251e | 2008-04-25 01:59:09 +0000 | [diff] [blame] | 1526 | Return a string describing the differences between the expected output for a |
| 1527 | given example (*example*) and the actual output (*got*). *optionflags* is the |
| 1528 | set of option flags used to compare *want* and *got*. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1529 | |
| 1530 | |
| 1531 | .. _doctest-debugging: |
| 1532 | |
| 1533 | Debugging |
| 1534 | --------- |
| 1535 | |
| 1536 | Doctest provides several mechanisms for debugging doctest examples: |
| 1537 | |
| 1538 | * Several functions convert doctests to executable Python programs, which can be |
| 1539 | run under the Python debugger, :mod:`pdb`. |
| 1540 | |
| 1541 | * The :class:`DebugRunner` class is a subclass of :class:`DocTestRunner` that |
| 1542 | raises an exception for the first failing example, containing information about |
| 1543 | that example. This information can be used to perform post-mortem debugging on |
| 1544 | the example. |
| 1545 | |
| 1546 | * The :mod:`unittest` cases generated by :func:`DocTestSuite` support the |
| 1547 | :meth:`debug` method defined by :class:`unittest.TestCase`. |
| 1548 | |
| 1549 | * You can add a call to :func:`pdb.set_trace` in a doctest example, and you'll |
| 1550 | drop into the Python debugger when that line is executed. Then you can inspect |
| 1551 | current values of variables, and so on. For example, suppose :file:`a.py` |
| 1552 | contains just this module docstring:: |
| 1553 | |
| 1554 | """ |
| 1555 | >>> def f(x): |
| 1556 | ... g(x*2) |
| 1557 | >>> def g(x): |
Georg Brandl | 6911e3c | 2007-09-04 07:15:32 +0000 | [diff] [blame] | 1558 | ... print(x+3) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1559 | ... import pdb; pdb.set_trace() |
| 1560 | >>> f(3) |
| 1561 | 9 |
| 1562 | """ |
| 1563 | |
| 1564 | Then an interactive Python session may look like this:: |
| 1565 | |
| 1566 | >>> import a, doctest |
| 1567 | >>> doctest.testmod(a) |
| 1568 | --Return-- |
| 1569 | > <doctest a[1]>(3)g()->None |
| 1570 | -> import pdb; pdb.set_trace() |
| 1571 | (Pdb) list |
| 1572 | 1 def g(x): |
Georg Brandl | 6911e3c | 2007-09-04 07:15:32 +0000 | [diff] [blame] | 1573 | 2 print(x+3) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1574 | 3 -> import pdb; pdb.set_trace() |
| 1575 | [EOF] |
Georg Brandl | 6911e3c | 2007-09-04 07:15:32 +0000 | [diff] [blame] | 1576 | (Pdb) p x |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1577 | 6 |
| 1578 | (Pdb) step |
| 1579 | --Return-- |
| 1580 | > <doctest a[0]>(2)f()->None |
| 1581 | -> g(x*2) |
| 1582 | (Pdb) list |
| 1583 | 1 def f(x): |
| 1584 | 2 -> g(x*2) |
| 1585 | [EOF] |
Georg Brandl | 6911e3c | 2007-09-04 07:15:32 +0000 | [diff] [blame] | 1586 | (Pdb) p x |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1587 | 3 |
| 1588 | (Pdb) step |
| 1589 | --Return-- |
| 1590 | > <doctest a[2]>(1)?()->None |
| 1591 | -> f(3) |
| 1592 | (Pdb) cont |
| 1593 | (0, 3) |
| 1594 | >>> |
| 1595 | |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1596 | |
| 1597 | Functions that convert doctests to Python code, and possibly run the synthesized |
| 1598 | code under the debugger: |
| 1599 | |
| 1600 | |
| 1601 | .. function:: script_from_examples(s) |
| 1602 | |
| 1603 | Convert text with examples to a script. |
| 1604 | |
| 1605 | Argument *s* is a string containing doctest examples. The string is converted |
| 1606 | to a Python script, where doctest examples in *s* are converted to regular code, |
| 1607 | and everything else is converted to Python comments. The generated script is |
| 1608 | returned as a string. For example, :: |
| 1609 | |
| 1610 | import doctest |
Georg Brandl | 6911e3c | 2007-09-04 07:15:32 +0000 | [diff] [blame] | 1611 | print(doctest.script_from_examples(r""" |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1612 | Set x and y to 1 and 2. |
| 1613 | >>> x, y = 1, 2 |
| 1614 | |
| 1615 | Print their sum: |
Georg Brandl | 6911e3c | 2007-09-04 07:15:32 +0000 | [diff] [blame] | 1616 | >>> print(x+y) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1617 | 3 |
Georg Brandl | 6911e3c | 2007-09-04 07:15:32 +0000 | [diff] [blame] | 1618 | """)) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1619 | |
| 1620 | displays:: |
| 1621 | |
| 1622 | # Set x and y to 1 and 2. |
| 1623 | x, y = 1, 2 |
| 1624 | # |
| 1625 | # Print their sum: |
Georg Brandl | 6911e3c | 2007-09-04 07:15:32 +0000 | [diff] [blame] | 1626 | print(x+y) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1627 | # Expected: |
| 1628 | ## 3 |
| 1629 | |
| 1630 | This function is used internally by other functions (see below), but can also be |
| 1631 | useful when you want to transform an interactive Python session into a Python |
| 1632 | script. |
| 1633 | |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1634 | |
| 1635 | .. function:: testsource(module, name) |
| 1636 | |
| 1637 | Convert the doctest for an object to a script. |
| 1638 | |
| 1639 | Argument *module* is a module object, or dotted name of a module, containing the |
| 1640 | object whose doctests are of interest. Argument *name* is the name (within the |
| 1641 | module) of the object with the doctests of interest. The result is a string, |
| 1642 | containing the object's docstring converted to a Python script, as described for |
| 1643 | :func:`script_from_examples` above. For example, if module :file:`a.py` |
| 1644 | contains a top-level function :func:`f`, then :: |
| 1645 | |
| 1646 | import a, doctest |
Georg Brandl | 6911e3c | 2007-09-04 07:15:32 +0000 | [diff] [blame] | 1647 | print(doctest.testsource(a, "a.f")) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1648 | |
| 1649 | prints a script version of function :func:`f`'s docstring, with doctests |
| 1650 | converted to code, and the rest placed in comments. |
| 1651 | |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1652 | |
Georg Brandl | c2a4f4f | 2009-04-10 09:03:43 +0000 | [diff] [blame] | 1653 | .. function:: debug(module, name, pm=False) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1654 | |
| 1655 | Debug the doctests for an object. |
| 1656 | |
| 1657 | The *module* and *name* arguments are the same as for function |
| 1658 | :func:`testsource` above. The synthesized Python script for the named object's |
| 1659 | docstring is written to a temporary file, and then that file is run under the |
| 1660 | control of the Python debugger, :mod:`pdb`. |
| 1661 | |
| 1662 | A shallow copy of ``module.__dict__`` is used for both local and global |
| 1663 | execution context. |
| 1664 | |
| 1665 | Optional argument *pm* controls whether post-mortem debugging is used. If *pm* |
| 1666 | has a true value, the script file is run directly, and the debugger gets |
| 1667 | involved only if the script terminates via raising an unhandled exception. If |
| 1668 | it does, then post-mortem debugging is invoked, via :func:`pdb.post_mortem`, |
| 1669 | passing the traceback object from the unhandled exception. If *pm* is not |
| 1670 | specified, or is false, the script is run under the debugger from the start, via |
| 1671 | passing an appropriate :func:`exec` call to :func:`pdb.run`. |
| 1672 | |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1673 | |
Georg Brandl | c2a4f4f | 2009-04-10 09:03:43 +0000 | [diff] [blame] | 1674 | .. function:: debug_src(src, pm=False, globs=None) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1675 | |
| 1676 | Debug the doctests in a string. |
| 1677 | |
| 1678 | This is like function :func:`debug` above, except that a string containing |
| 1679 | doctest examples is specified directly, via the *src* argument. |
| 1680 | |
| 1681 | Optional argument *pm* has the same meaning as in function :func:`debug` above. |
| 1682 | |
| 1683 | Optional argument *globs* gives a dictionary to use as both local and global |
| 1684 | execution context. If not specified, or ``None``, an empty dictionary is used. |
| 1685 | If specified, a shallow copy of the dictionary is used. |
| 1686 | |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1687 | |
| 1688 | The :class:`DebugRunner` class, and the special exceptions it may raise, are of |
| 1689 | most interest to testing framework authors, and will only be sketched here. See |
| 1690 | the source code, and especially :class:`DebugRunner`'s docstring (which is a |
| 1691 | doctest!) for more details: |
| 1692 | |
| 1693 | |
Georg Brandl | c2a4f4f | 2009-04-10 09:03:43 +0000 | [diff] [blame] | 1694 | .. class:: DebugRunner(checker=None, verbose=None, optionflags=0) |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1695 | |
| 1696 | A subclass of :class:`DocTestRunner` that raises an exception as soon as a |
| 1697 | failure is encountered. If an unexpected exception occurs, an |
| 1698 | :exc:`UnexpectedException` exception is raised, containing the test, the |
| 1699 | example, and the original exception. If the output doesn't match, then a |
| 1700 | :exc:`DocTestFailure` exception is raised, containing the test, the example, and |
| 1701 | the actual output. |
| 1702 | |
| 1703 | For information about the constructor parameters and methods, see the |
| 1704 | documentation for :class:`DocTestRunner` in section :ref:`doctest-advanced-api`. |
| 1705 | |
| 1706 | There are two exceptions that may be raised by :class:`DebugRunner` instances: |
| 1707 | |
| 1708 | |
| 1709 | .. exception:: DocTestFailure(test, example, got) |
| 1710 | |
Georg Brandl | 7cb1319 | 2010-08-03 12:06:29 +0000 | [diff] [blame] | 1711 | An exception raised by :class:`DocTestRunner` to signal that a doctest example's |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1712 | actual output did not match its expected output. The constructor arguments are |
Senthil Kumaran | a6bac95 | 2011-07-04 11:28:30 -0700 | [diff] [blame] | 1713 | used to initialize the attributes of the same names. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1714 | |
Senthil Kumaran | a6bac95 | 2011-07-04 11:28:30 -0700 | [diff] [blame] | 1715 | :exc:`DocTestFailure` defines the following attributes: |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1716 | |
| 1717 | |
| 1718 | .. attribute:: DocTestFailure.test |
| 1719 | |
| 1720 | The :class:`DocTest` object that was being run when the example failed. |
| 1721 | |
| 1722 | |
| 1723 | .. attribute:: DocTestFailure.example |
| 1724 | |
| 1725 | The :class:`Example` that failed. |
| 1726 | |
| 1727 | |
| 1728 | .. attribute:: DocTestFailure.got |
| 1729 | |
| 1730 | The example's actual output. |
| 1731 | |
| 1732 | |
| 1733 | .. exception:: UnexpectedException(test, example, exc_info) |
| 1734 | |
Georg Brandl | 7cb1319 | 2010-08-03 12:06:29 +0000 | [diff] [blame] | 1735 | An exception raised by :class:`DocTestRunner` to signal that a doctest |
| 1736 | example raised an unexpected exception. The constructor arguments are used |
Senthil Kumaran | a6bac95 | 2011-07-04 11:28:30 -0700 | [diff] [blame] | 1737 | to initialize the attributes of the same names. |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1738 | |
Senthil Kumaran | a6bac95 | 2011-07-04 11:28:30 -0700 | [diff] [blame] | 1739 | :exc:`UnexpectedException` defines the following attributes: |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1740 | |
| 1741 | |
| 1742 | .. attribute:: UnexpectedException.test |
| 1743 | |
| 1744 | The :class:`DocTest` object that was being run when the example failed. |
| 1745 | |
| 1746 | |
| 1747 | .. attribute:: UnexpectedException.example |
| 1748 | |
| 1749 | The :class:`Example` that failed. |
| 1750 | |
| 1751 | |
| 1752 | .. attribute:: UnexpectedException.exc_info |
| 1753 | |
| 1754 | A tuple containing information about the unexpected exception, as returned by |
| 1755 | :func:`sys.exc_info`. |
| 1756 | |
| 1757 | |
| 1758 | .. _doctest-soapbox: |
| 1759 | |
| 1760 | Soapbox |
| 1761 | ------- |
| 1762 | |
| 1763 | As mentioned in the introduction, :mod:`doctest` has grown to have three primary |
| 1764 | uses: |
| 1765 | |
| 1766 | #. Checking examples in docstrings. |
| 1767 | |
| 1768 | #. Regression testing. |
| 1769 | |
| 1770 | #. Executable documentation / literate testing. |
| 1771 | |
| 1772 | These uses have different requirements, and it is important to distinguish them. |
| 1773 | In particular, filling your docstrings with obscure test cases makes for bad |
| 1774 | documentation. |
| 1775 | |
| 1776 | When writing a docstring, choose docstring examples with care. There's an art to |
| 1777 | this that needs to be learned---it may not be natural at first. Examples should |
| 1778 | add genuine value to the documentation. A good example can often be worth many |
| 1779 | words. If done with care, the examples will be invaluable for your users, and |
| 1780 | will pay back the time it takes to collect them many times over as the years go |
| 1781 | by and things change. I'm still amazed at how often one of my :mod:`doctest` |
| 1782 | examples stops working after a "harmless" change. |
| 1783 | |
| 1784 | Doctest also makes an excellent tool for regression testing, especially if you |
| 1785 | don't skimp on explanatory text. By interleaving prose and examples, it becomes |
| 1786 | much easier to keep track of what's actually being tested, and why. When a test |
| 1787 | fails, good prose can make it much easier to figure out what the problem is, and |
| 1788 | how it should be fixed. It's true that you could write extensive comments in |
| 1789 | code-based testing, but few programmers do. Many have found that using doctest |
| 1790 | approaches instead leads to much clearer tests. Perhaps this is simply because |
| 1791 | doctest makes writing prose a little easier than writing code, while writing |
| 1792 | comments in code is a little harder. I think it goes deeper than just that: |
| 1793 | the natural attitude when writing a doctest-based test is that you want to |
| 1794 | explain the fine points of your software, and illustrate them with examples. |
| 1795 | This in turn naturally leads to test files that start with the simplest |
| 1796 | features, and logically progress to complications and edge cases. A coherent |
| 1797 | narrative is the result, instead of a collection of isolated functions that test |
| 1798 | isolated bits of functionality seemingly at random. It's a different attitude, |
| 1799 | and produces different results, blurring the distinction between testing and |
| 1800 | explaining. |
| 1801 | |
| 1802 | Regression testing is best confined to dedicated objects or files. There are |
| 1803 | several options for organizing tests: |
| 1804 | |
| 1805 | * Write text files containing test cases as interactive examples, and test the |
| 1806 | files using :func:`testfile` or :func:`DocFileSuite`. This is recommended, |
| 1807 | although is easiest to do for new projects, designed from the start to use |
| 1808 | doctest. |
| 1809 | |
| 1810 | * Define functions named ``_regrtest_topic`` that consist of single docstrings, |
| 1811 | containing test cases for the named topics. These functions can be included in |
| 1812 | the same file as the module, or separated out into a separate test file. |
| 1813 | |
| 1814 | * Define a ``__test__`` dictionary mapping from regression test topics to |
| 1815 | docstrings containing test cases. |
| 1816 | |
Ethan Furman | 2a5f9da | 2015-09-17 22:20:41 -0700 | [diff] [blame] | 1817 | When you have placed your tests in a module, the module can itself be the test |
| 1818 | runner. When a test fails, you can arrange for your test runner to re-run only |
| 1819 | the failing doctest while you debug the problem. Here is a minimal example of |
| 1820 | such a test runner:: |
| 1821 | |
| 1822 | if __name__ == '__main__': |
| 1823 | import doctest |
| 1824 | flags = doctest.REPORT_NDIFF|doctest.FAIL_FAST |
| 1825 | if len(sys.argv) > 1: |
| 1826 | name = sys.argv[1] |
| 1827 | if name in globals(): |
| 1828 | obj = globals()[name] |
| 1829 | else: |
| 1830 | obj = __test__[name] |
| 1831 | doctest.run_docstring_examples(obj, globals(), name=name, |
| 1832 | optionflags=flags) |
| 1833 | else: |
| 1834 | fail, total = doctest.testmod(optionflags=flags) |
| 1835 | print("{} failures out of {} tests".format(fail, total)) |
| 1836 | |
| 1837 | |
Georg Brandl | 116aa62 | 2007-08-15 14:28:22 +0000 | [diff] [blame] | 1838 | .. rubric:: Footnotes |
| 1839 | |
| 1840 | .. [#] Examples containing both expected output and an exception are not supported. |
| 1841 | Trying to guess where one ends and the other begins is too error-prone, and that |
| 1842 | also makes for a confusing test. |