Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

SIM903: Removed due to false-positives #131

Merged
merged 1 commit into from
Mar 29, 2022
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
20 changes: 2 additions & 18 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -86,7 +86,7 @@ General Code Style:
* [`SIM106`](https://github.com/MartinThoma/flake8-simplify/issues/8): Handle error-cases first ([example](#SIM106)). This rule was removed due to too many false-positives.
* [`SIM112`](https://github.com/MartinThoma/flake8-simplify/issues/19): Use CAPITAL environment variables ([example](#SIM112))
* `SIM122` / SIM902: ![](https://img.shields.io/badge/-removed-lightgrey) Moved to [flake8-scream](https://github.com/MartinThoma/flake8-scream) due to [issue 125](https://github.com/MartinThoma/flake8-simplify/issues/125)
* `SIM123`: Reserved for SIM903 once it's stable
* `SIM123` / SIM902: ![](https://img.shields.io/badge/-removed-lightgrey) Moved to [flake8-scream](https://github.com/MartinThoma/flake8-scream) due to [issue 130](https://github.com/MartinThoma/flake8-simplify/issues/130)
* `SIM124`: Reserved for SIM909 once it's stable

**Experimental rules:**
Expand All @@ -100,7 +100,7 @@ the code will change to another number.
Current experimental rules:

* `SIM901`: Use comparisons directly instead of wrapping them in a `bool(...)` call ([example](#SIM901))
* `SIM903`: Use keyword-argument instead of magic number ([example](#SIM903))

* `SIM904`: Assign values to dictionary directly at initialization ([example](#SIM904))
* [`SIM905`](https://github.com/MartinThoma/flake8-simplify/issues/86): Split string directly if only constants are used ([example](#SIM905))
* [`SIM906`](https://github.com/MartinThoma/flake8-simplify/issues/101): Merge nested os.path.join calls ([example](#SIM906))
Expand Down Expand Up @@ -508,22 +508,6 @@ a == b
```



### SIM903

This rule will be renamed to `SIM123` after its 6-month trial period is over.
Please report any issues you encounter with this rule!

The trial period starts on 12th of February and will end on 12th of September 2022.

```python
# Bad
foo(42, 1.234)

# Good
foo(the_answer=42, flux_compensation=1.234)
```

### SIM904

This rule will be renamed to `SIM224` after its 6-month trial period is over.
Expand Down
2 changes: 0 additions & 2 deletions flake8_simplify/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,6 @@
from flake8_simplify.rules.ast_call import (
get_sim115,
get_sim901,
get_sim903,
get_sim905,
get_sim906,
)
Expand Down Expand Up @@ -73,7 +72,6 @@ def visit_Assign(self, node: ast.Assign) -> Any:
def visit_Call(self, node: ast.Call) -> Any:
self.errors += get_sim115(Call(node))
self.errors += get_sim901(node)
self.errors += get_sim903(Call(node))
self.errors += get_sim905(node)
self.errors += get_sim906(node)
self.generic_visit(node)
Expand Down
68 changes: 0 additions & 68 deletions flake8_simplify/rules/ast_call.py
Original file line number Diff line number Diff line change
Expand Up @@ -92,74 +92,6 @@ def get_sim901(node: ast.Call) -> List[Tuple[int, int, str]]:
return errors


def get_sim903(node: Call) -> List[Tuple[int, int, str]]:
"""Find bare numeric function arguments."""
SIM903 = "SIM903 Use keyword-argument instead of magic number for '{func}'"
acceptable_magic_numbers = (0, 1, 2)
errors: List[Tuple[int, int, str]] = []

if isinstance(node.func, ast.Attribute):
call_name = node.func.attr
elif isinstance(node.func, ast.Name):
call_name = node.func.id
else:
logger.debug(f"Unknown call type: {type(node.func)}")
return errors

nb_args = len(node.args)
if nb_args <= 1 or call_name.startswith("_"):
return errors

functions_any_arg = ["partial", "min", "max", "minimum", "maximum"]
functions_1_arg = ["sqrt", "sleep", "hideColumn"]
functions_2_args = [
"arange",
"uniform",
"zeros",
"percentile",
"setColumnWidth",
"float_power",
"power",
"pow",
"float_power",
"binomial",
]
if any(
(
call_name in functions_any_arg,
call_name in functions_1_arg and nb_args == 1,
call_name in functions_2_args and nb_args == 2,
call_name in ["linspace"] and nb_args == 3,
"color" in call_name.lower() and nb_args in [3, 4],
"point" in call_name.lower() and nb_args in [2, 3],
)
):
return errors

has_bare_int = any(
isinstance(call_arg, ast.Num)
and call_arg.n not in acceptable_magic_numbers
for call_arg in node.args
)

is_setter = call_name.lower().startswith("set") and nb_args <= 2
is_exception = isinstance(node.func, ast.Name) and node.func.id == "range"
is_exception = is_exception or (
isinstance(node.func, ast.Attribute)
and node.func.attr
in [
"get",
"insert",
]
)
if has_bare_int and not (is_exception or is_setter):
source = to_source(node)
errors.append(
(node.lineno, node.col_offset, SIM903.format(func=source))
)
return errors


def get_sim905(node: ast.Call) -> List[Tuple[int, int, str]]:
RULE = "SIM905 Use '{expected}' instead of '{actual}'"
errors: List[Tuple[int, int, str]] = []
Expand Down
45 changes: 0 additions & 45 deletions tests/test_900_rules.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,51 +10,6 @@ def test_sim901():
assert results == {"1:0 SIM901 Use 'a == b' instead of 'bool(a == b)'"}


@pytest.mark.parametrize(
"s",
("foo(a, b, 123123)", "foo(a, b, 123.123)"),
ids=["int", "float"],
)
def test_sim903_true_positive_check(s):
error_messages = _results(s)
assert any("SIM903" in error_message for error_message in error_messages)


@pytest.mark.parametrize(
"s",
(
"dict.get('foo', 123)",
"set_foo(1.23)",
"line.set_foo(1.23)",
"partial(foo, 1, 2, 3)",
"min(0.5, g_norm)",
"QColor(53, 53, 53, 128)",
),
ids=[
"get_exception",
"set_function",
"set_method",
"partial",
"min",
"color",
],
)
def test_sim903_false_positive_check(s):
error_messages = _results(s)
for error_message in error_messages:
assert "SIM903" not in error_message


def test_sim903_insert_exception():
ret = _results("sys.path.insert(0, 'foo')")
assert ret == set()


def test_sim903_range_exception():
ret = _results("range(42)")
assert ret == set()


@pytest.mark.parametrize(
"s",
(
Expand Down