commit c6952feecfaef195c6ef6123f5f08ddd770c6aeb
Author: Damian Johnson <atagar(a)torproject.org>
Date: Sat Oct 17 16:06:17 2020 -0700
Static check fixes
Upgrading to pycodestyle 2.6.0 produced a few new warnings...
STATIC CHECKS
* /home/atagar/Desktop/stem/stem/descriptor/certificate.py
line 257 - undefined name 'cryptography' | def __init__(self, cert_type: Optional['stem.client.datatype.CertType'] = None, expiration: Optional[datetime.datetime] = None, key_type: Optional[int] = None, key: Optional[bytes] = None, extensions: Optional[Sequence['stem.descriptor.certificate.Ed25519Extension']] = None, signature: Optional[bytes] = None, signing_key: Optional['cryptography.hazmat.primitives.asymmetric.ed25519.Ed25519PrivateKey'] = None) -> None: # type: ignore
* /home/atagar/Desktop/stem/stem/descriptor/hidden_service.py
line 288 - E741 ambiguous variable name 'l' | link_specifiers = link_count + b''.join([l.pack() for l in self.link_specifiers])
* /home/atagar/Desktop/stem/stem/interpreter/commands.py
line 272 - E741 ambiguous variable name 'l' | lines += [format(l, *STANDARD_OUTPUT) for l in str(desc).splitlines()]
* /home/atagar/Desktop/stem/stem/util/__init__.py
line 84 - undefined name 'cryptography' | def _pubkey_bytes(key: Union['cryptography.hazmat.primitives.asymmetric.ed25519.Ed25519PrivateKey', 'cryptography.hazmat.primitives.asymmetric.ed25519.Ed25519PublicKey', 'cryptography.hazmat.primitives.asymmetric.x25519.X25519PrivateKey', 'cryptography.hazmat.primitives.asymmetric.x25519.X25519PublicKey']) -> bytes: # type: ignore
* /home/atagar/Desktop/stem/test/unit/response/events.py
line 540 - 'stem.control.Controller' imported but unused | from stem.control import Controller, EventType
* stem/client/__init__.py
line 322 - unused 'type: ignore' comment
* stem/control.py
line 2493 - Unpacking a string is disallowed [misc]
line 2511 - Unpacking a string is disallowed [misc]
line 2516 - Unpacking a string is disallowed [misc]
* stem/directory.py
line 270 - Unpacking a string is disallowed [misc]
line 271 - Unpacking a string is disallowed [misc]
line 436 - Unpacking a string is disallowed [misc]
---
stem/client/__init__.py | 2 +-
stem/control.py | 12 +++++++-----
stem/descriptor/hidden_service.py | 2 +-
stem/directory.py | 6 +++---
stem/interpreter/commands.py | 2 +-
test/settings.cfg | 2 ++
test/unit/response/events.py | 2 +-
7 files changed, 16 insertions(+), 12 deletions(-)
diff --git a/stem/client/__init__.py b/stem/client/__init__.py
index 877d60e2..5453f1f2 100644
--- a/stem/client/__init__.py
+++ b/stem/client/__init__.py
@@ -319,7 +319,7 @@ class Circuit(object):
except ImportError:
raise ImportError('Circuit construction requires the cryptography module')
- ctr = modes.CTR(ZERO * (algorithms.AES.block_size // 8)) # type: ignore
+ ctr = modes.CTR(ZERO * (algorithms.AES.block_size // 8))
self.relay = relay
self.id = circ_id
diff --git a/stem/control.py b/stem/control.py
index b889b801..91d1b3ed 100644
--- a/stem/control.py
+++ b/stem/control.py
@@ -2488,9 +2488,11 @@ class Controller(BaseController):
query_comp = ['RESETCONF' if reset else 'SETCONF']
if isinstance(params, dict):
- params = list(params.items())
+ params_list = list(params.items())
+ else:
+ params_list = params # type: ignore # type: Sequence[Tuple[str, Union[str, Sequence[str]]]]
- for param, value in params:
+ for param, value in params_list:
if isinstance(value, str):
query_comp.append('%s="%s"' % (param, value.strip()))
elif isinstance(value, collections.Iterable):
@@ -2508,12 +2510,12 @@ class Controller(BaseController):
if self.is_caching_enabled():
# clear cache for params; the CONF_CHANGED event will set cache for changes
- to_cache = dict((k.lower(), None) for k, v in params)
+ to_cache = dict((k.lower(), None) for k, v in params_list)
self._set_cache(to_cache, 'getconf')
- self._confchanged_cache_invalidation(dict(params))
+ self._confchanged_cache_invalidation(dict(params_list))
else:
log.debug('%s (failed, code: %s, message: %s)' % (query, response.code, response.message))
- immutable_params = [k for k, v in params if stem.util.str_tools._to_unicode(k).lower() in IMMUTABLE_CONFIG_OPTIONS]
+ immutable_params = [k for k, v in params_list if stem.util.str_tools._to_unicode(k).lower() in IMMUTABLE_CONFIG_OPTIONS]
if immutable_params:
raise stem.InvalidArguments(message = "%s cannot be changed while tor's running" % ', '.join(sorted(immutable_params)), arguments = immutable_params)
diff --git a/stem/descriptor/hidden_service.py b/stem/descriptor/hidden_service.py
index dc86b382..63f107e7 100644
--- a/stem/descriptor/hidden_service.py
+++ b/stem/descriptor/hidden_service.py
@@ -285,7 +285,7 @@ class IntroductionPointV3(collections.namedtuple('IntroductionPointV3', ['link_s
lines = []
link_count = stem.client.datatype.Size.CHAR.pack(len(self.link_specifiers))
- link_specifiers = link_count + b''.join([l.pack() for l in self.link_specifiers])
+ link_specifiers = link_count + b''.join([link.pack() for link in self.link_specifiers])
lines.append('introduction-point %s' % stem.util.str_tools._to_unicode(base64.b64encode(link_specifiers)))
lines.append('onion-key ntor %s' % self.onion_key_raw)
lines.append('auth-key\n' + self.auth_key_cert.to_base64(pem = True))
diff --git a/stem/directory.py b/stem/directory.py
index 39abfb90..710e598e 100644
--- a/stem/directory.py
+++ b/stem/directory.py
@@ -267,8 +267,8 @@ class Authority(Directory):
results = {}
for matches in _directory_entries(lines, Authority._pop_section, (AUTHORITY_NAME, AUTHORITY_V3IDENT, AUTHORITY_IPV6, AUTHORITY_ADDR), required = (AUTHORITY_NAME, AUTHORITY_ADDR)):
- nickname, or_port = matches.get(AUTHORITY_NAME)
- address, dir_port, fingerprint = matches.get(AUTHORITY_ADDR)
+ nickname, or_port = matches.get(AUTHORITY_NAME) # type: ignore
+ address, dir_port, fingerprint = matches.get(AUTHORITY_ADDR) # type: ignore
results[nickname] = Authority(
address = address,
@@ -433,7 +433,7 @@ class Fallback(Directory):
results = {}
for matches in _directory_entries(lines, Fallback._pop_section, (FALLBACK_ADDR, FALLBACK_NICKNAME, FALLBACK_EXTRAINFO, FALLBACK_IPV6), required = (FALLBACK_ADDR,)):
- address, dir_port, or_port, fingerprint = matches[FALLBACK_ADDR]
+ address, dir_port, or_port, fingerprint = matches[FALLBACK_ADDR] # type: ignore
results[fingerprint] = Fallback(
address = address,
diff --git a/stem/interpreter/commands.py b/stem/interpreter/commands.py
index 83fd18ef..8552b055 100644
--- a/stem/interpreter/commands.py
+++ b/stem/interpreter/commands.py
@@ -269,7 +269,7 @@ class ControlInterpreter(code.InteractiveConsole):
for label, desc in descriptor_section:
if desc:
lines += ['', div, format(label, *BOLD_OUTPUT), div, '']
- lines += [format(l, *STANDARD_OUTPUT) for l in str(desc).splitlines()]
+ lines += [format(line, *STANDARD_OUTPUT) for line in str(desc).splitlines()]
return '\n'.join(lines)
diff --git a/test/settings.cfg b/test/settings.cfg
index 853c4483..33d9d529 100644
--- a/test/settings.cfg
+++ b/test/settings.cfg
@@ -198,11 +198,13 @@ pyflakes.ignore stem/client/cell.py => undefined name 'cryptography'
pyflakes.ignore stem/client/cell.py => undefined name 'hashlib'
pyflakes.ignore stem/client/datatype.py => redefinition of unused 'pop' from *
pyflakes.ignore stem/descriptor/__init__.py => undefined name 'cryptography'
+pyflakes.ignore stem/descriptor/certificate.py => undefined name 'cryptography'
pyflakes.ignore stem/descriptor/hidden_service.py => undefined name 'cryptography'
pyflakes.ignore stem/interpreter/autocomplete.py => undefined name 'stem'
pyflakes.ignore stem/interpreter/help.py => undefined name 'stem'
pyflakes.ignore stem/response/events.py => undefined name 'datetime'
pyflakes.ignore stem/socket.py => redefinition of unused '_recv'*
+pyflakes.ignore stem/util/__init__.py => undefined name 'cryptography'
pyflakes.ignore stem/util/conf.py => undefined name 'stem'
pyflakes.ignore stem/util/enum.py => undefined name 'stem'
pyflakes.ignore test/require.py => 'cryptography.utils.int_from_bytes' imported but unused
diff --git a/test/unit/response/events.py b/test/unit/response/events.py
index f72a92bb..ad6d4950 100644
--- a/test/unit/response/events.py
+++ b/test/unit/response/events.py
@@ -537,7 +537,7 @@ class TestEvents(unittest.TestCase):
"""
import time
- from stem.control import Controller, EventType
+ from stem.control import EventType
def print_bw(event):
msg = 'sent: %i, received: %i' % (event.written, event.read)