summaryrefslogtreecommitdiffstats
path: root/Doc
diff options
context:
space:
mode:
authorEthan Furman <ethan@stoneleaf.us>2015-09-18 05:19:48 (GMT)
committerEthan Furman <ethan@stoneleaf.us>2015-09-18 05:19:48 (GMT)
commitb85154fa37c446851c937efff546573551a6faa5 (patch)
tree38244db3c8562725c9ab3dfefce18dae6ae26eb3 /Doc
parentdf11d7c2b42ff6baadd81a96ce7e61799105049c (diff)
downloadcpython-b85154fa37c446851c937efff546573551a6faa5.zip
cpython-b85154fa37c446851c937efff546573551a6faa5.tar.gz
cpython-b85154fa37c446851c937efff546573551a6faa5.tar.bz2
Issue24756: clarify usage of run_docstring_examples()
Diffstat (limited to 'Doc')
-rw-r--r--Doc/library/doctest.rst29
1 files changed, 23 insertions, 6 deletions
diff --git a/Doc/library/doctest.rst b/Doc/library/doctest.rst
index a1e270d..4558123 100644
--- a/Doc/library/doctest.rst
+++ b/Doc/library/doctest.rst
@@ -950,15 +950,11 @@ and :ref:`doctest-simple-testfile`.
.. versionchanged:: 2.5
The optional argument *isprivate*, deprecated in 2.4, was removed.
-There's also a function to run the doctests associated with a single object.
-This function is provided for backward compatibility. There are no plans to
-deprecate it, but it's rarely useful:
-
.. function:: run_docstring_examples(f, globs[, verbose][, name][, compileflags][, optionflags])
- Test examples associated with object *f*; for example, *f* may be a module,
- function, or class object.
+ Test examples associated with object *f*; for example, *f* may be a string,
+ a module, a function, or a class object.
A shallow copy of dictionary argument *globs* is used for the execution context.
@@ -1899,6 +1895,27 @@ several options for organizing tests:
* Define a ``__test__`` dictionary mapping from regression test topics to
docstrings containing test cases.
+When you have placed your tests in a module, the module can itself be the test
+runner. When a test fails, you can arrange for your test runner to re-run only
+the failing doctest while you debug the problem. Here is a minimal example of
+such a test runner::
+
+ if __name__ == '__main__':
+ import doctest
+ flags = doctest.REPORT_NDIFF|doctest.REPORT_ONLY_FIRST_FAILURE
+ if len(sys.argv) > 1:
+ name = sys.argv[1]
+ if name in globals():
+ obj = globals()[name]
+ else:
+ obj = __test__[name]
+ doctest.run_docstring_examples(obj, globals(), name=name,
+ optionflags=flags)
+ else:
+ fail, total = doctest.testmod(optionflags=flags)
+ print("{} failures out of {} tests".format(fail, total))
+
+
.. rubric:: Footnotes
.. [#] Examples containing both expected output and an exception are not supported.