Skip to content

Commit

Permalink
Fix #566. Add kwonlyargs to list of written arguments when extracting
Browse files Browse the repository at this point in the history
  • Loading branch information
lieryan committed Dec 14, 2022
1 parent eeacfed commit 5fb5359
Show file tree
Hide file tree
Showing 2 changed files with 20 additions and 0 deletions.
2 changes: 2 additions & 0 deletions rope/refactor/extract.py
Expand Up @@ -952,6 +952,8 @@ def _get_argnames(arguments):
result.append(arguments.vararg.arg)
if arguments.kwarg:
result.append(arguments.kwarg.arg)
if arguments.kwonlyargs:
result.extend(node.arg for node in arguments.kwonlyargs)
return result


Expand Down
18 changes: 18 additions & 0 deletions ropetest/refactor/extracttest.py
Expand Up @@ -204,6 +204,24 @@ def new_func():
""")
self.assertEqual(expected, refactored)

def test_extract_function_with_kwonlyargs(self):
code = dedent("""\
def a_func(b, *, a_var):
another_var = 20
third_var = a_var + another_var
""")
start, end = self._convert_line_range_to_offset(code, 3, 3)
refactored = self.do_extract_method(code, start, end, "new_func")
expected = dedent("""\
def a_func(b, *, a_var):
another_var = 20
new_func(a_var, another_var)
def new_func(a_var, another_var):
third_var = a_var + another_var
""")
self.assertEqual(expected, refactored)

def test_extract_function_with_multiple_return_values(self):
code = dedent("""\
def a_func():
Expand Down

0 comments on commit 5fb5359

Please sign in to comment.