From 5849ec20ed97917426a4bcf3b3c5fdd9be2b222f Mon Sep 17 00:00:00 2001 From: Pavel Bitiukov Date: Tue, 17 Oct 2023 18:33:16 +0100 Subject: [PATCH] Apply the bracket fix from issue 471 only for use_parentheses=True --- isort/wrap.py | 17 +++++++++-------- tests/unit/test_wrap.py | 32 ++++++++++++++++++++++++++++++++ 2 files changed, 41 insertions(+), 8 deletions(-) diff --git a/isort/wrap.py b/isort/wrap.py index 8904d0eda..119531ad6 100644 --- a/isort/wrap.py +++ b/isort/wrap.py @@ -122,20 +122,21 @@ def line(content: str, line_separator: str, config: Config = DEFAULT_CONFIG) -> _separator = line_separator else: _separator = "" - _comment = "" + noqa_comment = "" if comment and "noqa" in comment: - _comment = f"{config.comment_prefix}{comment}" + noqa_comment = f"{config.comment_prefix}{comment}" cont_line = cont_line.rstrip() _comma = "," if config.include_trailing_comma else "" output = ( - f"{content}{splitter}({_comment}" + f"{content}{splitter}({noqa_comment}" f"{line_separator}{cont_line}{_comma}{_separator})" ) - lines = output.split(line_separator) - if config.comment_prefix in lines[-1] and lines[-1].endswith(")"): - content, comment = lines[-1].split(config.comment_prefix, 1) - lines[-1] = content + ")" + config.comment_prefix + comment[:-1] - return line_separator.join(lines) + lines = output.split(line_separator) + if config.comment_prefix in lines[-1] and lines[-1].endswith(")"): + content, comment = lines[-1].split(config.comment_prefix, 1) + lines[-1] = content + ")" + config.comment_prefix + comment[:-1] + output = line_separator.join(lines) + return output return f"{content}{splitter}\\{line_separator}{cont_line}" elif len(content) > config.line_length and wrap_mode == Modes.NOQA and "# NOQA" not in content: # type: ignore return f"{content}{config.comment_prefix} NOQA" diff --git a/tests/unit/test_wrap.py b/tests/unit/test_wrap.py index 2e35951fe..ba378884a 100644 --- a/tests/unit/test_wrap.py +++ b/tests/unit/test_wrap.py @@ -1,5 +1,8 @@ +import pytest + from isort import wrap from isort.settings import Config +from isort.wrap_modes import WrapModes def test_import_statement(): @@ -16,3 +19,32 @@ def test_import_statement(): assert wrap.import_statement("from x import ", ["y", "z"], [], explode=True) == ( "from x import (\n y,\n z,\n)" ) + + +@pytest.mark.parametrize( + "multi_line_output, expected", + ( + ( + WrapModes.VERTICAL_HANGING_INDENT, # type: ignore + """from a import ( + b as c # comment that is long enough that this import doesn't fit in one line (parens) +)""", + ), + ( + WrapModes.VERTICAL, # type: ignore + """from a import ( + b as c) # comment that is long enough that this import doesn't fit in one line (parens)""", + ), + ), +) +def test_line__comment_with_brackets__expects_unchanged_comment(multi_line_output, expected): + content = ( + "from a import b as c " + "# comment that is long enough that this import doesn't fit in one line (parens)" + ) + config = Config( + multi_line_output=multi_line_output, + use_parentheses=True, + ) + + assert wrap.line(content=content, line_separator="\n", config=config) == expected