-
Notifications
You must be signed in to change notification settings - Fork 1.2k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
F401 - Distinguish between imports we wish to remove and those we wis…
…h to make explicit-exports (#11168) Resolves #10390 and starts to address #10391 # Changes to behavior * In `__init__.py` we now offer some fixes for unused imports. * If the import binding is first-party this PR suggests a fix to turn it into a redundant alias. * If the import binding is not first-party, this PR suggests a fix to remove it from the `__init__.py`. * The fix-titles are specific to these new suggested fixes. * `checker.settings.ignore_init_module_imports` setting is deprecated/ignored. There is probably a documentation change to make that complete which I haven't done. --- <details><summary>Old description of implementation changes</summary> # Changes to the implementation * In the body of the loop over import statements that contain unused bindings, the bindings are partitioned into `to_reexport` and `to_remove` (according to how we want to resolve the fact they're unused) with the following predicate: ```rust in_init && is_first_party(checker, &import.qualified_name().to_string()) // true means make it a reexport ``` * Instead of generating a single fix per import statement, we now generate up to two fixes per import statement: ```rust (fix_by_removing_imports(checker, node_id, &to_remove, in_init).ok(), fix_by_reexporting(checker, node_id, &to_reexport, dunder_all).ok()) ``` * The `to_remove` fixes are unsafe when `in_init`. * The `to_explicit` fixes are safe. Currently, until a future PR, we make them redundant aliases (e.g. `import a` would become `import a as a`). ## Other changes * `checker.settings.ignore_init_module_imports` is deprecated/ignored. Instead, all fixes are gated on `checker.settings.preview.is_enabled()`. * Got rid of the pattern match on the import-binding bound by the inner loop because it seemed less readable than referencing fields on the binding. * [x] `// FIXME: rename "imports" to "bindings"` if reviewer agrees (see code) * [x] `// FIXME: rename "node_id" to "import_statement"` if reviewer agrees (see code) <details> <summary><h2>Scope cut until a future PR</h2></summary> * (Not implemented) The `to_explicit` fixes will be added to `__all__` unless it doesn't exist. When `__all__` doesn't exist they're resolved by converting to redundant aliases (e.g. `import a` would become `import a as a`). --- </details> # Test plan * [x] `crates/ruff_linter/resources/test/fixtures/pyflakes/F401_24` contains an `__init__.py` with*out* `__all__` that exercises the features in this PR, but it doesn't pass. * [x] `crates/ruff_linter/resources/test/fixtures/pyflakes/F401_25_dunder_all` contains an `__init__.py` *with* `__all__` that exercises the features in this PR, but it doesn't pass. * [x] Write unit tests for the new edit functions in `fix::edits::make_redundant_alias`. </details> --------- Co-authored-by: Micha Reiser <micha@reiser.io>
- Loading branch information
1 parent
7cec3b2
commit 59afff0
Showing
17 changed files
with
343 additions
and
46 deletions.
There are no files selected for viewing
36 changes: 36 additions & 0 deletions
36
crates/ruff_linter/resources/test/fixtures/pyflakes/F401_24/__init__.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,36 @@ | ||
"""__init__.py without __all__ | ||
Unused stdlib and third party imports are unsafe removals | ||
Unused first party imports get changed to redundant aliases | ||
""" | ||
|
||
|
||
# stdlib | ||
|
||
import os # Ok: is used | ||
|
||
_ = os | ||
|
||
|
||
import argparse as argparse # Ok: is redundant alias | ||
|
||
|
||
import sys # F401: remove unused | ||
|
||
|
||
# first-party | ||
|
||
|
||
from . import used # Ok: is used | ||
|
||
_ = used | ||
|
||
|
||
from . import aliased as aliased # Ok: is redundant alias | ||
|
||
|
||
from . import unused # F401: change to redundant alias | ||
|
||
|
||
from . import renamed as bees # F401: no fix |
1 change: 1 addition & 0 deletions
1
crates/ruff_linter/resources/test/fixtures/pyflakes/F401_24/aliased.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
# empty module imported by __init__.py for test fixture |
1 change: 1 addition & 0 deletions
1
crates/ruff_linter/resources/test/fixtures/pyflakes/F401_24/renamed.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
# empty module imported by __init__.py for test fixture |
1 change: 1 addition & 0 deletions
1
crates/ruff_linter/resources/test/fixtures/pyflakes/F401_24/unused.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
# empty module imported by __init__.py for test fixture |
1 change: 1 addition & 0 deletions
1
crates/ruff_linter/resources/test/fixtures/pyflakes/F401_24/used.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
# empty module imported by __init__.py for test fixture |
42 changes: 42 additions & 0 deletions
42
crates/ruff_linter/resources/test/fixtures/pyflakes/F401_25__all/__init__.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,42 @@ | ||
"""__init__.py with __all__ | ||
Unused stdlib and third party imports are unsafe removals | ||
Unused first party imports get added to __all__ | ||
""" | ||
|
||
|
||
# stdlib | ||
|
||
import os # Ok: is used | ||
|
||
_ = os | ||
|
||
|
||
import argparse # Ok: is exported in __all__ | ||
|
||
|
||
import sys # F401: remove unused | ||
|
||
|
||
# first-party | ||
|
||
|
||
from . import used # Ok: is used | ||
|
||
_ = used | ||
|
||
|
||
from . import aliased as aliased # Ok: is redundant alias | ||
|
||
|
||
from . import exported # Ok: is exported in __all__ | ||
|
||
|
||
# from . import unused # F401: add to __all__ | ||
|
||
|
||
# from . import renamed as bees # F401: add to __all__ | ||
|
||
|
||
__all__ = ["argparse", "exported"] |
1 change: 1 addition & 0 deletions
1
crates/ruff_linter/resources/test/fixtures/pyflakes/F401_25__all/aliased.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
# empty module imported by __init__.py for test fixture |
1 change: 1 addition & 0 deletions
1
crates/ruff_linter/resources/test/fixtures/pyflakes/F401_25__all/exported.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
# empty module imported by __init__.py for test fixture |
1 change: 1 addition & 0 deletions
1
crates/ruff_linter/resources/test/fixtures/pyflakes/F401_25__all/renamed.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
# empty module imported by __init__.py for test fixture |
1 change: 1 addition & 0 deletions
1
crates/ruff_linter/resources/test/fixtures/pyflakes/F401_25__all/unused.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
# empty module imported by __init__.py for test fixture |
1 change: 1 addition & 0 deletions
1
crates/ruff_linter/resources/test/fixtures/pyflakes/F401_25__all/used.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
# empty module imported by __init__.py for test fixture |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.