From: Tim Peters Date: Mon, 23 Aug 2004 21:37:56 +0000 (+0000) Subject: debug_script(): I changed this in haste before to take out the use of X-Git-Tag: v2.4a3~146 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=b6a04d687da3803b7ed7434141a8d820d181f2a0;p=python debug_script(): I changed this in haste before to take out the use of NamedTemporaryFile (which can't work for this function's purposes on Windows). Leaving temp files behind wasn't a great idea either, though, so try to clean up. At least the test suite no longer leaves any of these guys behind now. --- diff --git a/Lib/doctest.py b/Lib/doctest.py index 4d1aa712b0..bcdc567bdc 100644 --- a/Lib/doctest.py +++ b/Lib/doctest.py @@ -2342,26 +2342,33 @@ def debug_script(src, pm=False, globs=None): "Debug a test script. `src` is the script, as a string." import pdb - srcfilename = tempfile.mktemp("doctestdebug.py") + # Note that tempfile.NameTemporaryFile() cannot be used. As the + # docs say, a file so created cannot be opened by name a second time + # on modern Windows boxes, and execfile() needs to open it. + srcfilename = tempfile.mktemp(".py", "doctestdebug") f = open(srcfilename, 'w') f.write(src) f.close() - if globs: - globs = globs.copy() - else: - globs = {} + try: + if globs: + globs = globs.copy() + else: + globs = {} - if pm: - try: - execfile(srcfilename, globs, globs) - except: - print sys.exc_info()[1] - pdb.post_mortem(sys.exc_info()[2]) - else: - # Note that %r is vital here. '%s' instead can, e.g., cause - # backslashes to get treated as metacharacters on Windows. - pdb.run("execfile(%r)" % srcfilename, globs, globs) + if pm: + try: + execfile(srcfilename, globs, globs) + except: + print sys.exc_info()[1] + pdb.post_mortem(sys.exc_info()[2]) + else: + # Note that %r is vital here. '%s' instead can, e.g., cause + # backslashes to get treated as metacharacters on Windows. + pdb.run("execfile(%r)" % srcfilename, globs, globs) + + finally: + os.remove(srcfilename) def debug(module, name, pm=False): """Debug a single doctest docstring.