defaults to a normal parser (i.e., \code{\class{DocTestParser}()}).
\versionadded{2.4}
+
+ Starting in Python 2.5, the global \code{__file__} was added to the
+ globals provided to doctests loaded from a text file using
+ \function{DocFileSuite()}.
\end{funcdesc}
\begin{funcdesc}{DocTestSuite}{\optional{module}\optional{,
globs=None, parser=DocTestParser(), **options):
if globs is None:
globs = {}
+ else:
+ globs = globs.copy()
if package and not module_relative:
raise ValueError("Package may only be specified for module-"
if module_relative:
package = _normalize_module(package)
path = _module_relative_path(package, path)
+ if "__file__" not in globs:
+ globs["__file__"] = path
# Find the file and read it.
name = os.path.basename(path)
modified the test globals. The test globals are
automatically cleared for us after a test.
+ Tests in a file run using `DocFileSuite` can also access the
+ `__file__` global, which is set to the name of the file
+ containing the tests:
+
+ >>> suite = doctest.DocFileSuite('test_doctest3.txt')
+ >>> suite.run(unittest.TestResult())
+ <unittest.TestResult run=1 errors=0 failures=0>
+
"""
def test_trailing_space_in_test():
--- /dev/null
+
+Here we check that `__file__` is provided:
+
+ >>> type(__file__)
+ <type 'str'>