summaryrefslogtreecommitdiff
path: root/Lib/test/test_linecache.py
diff options
context:
space:
mode:
authorSerhiy Storchaka <storchaka@gmail.com>2015-04-01 16:56:13 +0300
committerSerhiy Storchaka <storchaka@gmail.com>2015-04-01 16:56:13 +0300
commit05ddbf0875b449f69616c31fbbe49dd5f3d5e329 (patch)
treee7cbf07a3fad26c69006f38e2216d5c56d1c786b /Lib/test/test_linecache.py
parentef2a397a65bf5f321a04aa429efa76f910849e31 (diff)
parentc512adc90d49b1dae3ae14c81826e03c9ea46ba5 (diff)
downloadcpython-git-05ddbf0875b449f69616c31fbbe49dd5f3d5e329.tar.gz
Issue #23838: linecache now clears the cache and returns an empty result on
MemoryError.
Diffstat (limited to 'Lib/test/test_linecache.py')
-rw-r--r--Lib/test/test_linecache.py18
1 files changed, 15 insertions, 3 deletions
diff --git a/Lib/test/test_linecache.py b/Lib/test/test_linecache.py
index 2fb86626f7..21ef738932 100644
--- a/Lib/test/test_linecache.py
+++ b/Lib/test/test_linecache.py
@@ -169,9 +169,21 @@ class LineCacheTests(unittest.TestCase):
linecache.lazycache(NONEXISTENT_FILENAME, globals()))
self.assertEqual(4, len(linecache.cache[NONEXISTENT_FILENAME]))
+ def test_memoryerror(self):
+ lines = linecache.getlines(FILENAME)
+ self.assertTrue(lines)
+ def raise_memoryerror(*args, **kwargs):
+ raise MemoryError
+ with support.swap_attr(linecache, 'updatecache', raise_memoryerror):
+ lines2 = linecache.getlines(FILENAME)
+ self.assertEqual(lines2, lines)
+
+ linecache.clearcache()
+ with support.swap_attr(linecache, 'updatecache', raise_memoryerror):
+ lines3 = linecache.getlines(FILENAME)
+ self.assertEqual(lines3, [])
+ self.assertEqual(linecache.getlines(FILENAME), lines)
-def test_main():
- support.run_unittest(LineCacheTests)
if __name__ == "__main__":
- test_main()
+ unittest.main()