summaryrefslogtreecommitdiff
path: root/Lib/test/test_tokenize.py
diff options
context:
space:
mode:
authorVictor Stinner <victor.stinner@gmail.com>2015-05-26 00:46:44 +0200
committerVictor Stinner <victor.stinner@gmail.com>2015-05-26 00:46:44 +0200
commit24d262af0b16f76415baa6187c8892de1682c8a6 (patch)
treea13a4f056c5c47989c637f1131a26fe473757126 /Lib/test/test_tokenize.py
parente6efbdc94760ba0ca410d037b55ac32020de5cb2 (diff)
parent387729e183365a366c48fce7a9abfcaf4ec6ff4e (diff)
downloadcpython-git-24d262af0b16f76415baa6187c8892de1682c8a6.tar.gz
(Merge 3.5) Issue #23840: tokenize.open() now closes the temporary binary file
on error to fix a resource warning.
Diffstat (limited to 'Lib/test/test_tokenize.py')
-rw-r--r--Lib/test/test_tokenize.py10
1 files changed, 9 insertions, 1 deletions
diff --git a/Lib/test/test_tokenize.py b/Lib/test/test_tokenize.py
index 43fadaf1a3..b4e114c844 100644
--- a/Lib/test/test_tokenize.py
+++ b/Lib/test/test_tokenize.py
@@ -834,7 +834,7 @@ from tokenize import (tokenize, _tokenize, untokenize, NUMBER, NAME, OP,
STRING, ENDMARKER, ENCODING, tok_name, detect_encoding,
open as tokenize_open, Untokenizer)
from io import BytesIO
-from unittest import TestCase
+from unittest import TestCase, mock
import os, sys, glob
import token
@@ -1246,6 +1246,14 @@ class TestDetectEncoding(TestCase):
ins = Bunk(lines, path)
detect_encoding(ins.readline)
+ def test_open_error(self):
+ # Issue #23840: open() must close the binary file on error
+ m = BytesIO(b'#coding:xxx')
+ with mock.patch('tokenize._builtin_open', return_value=m):
+ self.assertRaises(SyntaxError, tokenize_open, 'foobar')
+ self.assertTrue(m.closed)
+
+
class TestTokenize(TestCase):