mirror of
https://github.com/home-assistant/core.git
synced 2025-11-09 02:49:40 +00:00
Enforce namespace use for import conventions (#118215)
* Enforce namespace use for import conventions
* Include all registries
* Only apply to functions
* Use blacklist
* Rephrase comment
* Add async_entries_for_config_entry
* Typo
* Improve
* More core files
* Revert "More core files"
This reverts commit 9978b93706.
* Revert diagnostics amends
* Include category/floor/label registries
* Performance
* Adjust text
This commit is contained in:
@@ -395,6 +395,38 @@ _OBSOLETE_IMPORT: dict[str, list[ObsoleteImportMatch]] = {
|
||||
}
|
||||
|
||||
|
||||
# Blacklist of imports that should be using the namespace
|
||||
@dataclass
|
||||
class NamespaceAlias:
|
||||
"""Class for namespace imports."""
|
||||
|
||||
alias: str
|
||||
names: set[str] # function names
|
||||
|
||||
|
||||
_FORCE_NAMESPACE_IMPORT: dict[str, NamespaceAlias] = {
|
||||
"homeassistant.helpers.area_registry": NamespaceAlias("ar", {"async_get"}),
|
||||
"homeassistant.helpers.category_registry": NamespaceAlias("cr", {"async_get"}),
|
||||
"homeassistant.helpers.device_registry": NamespaceAlias(
|
||||
"dr",
|
||||
{
|
||||
"async_get",
|
||||
"async_entries_for_config_entry",
|
||||
},
|
||||
),
|
||||
"homeassistant.helpers.entity_registry": NamespaceAlias(
|
||||
"er",
|
||||
{
|
||||
"async_get",
|
||||
"async_entries_for_config_entry",
|
||||
},
|
||||
),
|
||||
"homeassistant.helpers.floor_registry": NamespaceAlias("fr", {"async_get"}),
|
||||
"homeassistant.helpers.issue_registry": NamespaceAlias("ir", {"async_get"}),
|
||||
"homeassistant.helpers.label_registry": NamespaceAlias("lr", {"async_get"}),
|
||||
}
|
||||
|
||||
|
||||
class HassImportsFormatChecker(BaseChecker):
|
||||
"""Checker for imports."""
|
||||
|
||||
@@ -422,6 +454,12 @@ class HassImportsFormatChecker(BaseChecker):
|
||||
"Used when an import from another component should be "
|
||||
"from the component root",
|
||||
),
|
||||
"W7425": (
|
||||
"`%s` should not be imported directly. Please import `%s` as `%s` "
|
||||
"and use `%s.%s`",
|
||||
"hass-helper-namespace-import",
|
||||
"Used when a helper should be used via the namespace",
|
||||
),
|
||||
}
|
||||
options = ()
|
||||
|
||||
@@ -524,6 +562,20 @@ class HassImportsFormatChecker(BaseChecker):
|
||||
node=node,
|
||||
args=(import_match.string, obsolete_import.reason),
|
||||
)
|
||||
if namespace_alias := _FORCE_NAMESPACE_IMPORT.get(node.modname):
|
||||
for name in node.names:
|
||||
if name[0] in namespace_alias.names:
|
||||
self.add_message(
|
||||
"hass-helper-namespace-import",
|
||||
node=node,
|
||||
args=(
|
||||
name[0],
|
||||
node.modname,
|
||||
namespace_alias.alias,
|
||||
namespace_alias.alias,
|
||||
name[0],
|
||||
),
|
||||
)
|
||||
|
||||
|
||||
def register(linter: PyLinter) -> None:
|
||||
|
||||
Reference in New Issue
Block a user