Skip to content

Commit

Permalink
SIM902: Removed due to false-positives (#127)
Browse files Browse the repository at this point in the history
Closes #125
  • Loading branch information
MartinThoma authored Mar 29, 2022
1 parent 8bc3476 commit ad67ae7
Show file tree
Hide file tree
Showing 4 changed files with 1 addition and 95 deletions.
15 changes: 1 addition & 14 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -85,7 +85,7 @@ General Code Style:
* [`SIM103`](https://github.com/MartinThoma/flake8-simplify/issues/3): Return the boolean condition directly ([example](#SIM103))
* [`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`: Reserved for SIM902 once it's stable
* `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
* `SIM124`: Reserved for SIM909 once it's stable

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

* `SIM901`: Use comparisons directly instead of wrapping them in a `bool(...)` call ([example](#SIM901))
* `SIM902`: Use keyword-argument instead of magic boolean ([example](#SIM902))
* `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))
Expand Down Expand Up @@ -508,19 +507,7 @@ bool(a == b)
a == b
```

### SIM902

This rule will be renamed to `SIM122` after its 6-month trial period is over.

```python
# Bad
foo(False)
bar(True)

# Good
foo(verbose=False)
bar(enable_magic=True)
```

### SIM903

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_sim902,
get_sim903,
get_sim905,
get_sim906,
Expand Down Expand Up @@ -74,7 +73,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_sim902(Call(node))
self.errors += get_sim903(Call(node))
self.errors += get_sim905(node)
self.errors += get_sim906(node)
Expand Down
38 changes: 0 additions & 38 deletions flake8_simplify/rules/ast_call.py
Original file line number Diff line number Diff line change
Expand Up @@ -92,44 +92,6 @@ def get_sim901(node: ast.Call) -> List[Tuple[int, int, str]]:
return errors


def get_sim902(node: Call) -> List[Tuple[int, int, str]]:
"""Find bare boolean function arguments."""
SIM902 = (
"SIM902 Use keyword-argument instead of magic boolean for '{func}'"
)
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 call_name in ["partial", "min", "max"] or call_name.startswith("_"):
return errors

has_bare_bool = any(
isinstance(call_arg, (ast.Constant, ast.NameConstant))
and (call_arg.value is True or call_arg.value is False)
for call_arg in node.args
)

is_setter = call_name.lower().startswith("set") and nb_args <= 2
is_exception = isinstance(node.func, ast.Attribute) and node.func.attr in [
"get"
]
if has_bare_bool and not (is_exception or is_setter):
source = to_source(node)
errors.append(
(node.lineno, node.col_offset, SIM902.format(func=source))
)
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}'"
Expand Down
41 changes: 0 additions & 41 deletions tests/test_900_rules.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,47 +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, True)",
"set_foo(a, b, True)",
),
ids=[
"basic",
"set_multiple",
],
)
def test_sim902(s):
error_messages = _results(s)
assert any("SIM902" in error_message for error_message in error_messages)


@pytest.mark.parametrize(
"s",
(
"foo(a, b, foo=True)",
"dict.get('foo', True)",
"set_visible(True)",
"line.set_visible(True)",
"partial(foo, True)",
"partial(foo, bar=True)",
),
ids=[
"kw_arg_is_used",
"dict_get",
"boolean_setter_function",
"boolean_setter_method",
"partial_arg",
"partial_kwarg",
],
)
def test_sim902_false_positive_check(s):
error_messages = _results(s)
for error_message in error_messages:
assert "SIM902" not in error_message


@pytest.mark.parametrize(
"s",
("foo(a, b, 123123)", "foo(a, b, 123.123)"),
Expand Down

0 comments on commit ad67ae7

Please sign in to comment.