diff --git a/flake8_builtins.py b/flake8_builtins.py index 441fd7c..8753eed 100644 --- a/flake8_builtins.py +++ b/flake8_builtins.py @@ -17,6 +17,7 @@ class BuiltinsChecker: assign_msg = 'A001 variable "{0}" is shadowing a python builtin' argument_msg = 'A002 argument "{0}" is shadowing a python builtin' class_attribute_msg = 'A003 class attribute "{0}" is shadowing a python builtin' + import_msg = 'A004 import statement "{0}" is shadowing a Python builtin' names = [] ignore_list = { @@ -223,8 +224,17 @@ def check_comprehension(self, statement): def check_import(self, statement): for name in statement.names: - if name.asname in self.names: - yield self.error(statement, variable=name.asname) + collision = None + if name.name in self.names and name.asname is None: + collision = name.name + elif name.asname in self.names: + collision = name.asname + if collision: + yield self.error( + statement, + message=self.import_msg, + variable=collision, + ) def check_class(self, statement): if statement.name in self.names: diff --git a/run_tests.py b/run_tests.py index f96297f..d665529 100644 --- a/run_tests.py +++ b/run_tests.py @@ -147,7 +147,6 @@ def bla(dict=3): b = 4""" check_code(source, 'A002') - def test_kwonly_argument_message(): source = """ def bla(*, list): @@ -357,14 +356,19 @@ def test_list_comprehension_multiple_as_list(): check_code(source, 'A001') +def test_import(): + source = """from numpy import max""" + check_code(source, 'A004') + + def test_import_as(): source = 'import zope.component.getSite as int' - check_code(source, 'A001') + check_code(source, 'A004') def test_import_from_as(): source = 'from zope.component import getSite as int' - check_code(source, 'A001') + check_code(source, 'A004') def test_import_as_nothing(): @@ -372,6 +376,11 @@ def test_import_as_nothing(): check_code(source) +def test_import_collision_as_nothing(): + source = """from numpy import max as non_shadowing_max""" + check_code(source) + + def test_import_from_as_nothing(): source = 'from zope.component import getSite as something_else' check_code(source)