Issue #21707: Add missing kwonlyargcount argument to ModuleFinder.replace_paths_in_code().

This commit is contained in:
Berker Peksag 2014-07-07 14:58:12 +03:00
parent 344f8316fd
commit 0a0d1da987
3 changed files with 21 additions and 9 deletions

View File

@ -568,11 +568,12 @@ class ModuleFinder:
if isinstance(consts[i], type(co)):
consts[i] = self.replace_paths_in_code(consts[i])
return types.CodeType(co.co_argcount, co.co_nlocals, co.co_stacksize,
co.co_flags, co.co_code, tuple(consts), co.co_names,
co.co_varnames, new_filename, co.co_name,
co.co_firstlineno, co.co_lnotab,
co.co_freevars, co.co_cellvars)
return types.CodeType(co.co_argcount, co.co_kwonlyargcount,
co.co_nlocals, co.co_stacksize, co.co_flags,
co.co_code, tuple(consts), co.co_names,
co.co_varnames, new_filename, co.co_name,
co.co_firstlineno, co.co_lnotab, co.co_freevars,
co.co_cellvars)
def test():

View File

@ -245,11 +245,12 @@ def create_package(source):
class ModuleFinderTest(unittest.TestCase):
def _do_test(self, info, report=False):
def _do_test(self, info, report=False, debug=0, replace_paths=[]):
import_this, modules, missing, maybe_missing, source = info
create_package(source)
try:
mf = modulefinder.ModuleFinder(path=TEST_PATH)
mf = modulefinder.ModuleFinder(path=TEST_PATH, debug=debug,
replace_paths=replace_paths)
mf.import_hook(import_this)
if report:
mf.report()
@ -308,9 +309,16 @@ class ModuleFinderTest(unittest.TestCase):
os.remove(source_path)
self._do_test(bytecode_test)
def test_replace_paths(self):
old_path = os.path.join(TEST_DIR, 'a', 'module.py')
new_path = os.path.join(TEST_DIR, 'a', 'spam.py')
with support.captured_stdout() as output:
self._do_test(maybe_test, debug=2,
replace_paths=[(old_path, new_path)])
output = output.getvalue()
expected = "co_filename '%s' changed to '%s'" % (old_path, new_path)
self.assertIn(expected, output)
def test_main():
support.run_unittest(ModuleFinderTest)
if __name__ == "__main__":
unittest.main()

View File

@ -27,6 +27,9 @@ Core and Builtins
Library
-------
- Issue #21707: Add missing kwonlyargcount argument to
ModuleFinder.replace_paths_in_code().
- Issue #20639: calling Path.with_suffix('') allows removing the suffix
again. Patch by July Tikhonov.