2009-05-05 05:31:54 -03:00
|
|
|
""" Tests for the linecache module """
|
|
|
|
|
|
|
|
import linecache
|
|
|
|
import unittest
|
|
|
|
import os.path
|
|
|
|
from test import support
|
|
|
|
|
|
|
|
|
|
|
|
FILENAME = linecache.__file__
|
2015-03-04 19:07:57 -04:00
|
|
|
NONEXISTENT_FILENAME = FILENAME + '.missing'
|
2009-05-05 05:31:54 -03:00
|
|
|
INVALID_NAME = '!@$)(!@#_1'
|
|
|
|
EMPTY = ''
|
2011-05-16 12:18:51 -03:00
|
|
|
TESTS = 'inspect_fodder inspect_fodder2 mapping_tests'
|
2009-05-05 05:31:54 -03:00
|
|
|
TESTS = TESTS.split()
|
2013-07-28 07:56:19 -03:00
|
|
|
TEST_PATH = os.path.dirname(__file__)
|
2009-07-19 18:01:52 -03:00
|
|
|
MODULES = "linecache abc".split()
|
2009-05-05 05:31:54 -03:00
|
|
|
MODULE_PATH = os.path.dirname(FILENAME)
|
|
|
|
|
|
|
|
SOURCE_1 = '''
|
|
|
|
" Docstring "
|
|
|
|
|
|
|
|
def function():
|
|
|
|
return result
|
|
|
|
|
|
|
|
'''
|
|
|
|
|
|
|
|
SOURCE_2 = '''
|
|
|
|
def f():
|
|
|
|
return 1 + 1
|
|
|
|
|
|
|
|
a = f()
|
|
|
|
|
|
|
|
'''
|
|
|
|
|
2010-05-21 18:45:06 -03:00
|
|
|
SOURCE_3 = '''
|
|
|
|
def f():
|
|
|
|
return 3''' # No ending newline
|
|
|
|
|
|
|
|
|
2009-05-05 05:31:54 -03:00
|
|
|
class LineCacheTests(unittest.TestCase):
|
|
|
|
|
|
|
|
def test_getline(self):
|
|
|
|
getline = linecache.getline
|
|
|
|
|
|
|
|
# Bad values for line number should return an empty string
|
2010-11-20 15:04:17 -04:00
|
|
|
self.assertEqual(getline(FILENAME, 2**15), EMPTY)
|
|
|
|
self.assertEqual(getline(FILENAME, -1), EMPTY)
|
2009-05-05 05:31:54 -03:00
|
|
|
|
|
|
|
# Float values currently raise TypeError, should it?
|
|
|
|
self.assertRaises(TypeError, getline, FILENAME, 1.1)
|
|
|
|
|
|
|
|
# Bad filenames should return an empty string
|
2010-11-20 15:04:17 -04:00
|
|
|
self.assertEqual(getline(EMPTY, 1), EMPTY)
|
|
|
|
self.assertEqual(getline(INVALID_NAME, 1), EMPTY)
|
2009-05-05 05:31:54 -03:00
|
|
|
|
|
|
|
# Check whether lines correspond to those from file iteration
|
|
|
|
for entry in TESTS:
|
|
|
|
filename = os.path.join(TEST_PATH, entry) + '.py'
|
2010-10-29 20:55:51 -03:00
|
|
|
with open(filename) as file:
|
|
|
|
for index, line in enumerate(file):
|
2010-11-20 15:04:17 -04:00
|
|
|
self.assertEqual(line, getline(filename, index + 1))
|
2009-05-05 05:31:54 -03:00
|
|
|
|
|
|
|
# Check module loading
|
|
|
|
for entry in MODULES:
|
|
|
|
filename = os.path.join(MODULE_PATH, entry) + '.py'
|
2010-10-29 20:55:51 -03:00
|
|
|
with open(filename) as file:
|
|
|
|
for index, line in enumerate(file):
|
2010-11-20 15:04:17 -04:00
|
|
|
self.assertEqual(line, getline(filename, index + 1))
|
2009-05-05 05:31:54 -03:00
|
|
|
|
|
|
|
# Check that bogus data isn't returned (issue #1309567)
|
|
|
|
empty = linecache.getlines('a/b/c/__init__.py')
|
2010-11-20 15:04:17 -04:00
|
|
|
self.assertEqual(empty, [])
|
2009-05-05 05:31:54 -03:00
|
|
|
|
2010-05-21 18:45:06 -03:00
|
|
|
def test_no_ending_newline(self):
|
|
|
|
self.addCleanup(support.unlink, support.TESTFN)
|
|
|
|
with open(support.TESTFN, "w") as fp:
|
|
|
|
fp.write(SOURCE_3)
|
|
|
|
lines = linecache.getlines(support.TESTFN)
|
|
|
|
self.assertEqual(lines, ["\n", "def f():\n", " return 3\n"])
|
|
|
|
|
2009-05-05 05:31:54 -03:00
|
|
|
def test_clearcache(self):
|
|
|
|
cached = []
|
|
|
|
for entry in TESTS:
|
|
|
|
filename = os.path.join(TEST_PATH, entry) + '.py'
|
|
|
|
cached.append(filename)
|
|
|
|
linecache.getline(filename, 1)
|
|
|
|
|
|
|
|
# Are all files cached?
|
|
|
|
cached_empty = [fn for fn in cached if fn not in linecache.cache]
|
2010-11-20 15:04:17 -04:00
|
|
|
self.assertEqual(cached_empty, [])
|
2009-05-05 05:31:54 -03:00
|
|
|
|
|
|
|
# Can we clear the cache?
|
|
|
|
linecache.clearcache()
|
|
|
|
cached_empty = [fn for fn in cached if fn in linecache.cache]
|
2010-11-20 15:04:17 -04:00
|
|
|
self.assertEqual(cached_empty, [])
|
2009-05-05 05:31:54 -03:00
|
|
|
|
|
|
|
def test_checkcache(self):
|
|
|
|
getline = linecache.getline
|
2010-05-21 18:45:06 -03:00
|
|
|
# Create a source file and cache its contents
|
|
|
|
source_name = support.TESTFN + '.py'
|
|
|
|
self.addCleanup(support.unlink, source_name)
|
|
|
|
with open(source_name, 'w') as source:
|
|
|
|
source.write(SOURCE_1)
|
|
|
|
getline(source_name, 1)
|
|
|
|
|
|
|
|
# Keep a copy of the old contents
|
|
|
|
source_list = []
|
|
|
|
with open(source_name) as source:
|
|
|
|
for index, line in enumerate(source):
|
2010-11-20 15:04:17 -04:00
|
|
|
self.assertEqual(line, getline(source_name, index + 1))
|
2010-05-21 18:45:06 -03:00
|
|
|
source_list.append(line)
|
2009-12-03 20:09:14 -04:00
|
|
|
|
2010-05-21 18:45:06 -03:00
|
|
|
with open(source_name, 'w') as source:
|
|
|
|
source.write(SOURCE_2)
|
2009-12-03 20:09:14 -04:00
|
|
|
|
2010-05-21 18:45:06 -03:00
|
|
|
# Try to update a bogus cache entry
|
|
|
|
linecache.checkcache('dummy')
|
|
|
|
|
|
|
|
# Check that the cache matches the old contents
|
|
|
|
for index, line in enumerate(source_list):
|
2010-11-20 15:04:17 -04:00
|
|
|
self.assertEqual(line, getline(source_name, index + 1))
|
2010-05-21 18:45:06 -03:00
|
|
|
|
|
|
|
# Update the cache and check whether it matches the new source file
|
|
|
|
linecache.checkcache(source_name)
|
|
|
|
with open(source_name) as source:
|
|
|
|
for index, line in enumerate(source):
|
2010-11-20 15:04:17 -04:00
|
|
|
self.assertEqual(line, getline(source_name, index + 1))
|
2010-05-21 18:45:06 -03:00
|
|
|
source_list.append(line)
|
2009-05-05 05:31:54 -03:00
|
|
|
|
2015-03-04 19:07:57 -04:00
|
|
|
def test_lazycache_no_globals(self):
|
|
|
|
lines = linecache.getlines(FILENAME)
|
|
|
|
linecache.clearcache()
|
|
|
|
self.assertEqual(False, linecache.lazycache(FILENAME, None))
|
|
|
|
self.assertEqual(lines, linecache.getlines(FILENAME))
|
|
|
|
|
|
|
|
def test_lazycache_smoke(self):
|
|
|
|
lines = linecache.getlines(NONEXISTENT_FILENAME, globals())
|
|
|
|
linecache.clearcache()
|
|
|
|
self.assertEqual(
|
|
|
|
True, linecache.lazycache(NONEXISTENT_FILENAME, globals()))
|
|
|
|
self.assertEqual(1, len(linecache.cache[NONEXISTENT_FILENAME]))
|
|
|
|
# Note here that we're looking up a non existant filename with no
|
|
|
|
# globals: this would error if the lazy value wasn't resolved.
|
|
|
|
self.assertEqual(lines, linecache.getlines(NONEXISTENT_FILENAME))
|
|
|
|
|
|
|
|
def test_lazycache_provide_after_failed_lookup(self):
|
|
|
|
linecache.clearcache()
|
|
|
|
lines = linecache.getlines(NONEXISTENT_FILENAME, globals())
|
|
|
|
linecache.clearcache()
|
|
|
|
linecache.getlines(NONEXISTENT_FILENAME)
|
|
|
|
linecache.lazycache(NONEXISTENT_FILENAME, globals())
|
|
|
|
self.assertEqual(lines, linecache.updatecache(NONEXISTENT_FILENAME))
|
|
|
|
|
|
|
|
def test_lazycache_check(self):
|
|
|
|
linecache.clearcache()
|
|
|
|
linecache.lazycache(NONEXISTENT_FILENAME, globals())
|
|
|
|
linecache.checkcache()
|
|
|
|
|
|
|
|
def test_lazycache_bad_filename(self):
|
|
|
|
linecache.clearcache()
|
|
|
|
self.assertEqual(False, linecache.lazycache('', globals()))
|
|
|
|
self.assertEqual(False, linecache.lazycache('<foo>', globals()))
|
|
|
|
|
|
|
|
def test_lazycache_already_cached(self):
|
|
|
|
linecache.clearcache()
|
|
|
|
lines = linecache.getlines(NONEXISTENT_FILENAME, globals())
|
|
|
|
self.assertEqual(
|
|
|
|
False,
|
|
|
|
linecache.lazycache(NONEXISTENT_FILENAME, globals()))
|
|
|
|
self.assertEqual(4, len(linecache.cache[NONEXISTENT_FILENAME]))
|
|
|
|
|
|
|
|
|
2009-05-05 05:31:54 -03:00
|
|
|
def test_main():
|
|
|
|
support.run_unittest(LineCacheTests)
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
test_main()
|