Skip to content

Commit

Permalink
Merge pull request #597 from python-rope/lieryan-posonlyargs-kwonlyar…
Browse files Browse the repository at this point in the history
…gs-scope

Fix posonlyargs and kwonlyargs when extracting method
  • Loading branch information
lieryan committed Dec 14, 2022
2 parents eeacfed + c1b809c commit 7fc05ef
Show file tree
Hide file tree
Showing 3 changed files with 42 additions and 1 deletion.
1 change: 1 addition & 0 deletions CHANGELOG.md
Expand Up @@ -4,6 +4,7 @@
- #559 Improve handling of whitespace in import and from-import statements
- #581 Remove functions in rope.base.ast that has functionally identical implementation in stdlib's ast
- #589 Fix issue with `sample_project()` creating directories where it shouldn't when running tests
- #566, #567 Fix variables in kwonlyargs and posonlyargs not being correctly passed to extracted methods

# Release 1.5.1

Expand Down
5 changes: 4 additions & 1 deletion rope/refactor/extract.py
Expand Up @@ -947,11 +947,14 @@ def _handle_loop_context(self, node):


def _get_argnames(arguments):
result = [node.arg for node in arguments.args if isinstance(node, ast.arg)]
result = []
result.extend(node.arg for node in getattr(arguments, "posonlyargs", []))
result.extend(node.arg for node in arguments.args)
if arguments.vararg:
result.append(arguments.vararg.arg)
if arguments.kwarg:
result.append(arguments.kwarg.arg)
result.extend(node.arg for node in arguments.kwonlyargs)
return result


Expand Down
37 changes: 37 additions & 0 deletions ropetest/refactor/extracttest.py
Expand Up @@ -204,6 +204,43 @@ 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)

@testutils.only_for_versions_higher("3.8")
def test_extract_function_with_posonlyargs(self):
code = dedent("""\
def a_func(a_var, /, b):
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(a_var, /, b):
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 7fc05ef

Please sign in to comment.