mirror of
				https://github.com/python/cpython.git
				synced 2025-11-04 11:49:12 +00:00 
			
		
		
		
	svn+ssh://pythondev@svn.python.org/python/trunk ........ r76659 | r.david.murray | 2009-12-03 18:57:59 -0500 (Thu, 03 Dec 2009) | 4 lines Issue 7431: use TESTFN in test_linecache instead of trying to create a file in the Lib/test directory, which might be read-only for the user running the tests. ........
		
			
				
	
	
		
			125 lines
		
	
	
	
		
			3.9 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			125 lines
		
	
	
	
		
			3.9 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
""" Tests for the linecache module """
 | 
						|
 | 
						|
import linecache
 | 
						|
import unittest
 | 
						|
import os.path
 | 
						|
from test import support
 | 
						|
 | 
						|
 | 
						|
FILENAME = linecache.__file__
 | 
						|
INVALID_NAME = '!@$)(!@#_1'
 | 
						|
EMPTY = ''
 | 
						|
TESTS = 'cjkencodings_test inspect_fodder inspect_fodder2 mapping_tests'
 | 
						|
TESTS = TESTS.split()
 | 
						|
TEST_PATH = os.path.dirname(support.__file__)
 | 
						|
MODULES = "linecache abc".split()
 | 
						|
MODULE_PATH = os.path.dirname(FILENAME)
 | 
						|
 | 
						|
SOURCE_1 = '''
 | 
						|
" Docstring "
 | 
						|
 | 
						|
def function():
 | 
						|
    return result
 | 
						|
 | 
						|
'''
 | 
						|
 | 
						|
SOURCE_2 = '''
 | 
						|
def f():
 | 
						|
    return 1 + 1
 | 
						|
 | 
						|
a = f()
 | 
						|
 | 
						|
'''
 | 
						|
 | 
						|
class LineCacheTests(unittest.TestCase):
 | 
						|
 | 
						|
    def test_getline(self):
 | 
						|
        getline = linecache.getline
 | 
						|
 | 
						|
        # Bad values for line number should return an empty string
 | 
						|
        self.assertEquals(getline(FILENAME, 2**15), EMPTY)
 | 
						|
        self.assertEquals(getline(FILENAME, -1), EMPTY)
 | 
						|
 | 
						|
        # Float values currently raise TypeError, should it?
 | 
						|
        self.assertRaises(TypeError, getline, FILENAME, 1.1)
 | 
						|
 | 
						|
        # Bad filenames should return an empty string
 | 
						|
        self.assertEquals(getline(EMPTY, 1), EMPTY)
 | 
						|
        self.assertEquals(getline(INVALID_NAME, 1), EMPTY)
 | 
						|
 | 
						|
        # Check whether lines correspond to those from file iteration
 | 
						|
        for entry in TESTS:
 | 
						|
            filename = os.path.join(TEST_PATH, entry) + '.py'
 | 
						|
            for index, line in enumerate(open(filename)):
 | 
						|
                self.assertEquals(line, getline(filename, index + 1))
 | 
						|
 | 
						|
        # Check module loading
 | 
						|
        for entry in MODULES:
 | 
						|
            filename = os.path.join(MODULE_PATH, entry) + '.py'
 | 
						|
            for index, line in enumerate(open(filename)):
 | 
						|
                self.assertEquals(line, getline(filename, index + 1))
 | 
						|
 | 
						|
        # Check that bogus data isn't returned (issue #1309567)
 | 
						|
        empty = linecache.getlines('a/b/c/__init__.py')
 | 
						|
        self.assertEquals(empty, [])
 | 
						|
 | 
						|
    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]
 | 
						|
        self.assertEquals(cached_empty, [])
 | 
						|
 | 
						|
        # Can we clear the cache?
 | 
						|
        linecache.clearcache()
 | 
						|
        cached_empty = [fn for fn in cached if fn in linecache.cache]
 | 
						|
        self.assertEquals(cached_empty, [])
 | 
						|
 | 
						|
    def test_checkcache(self):
 | 
						|
        getline = linecache.getline
 | 
						|
        try:
 | 
						|
            # Create a source file and cache its contents
 | 
						|
            source_name = support.TESTFN + '.py'
 | 
						|
            with open(source_name, 'w') as source:
 | 
						|
                source.write(SOURCE_1)
 | 
						|
                source.close()
 | 
						|
                getline(source_name, 1)
 | 
						|
 | 
						|
                # Keep a copy of the old contents
 | 
						|
                source_list = []
 | 
						|
                source = open(source_name)
 | 
						|
                for index, line in enumerate(source):
 | 
						|
                    self.assertEquals(line, getline(source_name, index + 1))
 | 
						|
                    source_list.append(line)
 | 
						|
                source.close()
 | 
						|
 | 
						|
                source = open(source_name, 'w')
 | 
						|
                source.write(SOURCE_2)
 | 
						|
                source.close()
 | 
						|
 | 
						|
                # 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):
 | 
						|
                    self.assertEquals(line, getline(source_name, index + 1))
 | 
						|
 | 
						|
                # Update the cache and check whether it matches the new source file
 | 
						|
                linecache.checkcache(source_name)
 | 
						|
                source = open(source_name)
 | 
						|
                for index, line in enumerate(source):
 | 
						|
                    self.assertEquals(line, getline(source_name, index + 1))
 | 
						|
                    source_list.append(line)
 | 
						|
 | 
						|
        finally:
 | 
						|
            support.unlink(source_name)
 | 
						|
 | 
						|
def test_main():
 | 
						|
    support.run_unittest(LineCacheTests)
 | 
						|
 | 
						|
if __name__ == "__main__":
 | 
						|
    test_main()
 |