From af3f2a240d8bb59475862197d4652fb3f53595f8 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ville=20Skytt=C3=A4?= Date: Wed, 25 Jul 2018 23:09:08 +0300 Subject: [PATCH 01/13] Upgrade pylint to 2.0.1 --- requirements_test.txt | 2 +- requirements_test_all.txt | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/requirements_test.txt b/requirements_test.txt index 4d1f86059fcd4f..225958a722cd07 100644 --- a/requirements_test.txt +++ b/requirements_test.txt @@ -8,7 +8,7 @@ flake8==3.5 mock-open==1.3.1 mypy==0.620 pydocstyle==1.1.1 -pylint==1.9.2 +pylint==2.0.1 pytest-aiohttp==0.3.0 pytest-cov==2.5.1 pytest-sugar==0.9.1 diff --git a/requirements_test_all.txt b/requirements_test_all.txt index be979aa5374d0b..a38ac24dd7bce4 100644 --- a/requirements_test_all.txt +++ b/requirements_test_all.txt @@ -9,7 +9,7 @@ flake8==3.5 mock-open==1.3.1 mypy==0.620 pydocstyle==1.1.1 -pylint==1.9.2 +pylint==2.0.1 pytest-aiohttp==0.3.0 pytest-cov==2.5.1 pytest-sugar==0.9.1 From 0bb4c6c2aefd4fa1b610cad533d210cb07de5a70 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ville=20Skytt=C3=A4?= Date: Wed, 25 Jul 2018 23:09:08 +0300 Subject: [PATCH 02/13] Pylint 2 bad-whitespace fix --- homeassistant/util/dt.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/homeassistant/util/dt.py b/homeassistant/util/dt.py index 06159a944a26b4..ce6775b9ea7e3d 100644 --- a/homeassistant/util/dt.py +++ b/homeassistant/util/dt.py @@ -98,7 +98,7 @@ def utc_from_timestamp(timestamp: float) -> dt.datetime: def start_of_local_day(dt_or_d: - Union[dt.date, dt.datetime]=None) -> dt.datetime: + Union[dt.date, dt.datetime] = None) -> dt.datetime: """Return local datetime object of start of day from date or datetime.""" if dt_or_d is None: date = now().date() # type: dt.date From 2e332d17da608f9a62f67635d8bbe0a2525d4d84 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ville=20Skytt=C3=A4?= Date: Wed, 25 Jul 2018 23:09:08 +0300 Subject: [PATCH 03/13] Pylint 2 possibly-unused-variable fixes --- homeassistant/scripts/check_config.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/homeassistant/scripts/check_config.py b/homeassistant/scripts/check_config.py index 1924de88aafd7b..d7be5b1a91c7d0 100644 --- a/homeassistant/scripts/check_config.py +++ b/homeassistant/scripts/check_config.py @@ -163,13 +163,13 @@ def check(config_dir, secrets=False): 'secret_cache': None, } - # pylint: disable=unused-variable + # pylint: disable=possibly-unused-variable def mock_load(filename): """Mock hass.util.load_yaml to save config file names.""" res['yaml_files'][filename] = True return MOCKS['load'][1](filename) - # pylint: disable=unused-variable + # pylint: disable=possibly-unused-variable def mock_secrets(ldr, node): """Mock _get_secrets.""" try: From 3adc9016a2d2f9285608a20d3d3a46cad52d2338 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ville=20Skytt=C3=A4?= Date: Wed, 25 Jul 2018 23:09:08 +0300 Subject: [PATCH 04/13] Pylint 2 try-except-raise fixes --- homeassistant/components/media_player/bluesound.py | 8 ++------ homeassistant/components/sensor/nzbget.py | 6 +----- homeassistant/components/sensor/pyload.py | 6 +----- homeassistant/helpers/intent.py | 3 ++- 4 files changed, 6 insertions(+), 17 deletions(-) diff --git a/homeassistant/components/media_player/bluesound.py b/homeassistant/components/media_player/bluesound.py index a6b345b1d3bc76..5631ec06cf1ab4 100644 --- a/homeassistant/components/media_player/bluesound.py +++ b/homeassistant/components/media_player/bluesound.py @@ -216,12 +216,8 @@ def _try_get_index(string, search_string): async def force_update_sync_status( self, on_updated_cb=None, raise_timeout=False): """Update the internal status.""" - resp = None - try: - resp = await self.send_bluesound_command( - 'SyncStatus', raise_timeout, raise_timeout) - except Exception: - raise + resp = await self.send_bluesound_command( + 'SyncStatus', raise_timeout, raise_timeout) if not resp: return None diff --git a/homeassistant/components/sensor/nzbget.py b/homeassistant/components/sensor/nzbget.py index a8dda416a547af..a6fee5a69e8f38 100644 --- a/homeassistant/components/sensor/nzbget.py +++ b/homeassistant/components/sensor/nzbget.py @@ -173,8 +173,4 @@ def post(self, method, params=None): @Throttle(MIN_TIME_BETWEEN_UPDATES) def update(self): """Update cached response.""" - try: - self.status = self.post('status')['result'] - except requests.exceptions.ConnectionError: - # failed to update status - exception already logged in self.post - raise + self.status = self.post('status')['result'] diff --git a/homeassistant/components/sensor/pyload.py b/homeassistant/components/sensor/pyload.py index a5593c259a5505..4aa121e0895c76 100644 --- a/homeassistant/components/sensor/pyload.py +++ b/homeassistant/components/sensor/pyload.py @@ -162,8 +162,4 @@ def post(self, method, params=None): @Throttle(MIN_TIME_BETWEEN_UPDATES) def update(self): """Update cached response.""" - try: - self.status = self.post('speed') - except requests.exceptions.ConnectionError: - # Failed to update status - exception already logged in self.post - raise + self.status = self.post('speed') diff --git a/homeassistant/helpers/intent.py b/homeassistant/helpers/intent.py index 4357c4109ebbf1..8f26d4fe0eeeab 100644 --- a/homeassistant/helpers/intent.py +++ b/homeassistant/helpers/intent.py @@ -63,7 +63,8 @@ async def async_handle(hass, platform, intent_type, slots=None, intent_type, err) raise InvalidSlotInfo( 'Received invalid slot info for {}'.format(intent_type)) from err - except IntentHandleError: + # https://github.com/PyCQA/pylint/issues/2284 + except IntentHandleError: # pylint: disable=try-except-raise raise except Exception as err: raise IntentUnexpectedError( From 69ac7f091dc991c4e60c54a9379b2f28ed48af14 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ville=20Skytt=C3=A4?= Date: Wed, 25 Jul 2018 23:09:08 +0300 Subject: [PATCH 05/13] Disable pylint fixme for todoist for now https://github.com/PyCQA/pylint/pull/2320 --- homeassistant/components/calendar/todoist.py | 3 +++ 1 file changed, 3 insertions(+) diff --git a/homeassistant/components/calendar/todoist.py b/homeassistant/components/calendar/todoist.py index ba1f60027ba3cb..30c5a6177b4aef 100644 --- a/homeassistant/components/calendar/todoist.py +++ b/homeassistant/components/calendar/todoist.py @@ -26,6 +26,9 @@ CONF_PROJECT_LABEL_WHITELIST = 'labels' CONF_PROJECT_WHITELIST = 'include_projects' +# https://github.com/PyCQA/pylint/pull/2320 +# pylint: disable=fixme + # Calendar Platform: Does this calendar event last all day? ALL_DAY = 'all_day' # Attribute: All tasks in this project From 51c3d630df9b49a0f1d443e13b716321cdc3309f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ville=20Skytt=C3=A4?= Date: Wed, 25 Jul 2018 23:09:08 +0300 Subject: [PATCH 06/13] Disable pylint 2 useless-return for now https://github.com/PyCQA/pylint/issues/2300 --- pylintrc | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/pylintrc b/pylintrc index 1e9e490adfedbf..a2113aa7f14d49 100644 --- a/pylintrc +++ b/pylintrc @@ -11,6 +11,7 @@ # too-few-* - same as too-many-* # abstract-method - with intro of async there are always methods missing # inconsistent-return-statements - doesn't handle raise +# useless-return - https://github.com/PyCQA/pylint/issues/2300 disable= abstract-class-little-used, abstract-method, @@ -30,7 +31,8 @@ disable= too-many-public-methods, too-many-return-statements, too-many-statements, - unused-argument + unused-argument, + useless-return [REPORTS] reports=no From 47813002f9aa7eb4b7a70fa960ebe1105694eede Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ville=20Skytt=C3=A4?= Date: Wed, 25 Jul 2018 23:09:08 +0300 Subject: [PATCH 07/13] Disable pylint 2 invalid-name for type variables for now https://github.com/PyCQA/pylint/issues/1290 --- homeassistant/components/apple_tv.py | 2 +- homeassistant/core.py | 2 ++ homeassistant/loader.py | 2 +- homeassistant/util/__init__.py | 2 ++ homeassistant/util/decorator.py | 3 ++- homeassistant/util/yaml.py | 4 ++-- 6 files changed, 10 insertions(+), 5 deletions(-) diff --git a/homeassistant/components/apple_tv.py b/homeassistant/components/apple_tv.py index 958e4a197775fc..97fb2363024fb2 100644 --- a/homeassistant/components/apple_tv.py +++ b/homeassistant/components/apple_tv.py @@ -45,7 +45,7 @@ NOTIFICATION_SCAN_ID = 'apple_tv_scan_notification' NOTIFICATION_SCAN_TITLE = 'Apple TV Scan' -T = TypeVar('T') +T = TypeVar('T') # pylint: disable=invalid-name # This version of ensure_list interprets an empty dict as no value diff --git a/homeassistant/core.py b/homeassistant/core.py index a7684d130ae496..828dfc24d6ca6c 100644 --- a/homeassistant/core.py +++ b/homeassistant/core.py @@ -49,9 +49,11 @@ if TYPE_CHECKING: from homeassistant.config_entries import ConfigEntries # noqa +# pylint: disable=invalid-name T = TypeVar('T') CALLABLE_T = TypeVar('CALLABLE_T', bound=Callable) CALLBACK_TYPE = Callable[[], None] +# pylint: enable=invalid-name DOMAIN = 'homeassistant' diff --git a/homeassistant/loader.py b/homeassistant/loader.py index c5cf99de234954..3ac49e354b5d50 100644 --- a/homeassistant/loader.py +++ b/homeassistant/loader.py @@ -27,7 +27,7 @@ if TYPE_CHECKING: from homeassistant.core import HomeAssistant # NOQA -CALLABLE_T = TypeVar('CALLABLE_T', bound=Callable) +CALLABLE_T = TypeVar('CALLABLE_T', bound=Callable) # noqa pylint: disable=invalid-name PREPARED = False diff --git a/homeassistant/util/__init__.py b/homeassistant/util/__init__.py index 37f669944d97c9..91b98ea598074f 100644 --- a/homeassistant/util/__init__.py +++ b/homeassistant/util/__init__.py @@ -17,9 +17,11 @@ from .dt import as_local, utcnow +# pylint: disable=invalid-name T = TypeVar('T') U = TypeVar('U') ENUM_T = TypeVar('ENUM_T', bound=enum.Enum) +# pylint: enable=invalid-name RE_SANITIZE_FILENAME = re.compile(r'(~|\.\.|/|\\)') RE_SANITIZE_PATH = re.compile(r'(~|\.(\.)+)') diff --git a/homeassistant/util/decorator.py b/homeassistant/util/decorator.py index 9d2a4600a64ce4..22ed1a4dae66de 100644 --- a/homeassistant/util/decorator.py +++ b/homeassistant/util/decorator.py @@ -1,6 +1,7 @@ """Decorator utility functions.""" from typing import Callable, TypeVar -CALLABLE_T = TypeVar('CALLABLE_T', bound=Callable) + +CALLABLE_T = TypeVar('CALLABLE_T', bound=Callable) # noqa pylint: disable=invalid-name class Registry(dict): diff --git a/homeassistant/util/yaml.py b/homeassistant/util/yaml.py index 40ddfdf7b966a5..69f83aefad7989 100644 --- a/homeassistant/util/yaml.py +++ b/homeassistant/util/yaml.py @@ -24,8 +24,8 @@ SECRET_YAML = 'secrets.yaml' __SECRET_CACHE = {} # type: Dict[str, JSON_TYPE] -JSON_TYPE = Union[List, Dict, str] -DICT_T = TypeVar('DICT_T', bound=Dict) +JSON_TYPE = Union[List, Dict, str] # pylint: disable=invalid-name +DICT_T = TypeVar('DICT_T', bound=Dict) # pylint: disable=invalid-name class NodeListClass(list): From 84e6b3ad4a56d041aad3511166de2c39032b7625 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ville=20Skytt=C3=A4?= Date: Wed, 25 Jul 2018 23:09:08 +0300 Subject: [PATCH 08/13] Disable pylint 2 not-an-iterable for now https://github.com/PyCQA/pylint/issues/2311 --- pylintrc | 2 ++ 1 file changed, 2 insertions(+) diff --git a/pylintrc b/pylintrc index a2113aa7f14d49..00bc6582f3a038 100644 --- a/pylintrc +++ b/pylintrc @@ -12,6 +12,7 @@ # abstract-method - with intro of async there are always methods missing # inconsistent-return-statements - doesn't handle raise # useless-return - https://github.com/PyCQA/pylint/issues/2300 +# not-an-iterable - https://github.com/PyCQA/pylint/issues/2311 disable= abstract-class-little-used, abstract-method, @@ -20,6 +21,7 @@ disable= global-statement, inconsistent-return-statements, locally-disabled, + not-an-iterable, not-context-manager, redefined-variable-type, too-few-public-methods, From 7647c4a4274dbaca2e1bfa37ac70e345173508da Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ville=20Skytt=C3=A4?= Date: Wed, 25 Jul 2018 23:09:08 +0300 Subject: [PATCH 09/13] Pylint 2 unsubscriptable-object workarounds --- homeassistant/components/sensor/citybikes.py | 13 ++++--------- 1 file changed, 4 insertions(+), 9 deletions(-) diff --git a/homeassistant/components/sensor/citybikes.py b/homeassistant/components/sensor/citybikes.py index 24f8ea7e6a94f6..c9a69923135ccc 100644 --- a/homeassistant/components/sensor/citybikes.py +++ b/homeassistant/components/sensor/citybikes.py @@ -186,19 +186,14 @@ def get_closest_network_id(cls, hass, latitude, longitude): networks = yield from async_citybikes_request( hass, NETWORKS_URI, NETWORKS_RESPONSE_SCHEMA) cls.NETWORKS_LIST = networks[ATTR_NETWORKS_LIST] - networks_list = cls.NETWORKS_LIST - network = networks_list[0] - result = network[ATTR_ID] - minimum_dist = location.distance( - latitude, longitude, - network[ATTR_LOCATION][ATTR_LATITUDE], - network[ATTR_LOCATION][ATTR_LONGITUDE]) - for network in networks_list[1:]: + result = None + minimum_dist = None + for network in cls.NETWORKS_LIST: network_latitude = network[ATTR_LOCATION][ATTR_LATITUDE] network_longitude = network[ATTR_LOCATION][ATTR_LONGITUDE] dist = location.distance( latitude, longitude, network_latitude, network_longitude) - if dist < minimum_dist: + if minimum_dist is None or dist < minimum_dist: minimum_dist = dist result = network[ATTR_ID] From c1d0ae38b9fedff29863a91ff846d2a7791ed804 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ville=20Skytt=C3=A4?= Date: Wed, 25 Jul 2018 23:09:08 +0300 Subject: [PATCH 10/13] Disable intentional pylint 2 assignment-from-nones --- homeassistant/components/media_player/pandora.py | 2 ++ 1 file changed, 2 insertions(+) diff --git a/homeassistant/components/media_player/pandora.py b/homeassistant/components/media_player/pandora.py index 30e307fd1172c1..c4d8b77809552b 100644 --- a/homeassistant/components/media_player/pandora.py +++ b/homeassistant/components/media_player/pandora.py @@ -253,9 +253,11 @@ def _query_for_playing_status(self): _LOGGER.warning("On unexpected station list page") self._pianobar.sendcontrol('m') # press enter self._pianobar.sendcontrol('m') # do it again b/c an 'i' got in + # pylint: disable=assignment-from-none response = self.update_playing_status() elif match_idx == 3: _LOGGER.debug("Received new playlist list") + # pylint: disable=assignment-from-none response = self.update_playing_status() else: response = self._pianobar.before.decode('utf-8') From 9b072826ca4b3005669c93373e9269c4e9de649e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ville=20Skytt=C3=A4?= Date: Wed, 25 Jul 2018 23:09:08 +0300 Subject: [PATCH 11/13] Disable pylint 2 unsupported-membership-test apparent false positives --- homeassistant/components/light/__init__.py | 1 + 1 file changed, 1 insertion(+) diff --git a/homeassistant/components/light/__init__.py b/homeassistant/components/light/__init__.py index 472be92583aebb..58991a8e50597b 100644 --- a/homeassistant/components/light/__init__.py +++ b/homeassistant/components/light/__init__.py @@ -439,6 +439,7 @@ def get(cls, name): @classmethod def get_default(cls, entity_id): """Return the default turn-on profile for the given light.""" + # pylint: disable=unsupported-membership-test name = entity_id + ".default" if name in cls._all: return name From 4ff27f9a0a502d1d88510ea815827c4f0f07a085 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ville=20Skytt=C3=A4?= Date: Wed, 25 Jul 2018 23:09:08 +0300 Subject: [PATCH 12/13] Disable pylint 2 assignment-from-no-return apparent false positives --- homeassistant/scripts/influxdb_import.py | 1 + 1 file changed, 1 insertion(+) diff --git a/homeassistant/scripts/influxdb_import.py b/homeassistant/scripts/influxdb_import.py index 421e84d503a7ca..031df1d3a72a38 100644 --- a/homeassistant/scripts/influxdb_import.py +++ b/homeassistant/scripts/influxdb_import.py @@ -137,6 +137,7 @@ def run(script_args: List) -> int: override_measurement = args.override_measurement default_measurement = args.default_measurement + # pylint: disable=assignment-from-no-return query = session.query(func.count(models.Events.event_type)).filter( models.Events.event_type == 'state_changed') From bead86ee5c091de9b6baf23360ecd658f340cdc7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ville=20Skytt=C3=A4?= Date: Wed, 25 Jul 2018 23:09:08 +0300 Subject: [PATCH 13/13] Disable pylint 2 comparison-with-callable false positives https://github.com/PyCQA/pylint/issues/2306 --- homeassistant/util/__init__.py | 3 +++ 1 file changed, 3 insertions(+) diff --git a/homeassistant/util/__init__.py b/homeassistant/util/__init__.py index 91b98ea598074f..ff098b24fb8874 100644 --- a/homeassistant/util/__init__.py +++ b/homeassistant/util/__init__.py @@ -123,6 +123,9 @@ def get_random_string(length: int = 10) -> str: class OrderedEnum(enum.Enum): """Taken from Python 3.4.0 docs.""" + # https://github.com/PyCQA/pylint/issues/2306 + # pylint: disable=comparison-with-callable + def __ge__(self: ENUM_T, other: ENUM_T) -> bool: """Return the greater than element.""" if self.__class__ is other.__class__: