Clarify list/set/dict/tuple comprehensions and enforce via flake8 (#6957)

Ensure good comprehension hygiene using flake8-comprehensions.
This commit is contained in:
Patrick Cloke 2020-02-21 07:15:07 -05:00 committed by GitHub
parent 272eee1ae1
commit 509e381afa
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
73 changed files with 251 additions and 276 deletions

View File

@ -60,7 +60,7 @@ python 3.6 and to install each tool:
``` ```
# Install the dependencies # Install the dependencies
pip install -U black flake8 isort pip install -U black flake8 flake8-comprehensions isort
# Run the linter script # Run the linter script
./scripts-dev/lint.sh ./scripts-dev/lint.sh

1
changelog.d/6957.misc Normal file
View File

@ -0,0 +1 @@
Use flake8-comprehensions to enforce good hygiene of list/set/dict comprehensions.

View File

@ -30,7 +30,7 @@ The necessary tools are detailed below.
Install `flake8` with: Install `flake8` with:
pip install --upgrade flake8 pip install --upgrade flake8 flake8-comprehensions
Check all application and test code with: Check all application and test code with:

View File

@ -103,7 +103,7 @@ def main():
yaml.safe_dump(result, sys.stdout, default_flow_style=False) yaml.safe_dump(result, sys.stdout, default_flow_style=False)
rows = list(row for server, json in result.items() for row in rows_v2(server, json)) rows = [row for server, json in result.items() for row in rows_v2(server, json)]
cursor = connection.cursor() cursor = connection.cursor()
cursor.executemany( cursor.executemany(

View File

@ -141,7 +141,7 @@ def start_reactor(
def quit_with_error(error_string): def quit_with_error(error_string):
message_lines = error_string.split("\n") message_lines = error_string.split("\n")
line_length = max([len(l) for l in message_lines if len(l) < 80]) + 2 line_length = max(len(l) for l in message_lines if len(l) < 80) + 2
sys.stderr.write("*" * line_length + "\n") sys.stderr.write("*" * line_length + "\n")
for line in message_lines: for line in message_lines:
sys.stderr.write(" %s\n" % (line.rstrip(),)) sys.stderr.write(" %s\n" % (line.rstrip(),))

View File

@ -262,7 +262,7 @@ class FederationSenderHandler(object):
# ... as well as device updates and messages # ... as well as device updates and messages
elif stream_name == DeviceListsStream.NAME: elif stream_name == DeviceListsStream.NAME:
hosts = set(row.destination for row in rows) hosts = {row.destination for row in rows}
for host in hosts: for host in hosts:
self.federation_sender.send_device_messages(host) self.federation_sender.send_device_messages(host)
@ -270,7 +270,7 @@ class FederationSenderHandler(object):
# The to_device stream includes stuff to be pushed to both local # The to_device stream includes stuff to be pushed to both local
# clients and remote servers, so we ignore entities that start with # clients and remote servers, so we ignore entities that start with
# '@' (since they'll be local users rather than destinations). # '@' (since they'll be local users rather than destinations).
hosts = set(row.entity for row in rows if not row.entity.startswith("@")) hosts = {row.entity for row in rows if not row.entity.startswith("@")}
for host in hosts: for host in hosts:
self.federation_sender.send_device_messages(host) self.federation_sender.send_device_messages(host)

View File

@ -158,7 +158,7 @@ class PusherReplicationHandler(ReplicationClientHandler):
yield self.pusher_pool.on_new_notifications(token, token) yield self.pusher_pool.on_new_notifications(token, token)
elif stream_name == "receipts": elif stream_name == "receipts":
yield self.pusher_pool.on_new_receipts( yield self.pusher_pool.on_new_receipts(
token, token, set(row.room_id for row in rows) token, token, {row.room_id for row in rows}
) )
except Exception: except Exception:
logger.exception("Error poking pushers") logger.exception("Error poking pushers")

View File

@ -1066,12 +1066,12 @@ KNOWN_RESOURCES = (
def _check_resource_config(listeners): def _check_resource_config(listeners):
resource_names = set( resource_names = {
res_name res_name
for listener in listeners for listener in listeners
for res in listener.get("resources", []) for res in listener.get("resources", [])
for res_name in res.get("names", []) for res_name in res.get("names", [])
) }
for resource in resource_names: for resource in resource_names:
if resource not in KNOWN_RESOURCES: if resource not in KNOWN_RESOURCES:

View File

@ -260,7 +260,7 @@ class TlsConfig(Config):
crypto.FILETYPE_ASN1, self.tls_certificate crypto.FILETYPE_ASN1, self.tls_certificate
) )
sha256_fingerprint = encode_base64(sha256(x509_certificate_bytes).digest()) sha256_fingerprint = encode_base64(sha256(x509_certificate_bytes).digest())
sha256_fingerprints = set(f["sha256"] for f in self.tls_fingerprints) sha256_fingerprints = {f["sha256"] for f in self.tls_fingerprints}
if sha256_fingerprint not in sha256_fingerprints: if sha256_fingerprint not in sha256_fingerprints:
self.tls_fingerprints.append({"sha256": sha256_fingerprint}) self.tls_fingerprints.append({"sha256": sha256_fingerprint})

View File

@ -326,9 +326,7 @@ class Keyring(object):
verify_requests (list[VerifyJsonRequest]): list of verify requests verify_requests (list[VerifyJsonRequest]): list of verify requests
""" """
remaining_requests = set( remaining_requests = {rq for rq in verify_requests if not rq.key_ready.called}
(rq for rq in verify_requests if not rq.key_ready.called)
)
@defer.inlineCallbacks @defer.inlineCallbacks
def do_iterations(): def do_iterations():
@ -396,7 +394,7 @@ class Keyring(object):
results = yield fetcher.get_keys(missing_keys) results = yield fetcher.get_keys(missing_keys)
completed = list() completed = []
for verify_request in remaining_requests: for verify_request in remaining_requests:
server_name = verify_request.server_name server_name = verify_request.server_name

View File

@ -129,9 +129,9 @@ class FederationRemoteSendQueue(object):
for key in keys[:i]: for key in keys[:i]:
del self.presence_changed[key] del self.presence_changed[key]
user_ids = set( user_ids = {
user_id for uids in self.presence_changed.values() for user_id in uids user_id for uids in self.presence_changed.values() for user_id in uids
) }
keys = self.presence_destinations.keys() keys = self.presence_destinations.keys()
i = self.presence_destinations.bisect_left(position_to_delete) i = self.presence_destinations.bisect_left(position_to_delete)

View File

@ -608,7 +608,7 @@ class GroupsServerHandler(GroupsServerWorkerHandler):
user_results = yield self.store.get_users_in_group( user_results = yield self.store.get_users_in_group(
group_id, include_private=True group_id, include_private=True
) )
if user_id in [user_result["user_id"] for user_result in user_results]: if user_id in (user_result["user_id"] for user_result in user_results):
raise SynapseError(400, "User already in group") raise SynapseError(400, "User already in group")
content = { content = {

View File

@ -742,6 +742,6 @@ class DeviceListUpdater(object):
# We clobber the seen updates since we've re-synced from a given # We clobber the seen updates since we've re-synced from a given
# point. # point.
self._seen_updates[user_id] = set([stream_id]) self._seen_updates[user_id] = {stream_id}
defer.returnValue(result) defer.returnValue(result)

View File

@ -72,7 +72,7 @@ class DirectoryHandler(BaseHandler):
# TODO(erikj): Check if there is a current association. # TODO(erikj): Check if there is a current association.
if not servers: if not servers:
users = yield self.state.get_current_users_in_room(room_id) users = yield self.state.get_current_users_in_room(room_id)
servers = set(get_domain_from_id(u) for u in users) servers = {get_domain_from_id(u) for u in users}
if not servers: if not servers:
raise SynapseError(400, "Failed to get server list") raise SynapseError(400, "Failed to get server list")
@ -255,7 +255,7 @@ class DirectoryHandler(BaseHandler):
) )
users = yield self.state.get_current_users_in_room(room_id) users = yield self.state.get_current_users_in_room(room_id)
extra_servers = set(get_domain_from_id(u) for u in users) extra_servers = {get_domain_from_id(u) for u in users}
servers = set(extra_servers) | set(servers) servers = set(extra_servers) | set(servers)
# If this server is in the list of servers, return it first. # If this server is in the list of servers, return it first.

View File

@ -659,11 +659,11 @@ class FederationHandler(BaseHandler):
# this can happen if a remote server claims that the state or # this can happen if a remote server claims that the state or
# auth_events at an event in room A are actually events in room B # auth_events at an event in room A are actually events in room B
bad_events = list( bad_events = [
(event_id, event.room_id) (event_id, event.room_id)
for event_id, event in fetched_events.items() for event_id, event in fetched_events.items()
if event.room_id != room_id if event.room_id != room_id
) ]
for bad_event_id, bad_room_id in bad_events: for bad_event_id, bad_room_id in bad_events:
# This is a bogus situation, but since we may only discover it a long time # This is a bogus situation, but since we may only discover it a long time
@ -856,7 +856,7 @@ class FederationHandler(BaseHandler):
# Don't bother processing events we already have. # Don't bother processing events we already have.
seen_events = await self.store.have_events_in_timeline( seen_events = await self.store.have_events_in_timeline(
set(e.event_id for e in events) {e.event_id for e in events}
) )
events = [e for e in events if e.event_id not in seen_events] events = [e for e in events if e.event_id not in seen_events]
@ -866,7 +866,7 @@ class FederationHandler(BaseHandler):
event_map = {e.event_id: e for e in events} event_map = {e.event_id: e for e in events}
event_ids = set(e.event_id for e in events) event_ids = {e.event_id for e in events}
# build a list of events whose prev_events weren't in the batch. # build a list of events whose prev_events weren't in the batch.
# (XXX: this will include events whose prev_events we already have; that doesn't # (XXX: this will include events whose prev_events we already have; that doesn't
@ -892,13 +892,13 @@ class FederationHandler(BaseHandler):
state_events.update({s.event_id: s for s in state}) state_events.update({s.event_id: s for s in state})
events_to_state[e_id] = state events_to_state[e_id] = state
required_auth = set( required_auth = {
a_id a_id
for event in events for event in events
+ list(state_events.values()) + list(state_events.values())
+ list(auth_events.values()) + list(auth_events.values())
for a_id in event.auth_event_ids() for a_id in event.auth_event_ids()
) }
auth_events.update( auth_events.update(
{e_id: event_map[e_id] for e_id in required_auth if e_id in event_map} {e_id: event_map[e_id] for e_id in required_auth if e_id in event_map}
) )
@ -1247,7 +1247,7 @@ class FederationHandler(BaseHandler):
async def on_event_auth(self, event_id: str) -> List[EventBase]: async def on_event_auth(self, event_id: str) -> List[EventBase]:
event = await self.store.get_event(event_id) event = await self.store.get_event(event_id)
auth = await self.store.get_auth_chain( auth = await self.store.get_auth_chain(
[auth_id for auth_id in event.auth_event_ids()], include_given=True list(event.auth_event_ids()), include_given=True
) )
return list(auth) return list(auth)
@ -2152,7 +2152,7 @@ class FederationHandler(BaseHandler):
# Now get the current auth_chain for the event. # Now get the current auth_chain for the event.
local_auth_chain = await self.store.get_auth_chain( local_auth_chain = await self.store.get_auth_chain(
[auth_id for auth_id in event.auth_event_ids()], include_given=True list(event.auth_event_ids()), include_given=True
) )
# TODO: Check if we would now reject event_id. If so we need to tell # TODO: Check if we would now reject event_id. If so we need to tell
@ -2654,7 +2654,7 @@ class FederationHandler(BaseHandler):
member_handler = self.hs.get_room_member_handler() member_handler = self.hs.get_room_member_handler()
yield member_handler.send_membership_event(None, event, context) yield member_handler.send_membership_event(None, event, context)
else: else:
destinations = set(x.split(":", 1)[-1] for x in (sender_user_id, room_id)) destinations = {x.split(":", 1)[-1] for x in (sender_user_id, room_id)}
yield self.federation_client.forward_third_party_invite( yield self.federation_client.forward_third_party_invite(
destinations, room_id, event_dict destinations, room_id, event_dict
) )

View File

@ -313,7 +313,7 @@ class PresenceHandler(object):
notified_presence_counter.inc(len(to_notify)) notified_presence_counter.inc(len(to_notify))
yield self._persist_and_notify(list(to_notify.values())) yield self._persist_and_notify(list(to_notify.values()))
self.unpersisted_users_changes |= set(s.user_id for s in new_states) self.unpersisted_users_changes |= {s.user_id for s in new_states}
self.unpersisted_users_changes -= set(to_notify.keys()) self.unpersisted_users_changes -= set(to_notify.keys())
to_federation_ping = { to_federation_ping = {
@ -698,7 +698,7 @@ class PresenceHandler(object):
updates = yield self.current_state_for_users(target_user_ids) updates = yield self.current_state_for_users(target_user_ids)
updates = list(updates.values()) updates = list(updates.values())
for user_id in set(target_user_ids) - set(u.user_id for u in updates): for user_id in set(target_user_ids) - {u.user_id for u in updates}:
updates.append(UserPresenceState.default(user_id)) updates.append(UserPresenceState.default(user_id))
now = self.clock.time_msec() now = self.clock.time_msec()
@ -886,7 +886,7 @@ class PresenceHandler(object):
hosts = yield self.state.get_current_hosts_in_room(room_id) hosts = yield self.state.get_current_hosts_in_room(room_id)
# Filter out ourselves. # Filter out ourselves.
hosts = set(host for host in hosts if host != self.server_name) hosts = {host for host in hosts if host != self.server_name}
self.federation.send_presence_to_destinations( self.federation.send_presence_to_destinations(
states=[state], destinations=hosts states=[state], destinations=hosts

View File

@ -94,7 +94,7 @@ class ReceiptsHandler(BaseHandler):
# no new receipts # no new receipts
return False return False
affected_room_ids = list(set([r.room_id for r in receipts])) affected_room_ids = list({r.room_id for r in receipts})
self.notifier.on_new_event("receipt_key", max_batch_id, rooms=affected_room_ids) self.notifier.on_new_event("receipt_key", max_batch_id, rooms=affected_room_ids)
# Note that the min here shouldn't be relied upon to be accurate. # Note that the min here shouldn't be relied upon to be accurate.

View File

@ -355,7 +355,7 @@ class RoomCreationHandler(BaseHandler):
# If so, mark the new room as non-federatable as well # If so, mark the new room as non-federatable as well
creation_content["m.federate"] = False creation_content["m.federate"] = False
initial_state = dict() initial_state = {}
# Replicate relevant room events # Replicate relevant room events
types_to_copy = ( types_to_copy = (

View File

@ -184,7 +184,7 @@ class SearchHandler(BaseHandler):
membership_list=[Membership.JOIN], membership_list=[Membership.JOIN],
# membership_list=[Membership.JOIN, Membership.LEAVE, Membership.Ban], # membership_list=[Membership.JOIN, Membership.LEAVE, Membership.Ban],
) )
room_ids = set(r.room_id for r in rooms) room_ids = {r.room_id for r in rooms}
# If doing a subset of all rooms seearch, check if any of the rooms # If doing a subset of all rooms seearch, check if any of the rooms
# are from an upgraded room, and search their contents as well # are from an upgraded room, and search their contents as well
@ -374,12 +374,12 @@ class SearchHandler(BaseHandler):
).to_string() ).to_string()
if include_profile: if include_profile:
senders = set( senders = {
ev.sender ev.sender
for ev in itertools.chain( for ev in itertools.chain(
res["events_before"], [event], res["events_after"] res["events_before"], [event], res["events_after"]
) )
) }
if res["events_after"]: if res["events_after"]:
last_event_id = res["events_after"][-1].event_id last_event_id = res["events_after"][-1].event_id
@ -421,7 +421,7 @@ class SearchHandler(BaseHandler):
state_results = {} state_results = {}
if include_state: if include_state:
rooms = set(e.room_id for e in allowed_events) rooms = {e.room_id for e in allowed_events}
for room_id in rooms: for room_id in rooms:
state = yield self.state_handler.get_current_state(room_id) state = yield self.state_handler.get_current_state(room_id)
state_results[room_id] = list(state.values()) state_results[room_id] = list(state.values())

View File

@ -682,11 +682,9 @@ class SyncHandler(object):
# FIXME: order by stream ordering rather than as returned by SQL # FIXME: order by stream ordering rather than as returned by SQL
if joined_user_ids or invited_user_ids: if joined_user_ids or invited_user_ids:
summary["m.heroes"] = sorted( summary["m.heroes"] = sorted(joined_user_ids + invited_user_ids)[0:5]
[user_id for user_id in (joined_user_ids + invited_user_ids)]
)[0:5]
else: else:
summary["m.heroes"] = sorted([user_id for user_id in gone_user_ids])[0:5] summary["m.heroes"] = sorted(gone_user_ids)[0:5]
if not sync_config.filter_collection.lazy_load_members(): if not sync_config.filter_collection.lazy_load_members():
return summary return summary
@ -697,9 +695,9 @@ class SyncHandler(object):
# track which members the client should already know about via LL: # track which members the client should already know about via LL:
# Ones which are already in state... # Ones which are already in state...
existing_members = set( existing_members = {
user_id for (typ, user_id) in state.keys() if typ == EventTypes.Member user_id for (typ, user_id) in state.keys() if typ == EventTypes.Member
) }
# ...or ones which are in the timeline... # ...or ones which are in the timeline...
for ev in batch.events: for ev in batch.events:
@ -773,10 +771,10 @@ class SyncHandler(object):
# We only request state for the members needed to display the # We only request state for the members needed to display the
# timeline: # timeline:
members_to_fetch = set( members_to_fetch = {
event.sender # FIXME: we also care about invite targets etc. event.sender # FIXME: we also care about invite targets etc.
for event in batch.events for event in batch.events
) }
if full_state: if full_state:
# always make sure we LL ourselves so we know we're in the room # always make sure we LL ourselves so we know we're in the room
@ -1993,10 +1991,10 @@ def _calculate_state(
) )
} }
c_ids = set(e for e in itervalues(current)) c_ids = set(itervalues(current))
ts_ids = set(e for e in itervalues(timeline_start)) ts_ids = set(itervalues(timeline_start))
p_ids = set(e for e in itervalues(previous)) p_ids = set(itervalues(previous))
tc_ids = set(e for e in itervalues(timeline_contains)) tc_ids = set(itervalues(timeline_contains))
# If we are lazyloading room members, we explicitly add the membership events # If we are lazyloading room members, we explicitly add the membership events
# for the senders in the timeline into the state block returned by /sync, # for the senders in the timeline into the state block returned by /sync,

View File

@ -198,7 +198,7 @@ class TypingHandler(object):
now=now, obj=member, then=now + FEDERATION_PING_INTERVAL now=now, obj=member, then=now + FEDERATION_PING_INTERVAL
) )
for domain in set(get_domain_from_id(u) for u in users): for domain in {get_domain_from_id(u) for u in users}:
if domain != self.server_name: if domain != self.server_name:
logger.debug("sending typing update to %s", domain) logger.debug("sending typing update to %s", domain)
self.federation.build_and_send_edu( self.federation.build_and_send_edu(
@ -231,7 +231,7 @@ class TypingHandler(object):
return return
users = yield self.state.get_current_users_in_room(room_id) users = yield self.state.get_current_users_in_room(room_id)
domains = set(get_domain_from_id(u) for u in users) domains = {get_domain_from_id(u) for u in users}
if self.server_name in domains: if self.server_name in domains:
logger.info("Got typing update from %s: %r", user_id, content) logger.info("Got typing update from %s: %r", user_id, content)

View File

@ -148,7 +148,7 @@ def trace_function(f):
pathname=pathname, pathname=pathname,
lineno=lineno, lineno=lineno,
msg=msg, msg=msg,
args=tuple(), args=(),
exc_info=None, exc_info=None,
) )

View File

@ -240,7 +240,7 @@ class BucketCollector(object):
res.append(["+Inf", sum(data.values())]) res.append(["+Inf", sum(data.values())])
metric = HistogramMetricFamily( metric = HistogramMetricFamily(
self.name, "", buckets=res, sum_value=sum([x * y for x, y in data.items()]) self.name, "", buckets=res, sum_value=sum(x * y for x, y in data.items())
) )
yield metric yield metric

View File

@ -80,13 +80,13 @@ _background_process_db_sched_duration = Counter(
# map from description to a counter, so that we can name our logcontexts # map from description to a counter, so that we can name our logcontexts
# incrementally. (It actually duplicates _background_process_start_count, but # incrementally. (It actually duplicates _background_process_start_count, but
# it's much simpler to do so than to try to combine them.) # it's much simpler to do so than to try to combine them.)
_background_process_counts = dict() # type: dict[str, int] _background_process_counts = {} # type: dict[str, int]
# map from description to the currently running background processes. # map from description to the currently running background processes.
# #
# it's kept as a dict of sets rather than a big set so that we can keep track # it's kept as a dict of sets rather than a big set so that we can keep track
# of process descriptions that no longer have any active processes. # of process descriptions that no longer have any active processes.
_background_processes = dict() # type: dict[str, set[_BackgroundProcess]] _background_processes = {} # type: dict[str, set[_BackgroundProcess]]
# A lock that covers the above dicts # A lock that covers the above dicts
_bg_metrics_lock = threading.Lock() _bg_metrics_lock = threading.Lock()

View File

@ -400,11 +400,11 @@ class RulesForRoom(object):
if logger.isEnabledFor(logging.DEBUG): if logger.isEnabledFor(logging.DEBUG):
logger.debug("Found members %r: %r", self.room_id, members.values()) logger.debug("Found members %r: %r", self.room_id, members.values())
interested_in_user_ids = set( interested_in_user_ids = {
user_id user_id
for user_id, membership in itervalues(members) for user_id, membership in itervalues(members)
if membership == Membership.JOIN if membership == Membership.JOIN
) }
logger.debug("Joined: %r", interested_in_user_ids) logger.debug("Joined: %r", interested_in_user_ids)
@ -412,9 +412,9 @@ class RulesForRoom(object):
interested_in_user_ids, on_invalidate=self.invalidate_all_cb interested_in_user_ids, on_invalidate=self.invalidate_all_cb
) )
user_ids = set( user_ids = {
uid for uid, have_pusher in iteritems(if_users_with_pushers) if have_pusher uid for uid, have_pusher in iteritems(if_users_with_pushers) if have_pusher
) }
logger.debug("With pushers: %r", user_ids) logger.debug("With pushers: %r", user_ids)

View File

@ -204,7 +204,7 @@ class EmailPusher(object):
yield self.send_notification(unprocessed, reason) yield self.send_notification(unprocessed, reason)
yield self.save_last_stream_ordering_and_success( yield self.save_last_stream_ordering_and_success(
max([ea["stream_ordering"] for ea in unprocessed]) max(ea["stream_ordering"] for ea in unprocessed)
) )
# we update the throttle on all the possible unprocessed push actions # we update the throttle on all the possible unprocessed push actions

View File

@ -526,12 +526,10 @@ class Mailer(object):
# If the room doesn't have a name, say who the messages # If the room doesn't have a name, say who the messages
# are from explicitly to avoid, "messages in the Bob room" # are from explicitly to avoid, "messages in the Bob room"
sender_ids = list( sender_ids = list(
set( {
[
notif_events[n["event_id"]].sender notif_events[n["event_id"]].sender
for n in notifs_by_room[room_id] for n in notifs_by_room[room_id]
] }
)
) )
member_events = yield self.store.get_events( member_events = yield self.store.get_events(
@ -558,12 +556,10 @@ class Mailer(object):
# If the reason room doesn't have a name, say who the messages # If the reason room doesn't have a name, say who the messages
# are from explicitly to avoid, "messages in the Bob room" # are from explicitly to avoid, "messages in the Bob room"
sender_ids = list( sender_ids = list(
set( {
[
notif_events[n["event_id"]].sender notif_events[n["event_id"]].sender
for n in notifs_by_room[reason["room_id"]] for n in notifs_by_room[reason["room_id"]]
] }
)
) )
member_events = yield self.store.get_events( member_events = yield self.store.get_events(

View File

@ -191,7 +191,7 @@ class PusherPool:
min_stream_id - 1, max_stream_id min_stream_id - 1, max_stream_id
) )
# This returns a tuple, user_id is at index 3 # This returns a tuple, user_id is at index 3
users_affected = set([r[3] for r in updated_receipts]) users_affected = {r[3] for r in updated_receipts}
for u in users_affected: for u in users_affected:
if u in self.pushers: if u in self.pushers:

View File

@ -29,7 +29,7 @@ def historical_admin_path_patterns(path_regex):
Note that this should only be used for existing endpoints: new ones should just Note that this should only be used for existing endpoints: new ones should just
register for the /_synapse/admin path. register for the /_synapse/admin path.
""" """
return list( return [
re.compile(prefix + path_regex) re.compile(prefix + path_regex)
for prefix in ( for prefix in (
"^/_synapse/admin/v1", "^/_synapse/admin/v1",
@ -37,7 +37,7 @@ def historical_admin_path_patterns(path_regex):
"^/_matrix/client/unstable/admin", "^/_matrix/client/unstable/admin",
"^/_matrix/client/r0/admin", "^/_matrix/client/r0/admin",
) )
) ]
def admin_patterns(path_regex: str): def admin_patterns(path_regex: str):

View File

@ -49,7 +49,7 @@ class PushRuleRestServlet(RestServlet):
if self._is_worker: if self._is_worker:
raise Exception("Cannot handle PUT /push_rules on worker") raise Exception("Cannot handle PUT /push_rules on worker")
spec = _rule_spec_from_path([x for x in path.split("/")]) spec = _rule_spec_from_path(path.split("/"))
try: try:
priority_class = _priority_class_from_spec(spec) priority_class = _priority_class_from_spec(spec)
except InvalidRuleException as e: except InvalidRuleException as e:
@ -110,7 +110,7 @@ class PushRuleRestServlet(RestServlet):
if self._is_worker: if self._is_worker:
raise Exception("Cannot handle DELETE /push_rules on worker") raise Exception("Cannot handle DELETE /push_rules on worker")
spec = _rule_spec_from_path([x for x in path.split("/")]) spec = _rule_spec_from_path(path.split("/"))
requester = await self.auth.get_user_by_req(request) requester = await self.auth.get_user_by_req(request)
user_id = requester.user.to_string() user_id = requester.user.to_string()
@ -138,7 +138,7 @@ class PushRuleRestServlet(RestServlet):
rules = format_push_rules_for_user(requester.user, rules) rules = format_push_rules_for_user(requester.user, rules)
path = [x for x in path.split("/")][1:] path = path.split("/")[1:]
if path == []: if path == []:
# we're a reference impl: pedantry is our job. # we're a reference impl: pedantry is our job.

View File

@ -54,9 +54,9 @@ class PushersRestServlet(RestServlet):
pushers = await self.hs.get_datastore().get_pushers_by_user_id(user.to_string()) pushers = await self.hs.get_datastore().get_pushers_by_user_id(user.to_string())
filtered_pushers = list( filtered_pushers = [
{k: v for k, v in p.items() if k in ALLOWED_KEYS} for p in pushers {k: v for k, v in p.items() if k in ALLOWED_KEYS} for p in pushers
) ]
return 200, {"pushers": filtered_pushers} return 200, {"pushers": filtered_pushers}

View File

@ -72,7 +72,7 @@ class SyncRestServlet(RestServlet):
""" """
PATTERNS = client_patterns("/sync$") PATTERNS = client_patterns("/sync$")
ALLOWED_PRESENCE = set(["online", "offline", "unavailable"]) ALLOWED_PRESENCE = {"online", "offline", "unavailable"}
def __init__(self, hs): def __init__(self, hs):
super(SyncRestServlet, self).__init__() super(SyncRestServlet, self).__init__()

View File

@ -149,7 +149,7 @@ class RemoteKey(DirectServeResource):
time_now_ms = self.clock.time_msec() time_now_ms = self.clock.time_msec()
cache_misses = dict() # type: Dict[str, Set[str]] cache_misses = {} # type: Dict[str, Set[str]]
for (server_name, key_id, from_server), results in cached.items(): for (server_name, key_id, from_server), results in cached.items():
results = [(result["ts_added_ms"], result) for result in results] results = [(result["ts_added_ms"], result) for result in results]

View File

@ -135,8 +135,7 @@ def add_file_headers(request, media_type, file_size, upload_name):
# separators as defined in RFC2616. SP and HT are handled separately. # separators as defined in RFC2616. SP and HT are handled separately.
# see _can_encode_filename_as_token. # see _can_encode_filename_as_token.
_FILENAME_SEPARATOR_CHARS = set( _FILENAME_SEPARATOR_CHARS = {
(
"(", "(",
")", ")",
"<", "<",
@ -154,8 +153,7 @@ _FILENAME_SEPARATOR_CHARS = set(
"=", "=",
"{", "{",
"}", "}",
) }
)
def _can_encode_filename_as_token(x): def _can_encode_filename_as_token(x):

View File

@ -69,9 +69,9 @@ def resolve_events_with_store(
unconflicted_state, conflicted_state = _seperate(state_sets) unconflicted_state, conflicted_state = _seperate(state_sets)
needed_events = set( needed_events = {
event_id for event_ids in itervalues(conflicted_state) for event_id in event_ids event_id for event_ids in itervalues(conflicted_state) for event_id in event_ids
) }
needed_event_count = len(needed_events) needed_event_count = len(needed_events)
if event_map is not None: if event_map is not None:
needed_events -= set(iterkeys(event_map)) needed_events -= set(iterkeys(event_map))
@ -261,11 +261,11 @@ def _resolve_state_events(conflicted_state, auth_events):
def _resolve_auth_events(events, auth_events): def _resolve_auth_events(events, auth_events):
reverse = [i for i in reversed(_ordered_events(events))] reverse = list(reversed(_ordered_events(events)))
auth_keys = set( auth_keys = {
key for event in events for key in event_auth.auth_types_for_event(event) key for event in events for key in event_auth.auth_types_for_event(event)
) }
new_auth_events = {} new_auth_events = {}
for key in auth_keys: for key in auth_keys:

View File

@ -105,7 +105,7 @@ def resolve_events_with_store(
% (room_id, event.event_id, event.room_id,) % (room_id, event.event_id, event.room_id,)
) )
full_conflicted_set = set(eid for eid in full_conflicted_set if eid in event_map) full_conflicted_set = {eid for eid in full_conflicted_set if eid in event_map}
logger.debug("%d full_conflicted_set entries", len(full_conflicted_set)) logger.debug("%d full_conflicted_set entries", len(full_conflicted_set))
@ -233,7 +233,7 @@ def _get_auth_chain_difference(state_sets, event_map, state_res_store):
auth_sets = [] auth_sets = []
for state_set in state_sets: for state_set in state_sets:
auth_ids = set( auth_ids = {
eid eid
for key, eid in iteritems(state_set) for key, eid in iteritems(state_set)
if ( if (
@ -246,7 +246,7 @@ def _get_auth_chain_difference(state_sets, event_map, state_res_store):
) )
) )
and eid not in common and eid not in common
) }
auth_chain = yield state_res_store.get_auth_chain(auth_ids, common) auth_chain = yield state_res_store.get_auth_chain(auth_ids, common)
auth_ids.update(auth_chain) auth_ids.update(auth_chain)
@ -275,7 +275,7 @@ def _seperate(state_sets):
conflicted_state = {} conflicted_state = {}
for key in set(itertools.chain.from_iterable(state_sets)): for key in set(itertools.chain.from_iterable(state_sets)):
event_ids = set(state_set.get(key) for state_set in state_sets) event_ids = {state_set.get(key) for state_set in state_sets}
if len(event_ids) == 1: if len(event_ids) == 1:
unconflicted_state[key] = event_ids.pop() unconflicted_state[key] = event_ids.pop()
else: else:

View File

@ -56,7 +56,7 @@ class SQLBaseStore(metaclass=ABCMeta):
members_changed (iterable[str]): The user_ids of members that have members_changed (iterable[str]): The user_ids of members that have
changed changed
""" """
for host in set(get_domain_from_id(u) for u in members_changed): for host in {get_domain_from_id(u) for u in members_changed}:
self._attempt_to_invalidate_cache("is_host_joined", (room_id, host)) self._attempt_to_invalidate_cache("is_host_joined", (room_id, host))
self._attempt_to_invalidate_cache("was_host_joined", (room_id, host)) self._attempt_to_invalidate_cache("was_host_joined", (room_id, host))

View File

@ -189,7 +189,7 @@ class BackgroundUpdater(object):
keyvalues=None, keyvalues=None,
retcols=("update_name", "depends_on"), retcols=("update_name", "depends_on"),
) )
in_flight = set(update["update_name"] for update in updates) in_flight = {update["update_name"] for update in updates}
for update in updates: for update in updates:
if update["depends_on"] not in in_flight: if update["depends_on"] not in in_flight:
self._background_update_queue.append(update["update_name"]) self._background_update_queue.append(update["update_name"])

View File

@ -135,7 +135,7 @@ class ApplicationServiceTransactionWorkerStore(
may be empty. may be empty.
""" """
results = yield self.db.simple_select_list( results = yield self.db.simple_select_list(
"application_services_state", dict(state=state), ["as_id"] "application_services_state", {"state": state}, ["as_id"]
) )
# NB: This assumes this class is linked with ApplicationServiceStore # NB: This assumes this class is linked with ApplicationServiceStore
as_list = self.get_app_services() as_list = self.get_app_services()
@ -158,7 +158,7 @@ class ApplicationServiceTransactionWorkerStore(
""" """
result = yield self.db.simple_select_one( result = yield self.db.simple_select_one(
"application_services_state", "application_services_state",
dict(as_id=service.id), {"as_id": service.id},
["state"], ["state"],
allow_none=True, allow_none=True,
desc="get_appservice_state", desc="get_appservice_state",
@ -177,7 +177,7 @@ class ApplicationServiceTransactionWorkerStore(
A Deferred which resolves when the state was set successfully. A Deferred which resolves when the state was set successfully.
""" """
return self.db.simple_upsert( return self.db.simple_upsert(
"application_services_state", dict(as_id=service.id), dict(state=state) "application_services_state", {"as_id": service.id}, {"state": state}
) )
def create_appservice_txn(self, service, events): def create_appservice_txn(self, service, events):
@ -253,13 +253,15 @@ class ApplicationServiceTransactionWorkerStore(
self.db.simple_upsert_txn( self.db.simple_upsert_txn(
txn, txn,
"application_services_state", "application_services_state",
dict(as_id=service.id), {"as_id": service.id},
dict(last_txn=txn_id), {"last_txn": txn_id},
) )
# Delete txn # Delete txn
self.db.simple_delete_txn( self.db.simple_delete_txn(
txn, "application_services_txns", dict(txn_id=txn_id, as_id=service.id) txn,
"application_services_txns",
{"txn_id": txn_id, "as_id": service.id},
) )
return self.db.runInteraction( return self.db.runInteraction(

View File

@ -530,7 +530,7 @@ class ClientIpStore(ClientIpBackgroundUpdateStore):
((row["access_token"], row["ip"]), (row["user_agent"], row["last_seen"])) ((row["access_token"], row["ip"]), (row["user_agent"], row["last_seen"]))
for row in rows for row in rows
) )
return list( return [
{ {
"access_token": access_token, "access_token": access_token,
"ip": ip, "ip": ip,
@ -538,7 +538,7 @@ class ClientIpStore(ClientIpBackgroundUpdateStore):
"last_seen": last_seen, "last_seen": last_seen,
} }
for (access_token, ip), (user_agent, last_seen) in iteritems(results) for (access_token, ip), (user_agent, last_seen) in iteritems(results)
) ]
@wrap_as_background_process("prune_old_user_ips") @wrap_as_background_process("prune_old_user_ips")
async def _prune_old_user_ips(self): async def _prune_old_user_ips(self):

View File

@ -137,7 +137,7 @@ class DeviceWorkerStore(SQLBaseStore):
# get the cross-signing keys of the users in the list, so that we can # get the cross-signing keys of the users in the list, so that we can
# determine which of the device changes were cross-signing keys # determine which of the device changes were cross-signing keys
users = set(r[0] for r in updates) users = {r[0] for r in updates}
master_key_by_user = {} master_key_by_user = {}
self_signing_key_by_user = {} self_signing_key_by_user = {}
for user in users: for user in users:
@ -446,7 +446,7 @@ class DeviceWorkerStore(SQLBaseStore):
a set of user_ids and results_map is a mapping of a set of user_ids and results_map is a mapping of
user_id -> device_id -> device_info user_id -> device_id -> device_info
""" """
user_ids = set(user_id for user_id, _ in query_list) user_ids = {user_id for user_id, _ in query_list}
user_map = yield self.get_device_list_last_stream_id_for_remotes(list(user_ids)) user_map = yield self.get_device_list_last_stream_id_for_remotes(list(user_ids))
# We go and check if any of the users need to have their device lists # We go and check if any of the users need to have their device lists
@ -454,10 +454,9 @@ class DeviceWorkerStore(SQLBaseStore):
users_needing_resync = yield self.get_user_ids_requiring_device_list_resync( users_needing_resync = yield self.get_user_ids_requiring_device_list_resync(
user_ids user_ids
) )
user_ids_in_cache = ( user_ids_in_cache = {
set(user_id for user_id, stream_id in user_map.items() if stream_id) user_id for user_id, stream_id in user_map.items() if stream_id
- users_needing_resync } - users_needing_resync
)
user_ids_not_in_cache = user_ids - user_ids_in_cache user_ids_not_in_cache = user_ids - user_ids_in_cache
results = {} results = {}
@ -604,7 +603,7 @@ class DeviceWorkerStore(SQLBaseStore):
rows = yield self.db.execute( rows = yield self.db.execute(
"get_users_whose_signatures_changed", None, sql, user_id, from_key "get_users_whose_signatures_changed", None, sql, user_id, from_key
) )
return set(user for row in rows for user in json.loads(row[0])) return {user for row in rows for user in json.loads(row[0])}
else: else:
return set() return set()

View File

@ -426,7 +426,7 @@ class EventFederationWorkerStore(EventsWorkerStore, SignatureWorkerStore, SQLBas
query, (room_id, event_id, False, limit - len(event_results)) query, (room_id, event_id, False, limit - len(event_results))
) )
new_results = set(t[0] for t in txn) - seen_events new_results = {t[0] for t in txn} - seen_events
new_front |= new_results new_front |= new_results
seen_events |= new_results seen_events |= new_results

View File

@ -145,7 +145,7 @@ class EventsStore(
return txn.fetchall() return txn.fetchall()
res = yield self.db.runInteraction("read_forward_extremities", fetch) res = yield self.db.runInteraction("read_forward_extremities", fetch)
self._current_forward_extremities_amount = c_counter(list(x[0] for x in res)) self._current_forward_extremities_amount = c_counter([x[0] for x in res])
@_retry_on_integrity_error @_retry_on_integrity_error
@defer.inlineCallbacks @defer.inlineCallbacks
@ -598,11 +598,11 @@ class EventsStore(
# We find out which membership events we may have deleted # We find out which membership events we may have deleted
# and which we have added, then we invlidate the caches for all # and which we have added, then we invlidate the caches for all
# those users. # those users.
members_changed = set( members_changed = {
state_key state_key
for ev_type, state_key in itertools.chain(to_delete, to_insert) for ev_type, state_key in itertools.chain(to_delete, to_insert)
if ev_type == EventTypes.Member if ev_type == EventTypes.Member
) }
for member in members_changed: for member in members_changed:
txn.call_after( txn.call_after(
@ -1615,7 +1615,7 @@ class EventsStore(
""" """
) )
referenced_state_groups = set(sg for sg, in txn) referenced_state_groups = {sg for sg, in txn}
logger.info( logger.info(
"[purge] found %i referenced state groups", len(referenced_state_groups) "[purge] found %i referenced state groups", len(referenced_state_groups)
) )

View File

@ -402,7 +402,7 @@ class EventsBackgroundUpdatesStore(SQLBaseStore):
keyvalues={}, keyvalues={},
retcols=("room_id",), retcols=("room_id",),
) )
room_ids = set(row["room_id"] for row in rows) room_ids = {row["room_id"] for row in rows}
for room_id in room_ids: for room_id in room_ids:
txn.call_after( txn.call_after(
self.get_latest_event_ids_in_room.invalidate, (room_id,) self.get_latest_event_ids_in_room.invalidate, (room_id,)

View File

@ -494,9 +494,9 @@ class EventsWorkerStore(SQLBaseStore):
""" """
with Measure(self._clock, "_fetch_event_list"): with Measure(self._clock, "_fetch_event_list"):
try: try:
events_to_fetch = set( events_to_fetch = {
event_id for events, _ in event_list for event_id in events event_id for events, _ in event_list for event_id in events
) }
row_dict = self.db.new_transaction( row_dict = self.db.new_transaction(
conn, "do_fetch", [], [], self._fetch_event_rows, events_to_fetch conn, "do_fetch", [], [], self._fetch_event_rows, events_to_fetch
@ -804,7 +804,7 @@ class EventsWorkerStore(SQLBaseStore):
desc="have_events_in_timeline", desc="have_events_in_timeline",
) )
return set(r["event_id"] for r in rows) return {r["event_id"] for r in rows}
@defer.inlineCallbacks @defer.inlineCallbacks
def have_seen_events(self, event_ids): def have_seen_events(self, event_ids):

View File

@ -276,21 +276,21 @@ class PushRulesWorkerStore(
# We ignore app service users for now. This is so that we don't fill # We ignore app service users for now. This is so that we don't fill
# up the `get_if_users_have_pushers` cache with AS entries that we # up the `get_if_users_have_pushers` cache with AS entries that we
# know don't have pushers, nor even read receipts. # know don't have pushers, nor even read receipts.
local_users_in_room = set( local_users_in_room = {
u u
for u in users_in_room for u in users_in_room
if self.hs.is_mine_id(u) if self.hs.is_mine_id(u)
and not self.get_if_app_services_interested_in_user(u) and not self.get_if_app_services_interested_in_user(u)
) }
# users in the room who have pushers need to get push rules run because # users in the room who have pushers need to get push rules run because
# that's how their pushers work # that's how their pushers work
if_users_with_pushers = yield self.get_if_users_have_pushers( if_users_with_pushers = yield self.get_if_users_have_pushers(
local_users_in_room, on_invalidate=cache_context.invalidate local_users_in_room, on_invalidate=cache_context.invalidate
) )
user_ids = set( user_ids = {
uid for uid, have_pusher in if_users_with_pushers.items() if have_pusher uid for uid, have_pusher in if_users_with_pushers.items() if have_pusher
) }
users_with_receipts = yield self.get_users_with_read_receipts_in_room( users_with_receipts = yield self.get_users_with_read_receipts_in_room(
room_id, on_invalidate=cache_context.invalidate room_id, on_invalidate=cache_context.invalidate

View File

@ -58,7 +58,7 @@ class ReceiptsWorkerStore(SQLBaseStore):
@cachedInlineCallbacks() @cachedInlineCallbacks()
def get_users_with_read_receipts_in_room(self, room_id): def get_users_with_read_receipts_in_room(self, room_id):
receipts = yield self.get_receipts_for_room(room_id, "m.read") receipts = yield self.get_receipts_for_room(room_id, "m.read")
return set(r["user_id"] for r in receipts) return {r["user_id"] for r in receipts}
@cached(num_args=2) @cached(num_args=2)
def get_receipts_for_room(self, room_id, receipt_type): def get_receipts_for_room(self, room_id, receipt_type):
@ -283,7 +283,7 @@ class ReceiptsWorkerStore(SQLBaseStore):
args.append(limit) args.append(limit)
txn.execute(sql, args) txn.execute(sql, args)
return list(r[0:5] + (json.loads(r[5]),) for r in txn) return [r[0:5] + (json.loads(r[5]),) for r in txn]
return self.db.runInteraction( return self.db.runInteraction(
"get_all_updated_receipts", get_all_updated_receipts_txn "get_all_updated_receipts", get_all_updated_receipts_txn

View File

@ -465,7 +465,7 @@ class RoomMemberWorkerStore(EventsWorkerStore):
txn.execute(sql % (clause,), args) txn.execute(sql % (clause,), args)
return set(row[0] for row in txn) return {row[0] for row in txn}
return await self.db.runInteraction( return await self.db.runInteraction(
"get_users_server_still_shares_room_with", "get_users_server_still_shares_room_with",
@ -826,7 +826,7 @@ class RoomMemberWorkerStore(EventsWorkerStore):
GROUP BY room_id, user_id; GROUP BY room_id, user_id;
""" """
txn.execute(sql, (user_id,)) txn.execute(sql, (user_id,))
return set(row[0] for row in txn if row[1] == 0) return {row[0] for row in txn if row[1] == 0}
return self.db.runInteraction( return self.db.runInteraction(
"get_forgotten_rooms_for_user", _get_forgotten_rooms_for_user_txn "get_forgotten_rooms_for_user", _get_forgotten_rooms_for_user_txn

View File

@ -321,7 +321,7 @@ class StateGroupWorkerStore(EventsWorkerStore, SQLBaseStore):
desc="get_referenced_state_groups", desc="get_referenced_state_groups",
) )
return set(row["state_group"] for row in rows) return {row["state_group"] for row in rows}
class MainStateBackgroundUpdateStore(RoomMemberWorkerStore): class MainStateBackgroundUpdateStore(RoomMemberWorkerStore):
@ -367,7 +367,7 @@ class MainStateBackgroundUpdateStore(RoomMemberWorkerStore):
""" """
txn.execute(sql, (last_room_id, batch_size)) txn.execute(sql, (last_room_id, batch_size))
room_ids = list(row[0] for row in txn) room_ids = [row[0] for row in txn]
if not room_ids: if not room_ids:
return True, set() return True, set()
@ -384,7 +384,7 @@ class MainStateBackgroundUpdateStore(RoomMemberWorkerStore):
txn.execute(sql, (last_room_id, room_ids[-1], "%:" + self.server_name)) txn.execute(sql, (last_room_id, room_ids[-1], "%:" + self.server_name))
joined_room_ids = set(row[0] for row in txn) joined_room_ids = {row[0] for row in txn}
left_rooms = set(room_ids) - joined_room_ids left_rooms = set(room_ids) - joined_room_ids
@ -404,7 +404,7 @@ class MainStateBackgroundUpdateStore(RoomMemberWorkerStore):
retcols=("state_key",), retcols=("state_key",),
) )
potentially_left_users = set(row["state_key"] for row in rows) potentially_left_users = {row["state_key"] for row in rows}
# Now lets actually delete the rooms from the DB. # Now lets actually delete the rooms from the DB.
self.db.simple_delete_many_txn( self.db.simple_delete_many_txn(

View File

@ -346,11 +346,11 @@ class StreamWorkerStore(EventsWorkerStore, SQLBaseStore):
from_key (str): The room_key portion of a StreamToken from_key (str): The room_key portion of a StreamToken
""" """
from_key = RoomStreamToken.parse_stream_token(from_key).stream from_key = RoomStreamToken.parse_stream_token(from_key).stream
return set( return {
room_id room_id
for room_id in room_ids for room_id in room_ids
if self._events_stream_cache.has_entity_changed(room_id, from_key) if self._events_stream_cache.has_entity_changed(room_id, from_key)
) }
@defer.inlineCallbacks @defer.inlineCallbacks
def get_room_events_stream_for_room( def get_room_events_stream_for_room(
@ -679,11 +679,11 @@ class StreamWorkerStore(EventsWorkerStore, SQLBaseStore):
) )
events_before = yield self.get_events_as_list( events_before = yield self.get_events_as_list(
[e for e in results["before"]["event_ids"]], get_prev_content=True list(results["before"]["event_ids"]), get_prev_content=True
) )
events_after = yield self.get_events_as_list( events_after = yield self.get_events_as_list(
[e for e in results["after"]["event_ids"]], get_prev_content=True list(results["after"]["event_ids"]), get_prev_content=True
) )
return { return {

View File

@ -63,9 +63,9 @@ class UserErasureWorkerStore(SQLBaseStore):
retcols=("user_id",), retcols=("user_id",),
desc="are_users_erased", desc="are_users_erased",
) )
erased_users = set(row["user_id"] for row in rows) erased_users = {row["user_id"] for row in rows}
res = dict((u, u in erased_users) for u in user_ids) res = {u: u in erased_users for u in user_ids}
return res return res

View File

@ -520,11 +520,11 @@ class StateGroupDataStore(StateBackgroundUpdateStore, SQLBaseStore):
retcols=("state_group",), retcols=("state_group",),
) )
remaining_state_groups = set( remaining_state_groups = {
row["state_group"] row["state_group"]
for row in rows for row in rows
if row["state_group"] not in state_groups_to_delete if row["state_group"] not in state_groups_to_delete
) }
logger.info( logger.info(
"[purge] de-delta-ing %i remaining state groups", "[purge] de-delta-ing %i remaining state groups",

View File

@ -554,8 +554,8 @@ class Database(object):
Returns: Returns:
A list of dicts where the key is the column header. A list of dicts where the key is the column header.
""" """
col_headers = list(intern(str(column[0])) for column in cursor.description) col_headers = [intern(str(column[0])) for column in cursor.description]
results = list(dict(zip(col_headers, row)) for row in cursor) results = [dict(zip(col_headers, row)) for row in cursor]
return results return results
def execute(self, desc, decoder, query, *args): def execute(self, desc, decoder, query, *args):

View File

@ -602,14 +602,14 @@ class EventsPersistenceStorage(object):
event_id_to_state_group.update(event_to_groups) event_id_to_state_group.update(event_to_groups)
# State groups of old_latest_event_ids # State groups of old_latest_event_ids
old_state_groups = set( old_state_groups = {
event_id_to_state_group[evid] for evid in old_latest_event_ids event_id_to_state_group[evid] for evid in old_latest_event_ids
) }
# State groups of new_latest_event_ids # State groups of new_latest_event_ids
new_state_groups = set( new_state_groups = {
event_id_to_state_group[evid] for evid in new_latest_event_ids event_id_to_state_group[evid] for evid in new_latest_event_ids
) }
# If they old and new groups are the same then we don't need to do # If they old and new groups are the same then we don't need to do
# anything. # anything.

View File

@ -345,9 +345,9 @@ def _upgrade_existing_database(
"Could not open delta dir for version %d: %s" % (v, directory) "Could not open delta dir for version %d: %s" % (v, directory)
) )
duplicates = set( duplicates = {
file_name for file_name, count in file_name_counter.items() if count > 1 file_name for file_name, count in file_name_counter.items() if count > 1
) }
if duplicates: if duplicates:
# We don't support using the same file name in the same delta version. # We don't support using the same file name in the same delta version.
raise PrepareDatabaseException( raise PrepareDatabaseException(
@ -454,7 +454,7 @@ def _apply_module_schema_files(cur, database_engine, modname, names_and_streams)
), ),
(modname,), (modname,),
) )
applied_deltas = set(d for d, in cur) applied_deltas = {d for d, in cur}
for (name, stream) in names_and_streams: for (name, stream) in names_and_streams:
if name in applied_deltas: if name in applied_deltas:
continue continue

View File

@ -30,7 +30,7 @@ def freeze(o):
return o return o
try: try:
return tuple([freeze(i) for i in o]) return tuple(freeze(i) for i in o)
except TypeError: except TypeError:
pass pass

View File

@ -75,7 +75,7 @@ def filter_events_for_client(
""" """
# Filter out events that have been soft failed so that we don't relay them # Filter out events that have been soft failed so that we don't relay them
# to clients. # to clients.
events = list(e for e in events if not e.internal_metadata.is_soft_failed()) events = [e for e in events if not e.internal_metadata.is_soft_failed()]
types = ((EventTypes.RoomHistoryVisibility, ""), (EventTypes.Member, user_id)) types = ((EventTypes.RoomHistoryVisibility, ""), (EventTypes.Member, user_id))
event_id_to_state = yield storage.state.get_state_for_events( event_id_to_state = yield storage.state.get_state_for_events(
@ -97,7 +97,7 @@ def filter_events_for_client(
erased_senders = yield storage.main.are_users_erased((e.sender for e in events)) erased_senders = yield storage.main.are_users_erased((e.sender for e in events))
if apply_retention_policies: if apply_retention_policies:
room_ids = set(e.room_id for e in events) room_ids = {e.room_id for e in events}
retention_policies = {} retention_policies = {}
for room_id in room_ids: for room_id in room_ids:

View File

@ -48,7 +48,7 @@ class ConfigGenerationTestCase(unittest.TestCase):
) )
self.assertSetEqual( self.assertSetEqual(
set(["homeserver.yaml", "lemurs.win.log.config", "lemurs.win.signing.key"]), {"homeserver.yaml", "lemurs.win.log.config", "lemurs.win.signing.key"},
set(os.listdir(self.dir)), set(os.listdir(self.dir)),
) )

View File

@ -83,7 +83,7 @@ class StateQueryTests(unittest.FederatingHomeserverTestCase):
) )
) )
self.assertEqual(members, set(["@user:other.example.com", u1])) self.assertEqual(members, {"@user:other.example.com", u1})
self.assertEqual(len(channel.json_body["pdus"]), 6) self.assertEqual(len(channel.json_body["pdus"]), 6)
def test_needs_to_be_in_room(self): def test_needs_to_be_in_room(self):

View File

@ -338,7 +338,7 @@ class PresenceTimeoutTestCase(unittest.TestCase):
) )
new_state = handle_timeout( new_state = handle_timeout(
state, is_mine=True, syncing_user_ids=set([user_id]), now=now state, is_mine=True, syncing_user_ids={user_id}, now=now
) )
self.assertIsNotNone(new_state) self.assertIsNotNone(new_state)
@ -579,7 +579,7 @@ class PresenceJoinTestCase(unittest.HomeserverTestCase):
) )
self.assertEqual(expected_state.state, PresenceState.ONLINE) self.assertEqual(expected_state.state, PresenceState.ONLINE)
self.federation_sender.send_presence_to_destinations.assert_called_once_with( self.federation_sender.send_presence_to_destinations.assert_called_once_with(
destinations=set(("server2", "server3")), states=[expected_state] destinations={"server2", "server3"}, states=[expected_state]
) )
def _add_new_user(self, room_id, user_id): def _add_new_user(self, room_id, user_id):

View File

@ -129,12 +129,12 @@ class TypingNotificationsTestCase(unittest.HomeserverTestCase):
hs.get_auth().check_user_in_room = check_user_in_room hs.get_auth().check_user_in_room = check_user_in_room
def get_joined_hosts_for_room(room_id): def get_joined_hosts_for_room(room_id):
return set(member.domain for member in self.room_members) return {member.domain for member in self.room_members}
self.datastore.get_joined_hosts_for_room = get_joined_hosts_for_room self.datastore.get_joined_hosts_for_room = get_joined_hosts_for_room
def get_current_users_in_room(room_id): def get_current_users_in_room(room_id):
return set(str(u) for u in self.room_members) return {str(u) for u in self.room_members}
hs.get_state_handler().get_current_users_in_room = get_current_users_in_room hs.get_state_handler().get_current_users_in_room = get_current_users_in_room
@ -257,7 +257,7 @@ class TypingNotificationsTestCase(unittest.HomeserverTestCase):
member = RoomMember(ROOM_ID, U_APPLE.to_string()) member = RoomMember(ROOM_ID, U_APPLE.to_string())
self.handler._member_typing_until[member] = 1002000 self.handler._member_typing_until[member] = 1002000
self.handler._room_typing[ROOM_ID] = set([U_APPLE.to_string()]) self.handler._room_typing[ROOM_ID] = {U_APPLE.to_string()}
self.assertEquals(self.event_source.get_current_key(), 0) self.assertEquals(self.event_source.get_current_key(), 0)

View File

@ -114,7 +114,7 @@ class UserDirectoryTestCase(unittest.HomeserverTestCase):
public_users = self.get_users_in_public_rooms() public_users = self.get_users_in_public_rooms()
self.assertEqual( self.assertEqual(
self._compress_shared(shares_private), set([(u1, u2, room), (u2, u1, room)]) self._compress_shared(shares_private), {(u1, u2, room), (u2, u1, room)}
) )
self.assertEqual(public_users, []) self.assertEqual(public_users, [])
@ -169,7 +169,7 @@ class UserDirectoryTestCase(unittest.HomeserverTestCase):
public_users = self.get_users_in_public_rooms() public_users = self.get_users_in_public_rooms()
self.assertEqual( self.assertEqual(
self._compress_shared(shares_private), set([(u1, u2, room), (u2, u1, room)]) self._compress_shared(shares_private), {(u1, u2, room), (u2, u1, room)}
) )
self.assertEqual(public_users, []) self.assertEqual(public_users, [])
@ -226,7 +226,7 @@ class UserDirectoryTestCase(unittest.HomeserverTestCase):
public_users = self.get_users_in_public_rooms() public_users = self.get_users_in_public_rooms()
self.assertEqual( self.assertEqual(
self._compress_shared(shares_private), set([(u1, u2, room), (u2, u1, room)]) self._compress_shared(shares_private), {(u1, u2, room), (u2, u1, room)}
) )
self.assertEqual(public_users, []) self.assertEqual(public_users, [])
@ -358,12 +358,12 @@ class UserDirectoryTestCase(unittest.HomeserverTestCase):
public_users = self.get_users_in_public_rooms() public_users = self.get_users_in_public_rooms()
# User 1 and User 2 are in the same public room # User 1 and User 2 are in the same public room
self.assertEqual(set(public_users), set([(u1, room), (u2, room)])) self.assertEqual(set(public_users), {(u1, room), (u2, room)})
# User 1 and User 3 share private rooms # User 1 and User 3 share private rooms
self.assertEqual( self.assertEqual(
self._compress_shared(shares_private), self._compress_shared(shares_private),
set([(u1, u3, private_room), (u3, u1, private_room)]), {(u1, u3, private_room), (u3, u1, private_room)},
) )
def test_initial_share_all_users(self): def test_initial_share_all_users(self):
@ -398,7 +398,7 @@ class UserDirectoryTestCase(unittest.HomeserverTestCase):
# No users share rooms # No users share rooms
self.assertEqual(public_users, []) self.assertEqual(public_users, [])
self.assertEqual(self._compress_shared(shares_private), set([])) self.assertEqual(self._compress_shared(shares_private), set())
# Despite not sharing a room, search_all_users means we get a search # Despite not sharing a room, search_all_users means we get a search
# result. # result.

View File

@ -163,7 +163,7 @@ class EmailPusherTests(HomeserverTestCase):
# Get the stream ordering before it gets sent # Get the stream ordering before it gets sent
pushers = self.get_success( pushers = self.get_success(
self.hs.get_datastore().get_pushers_by(dict(user_name=self.user_id)) self.hs.get_datastore().get_pushers_by({"user_name": self.user_id})
) )
pushers = list(pushers) pushers = list(pushers)
self.assertEqual(len(pushers), 1) self.assertEqual(len(pushers), 1)
@ -174,7 +174,7 @@ class EmailPusherTests(HomeserverTestCase):
# It hasn't succeeded yet, so the stream ordering shouldn't have moved # It hasn't succeeded yet, so the stream ordering shouldn't have moved
pushers = self.get_success( pushers = self.get_success(
self.hs.get_datastore().get_pushers_by(dict(user_name=self.user_id)) self.hs.get_datastore().get_pushers_by({"user_name": self.user_id})
) )
pushers = list(pushers) pushers = list(pushers)
self.assertEqual(len(pushers), 1) self.assertEqual(len(pushers), 1)
@ -192,7 +192,7 @@ class EmailPusherTests(HomeserverTestCase):
# The stream ordering has increased # The stream ordering has increased
pushers = self.get_success( pushers = self.get_success(
self.hs.get_datastore().get_pushers_by(dict(user_name=self.user_id)) self.hs.get_datastore().get_pushers_by({"user_name": self.user_id})
) )
pushers = list(pushers) pushers = list(pushers)
self.assertEqual(len(pushers), 1) self.assertEqual(len(pushers), 1)

View File

@ -102,7 +102,7 @@ class HTTPPusherTests(HomeserverTestCase):
# Get the stream ordering before it gets sent # Get the stream ordering before it gets sent
pushers = self.get_success( pushers = self.get_success(
self.hs.get_datastore().get_pushers_by(dict(user_name=user_id)) self.hs.get_datastore().get_pushers_by({"user_name": user_id})
) )
pushers = list(pushers) pushers = list(pushers)
self.assertEqual(len(pushers), 1) self.assertEqual(len(pushers), 1)
@ -113,7 +113,7 @@ class HTTPPusherTests(HomeserverTestCase):
# It hasn't succeeded yet, so the stream ordering shouldn't have moved # It hasn't succeeded yet, so the stream ordering shouldn't have moved
pushers = self.get_success( pushers = self.get_success(
self.hs.get_datastore().get_pushers_by(dict(user_name=user_id)) self.hs.get_datastore().get_pushers_by({"user_name": user_id})
) )
pushers = list(pushers) pushers = list(pushers)
self.assertEqual(len(pushers), 1) self.assertEqual(len(pushers), 1)
@ -132,7 +132,7 @@ class HTTPPusherTests(HomeserverTestCase):
# The stream ordering has increased # The stream ordering has increased
pushers = self.get_success( pushers = self.get_success(
self.hs.get_datastore().get_pushers_by(dict(user_name=user_id)) self.hs.get_datastore().get_pushers_by({"user_name": user_id})
) )
pushers = list(pushers) pushers = list(pushers)
self.assertEqual(len(pushers), 1) self.assertEqual(len(pushers), 1)
@ -152,7 +152,7 @@ class HTTPPusherTests(HomeserverTestCase):
# The stream ordering has increased, again # The stream ordering has increased, again
pushers = self.get_success( pushers = self.get_success(
self.hs.get_datastore().get_pushers_by(dict(user_name=user_id)) self.hs.get_datastore().get_pushers_by({"user_name": user_id})
) )
pushers = list(pushers) pushers = list(pushers)
self.assertEqual(len(pushers), 1) self.assertEqual(len(pushers), 1)

View File

@ -40,16 +40,14 @@ class FilterTestCase(unittest.HomeserverTestCase):
self.assertEqual(channel.code, 200) self.assertEqual(channel.code, 200)
self.assertTrue( self.assertTrue(
set( {
[
"next_batch", "next_batch",
"rooms", "rooms",
"presence", "presence",
"account_data", "account_data",
"to_device", "to_device",
"device_lists", "device_lists",
] }.issubset(set(channel.json_body.keys()))
).issubset(set(channel.json_body.keys()))
) )
def test_sync_presence_disabled(self): def test_sync_presence_disabled(self):
@ -63,9 +61,13 @@ class FilterTestCase(unittest.HomeserverTestCase):
self.assertEqual(channel.code, 200) self.assertEqual(channel.code, 200)
self.assertTrue( self.assertTrue(
set( {
["next_batch", "rooms", "account_data", "to_device", "device_lists"] "next_batch",
).issubset(set(channel.json_body.keys())) "rooms",
"account_data",
"to_device",
"device_lists",
}.issubset(set(channel.json_body.keys()))
) )

View File

@ -373,7 +373,7 @@ class UpsertManyTests(unittest.HomeserverTestCase):
) )
self.assertEqual( self.assertEqual(
set(self._dump_to_tuple(res)), set(self._dump_to_tuple(res)),
set([(1, "user1", "hello"), (2, "user2", "there")]), {(1, "user1", "hello"), (2, "user2", "there")},
) )
# Update only user2 # Update only user2
@ -400,5 +400,5 @@ class UpsertManyTests(unittest.HomeserverTestCase):
) )
self.assertEqual( self.assertEqual(
set(self._dump_to_tuple(res)), set(self._dump_to_tuple(res)),
set([(1, "user1", "hello"), (2, "user2", "bleb")]), {(1, "user1", "hello"), (2, "user2", "bleb")},
) )

View File

@ -69,14 +69,14 @@ class ApplicationServiceStoreTestCase(unittest.TestCase):
pass pass
def _add_appservice(self, as_token, id, url, hs_token, sender): def _add_appservice(self, as_token, id, url, hs_token, sender):
as_yaml = dict( as_yaml = {
url=url, "url": url,
as_token=as_token, "as_token": as_token,
hs_token=hs_token, "hs_token": hs_token,
id=id, "id": id,
sender_localpart=sender, "sender_localpart": sender,
namespaces={}, "namespaces": {},
) }
# use the token as the filename # use the token as the filename
with open(as_token, "w") as outfile: with open(as_token, "w") as outfile:
outfile.write(yaml.dump(as_yaml)) outfile.write(yaml.dump(as_yaml))
@ -135,14 +135,14 @@ class ApplicationServiceTransactionStoreTestCase(unittest.TestCase):
) )
def _add_service(self, url, as_token, id): def _add_service(self, url, as_token, id):
as_yaml = dict( as_yaml = {
url=url, "url": url,
as_token=as_token, "as_token": as_token,
hs_token="something", "hs_token": "something",
id=id, "id": id,
sender_localpart="a_sender", "sender_localpart": "a_sender",
namespaces={}, "namespaces": {},
) }
# use the token as the filename # use the token as the filename
with open(as_token, "w") as outfile: with open(as_token, "w") as outfile:
outfile.write(yaml.dump(as_yaml)) outfile.write(yaml.dump(as_yaml))
@ -384,8 +384,8 @@ class ApplicationServiceTransactionStoreTestCase(unittest.TestCase):
) )
self.assertEquals(2, len(services)) self.assertEquals(2, len(services))
self.assertEquals( self.assertEquals(
set([self.as_list[2]["id"], self.as_list[0]["id"]]), {self.as_list[2]["id"], self.as_list[0]["id"]},
set([services[0].id, services[1].id]), {services[0].id, services[1].id},
) )

View File

@ -134,7 +134,7 @@ class CleanupExtremBackgroundUpdateStoreTestCase(HomeserverTestCase):
latest_event_ids = self.get_success( latest_event_ids = self.get_success(
self.store.get_latest_event_ids_in_room(self.room_id) self.store.get_latest_event_ids_in_room(self.room_id)
) )
self.assertEqual(set(latest_event_ids), set((event_id_a, event_id_b))) self.assertEqual(set(latest_event_ids), {event_id_a, event_id_b})
# Run the background update and check it did the right thing # Run the background update and check it did the right thing
self.run_background_update() self.run_background_update()
@ -172,7 +172,7 @@ class CleanupExtremBackgroundUpdateStoreTestCase(HomeserverTestCase):
latest_event_ids = self.get_success( latest_event_ids = self.get_success(
self.store.get_latest_event_ids_in_room(self.room_id) self.store.get_latest_event_ids_in_room(self.room_id)
) )
self.assertEqual(set(latest_event_ids), set((event_id_a, event_id_b))) self.assertEqual(set(latest_event_ids), {event_id_a, event_id_b})
# Run the background update and check it did the right thing # Run the background update and check it did the right thing
self.run_background_update() self.run_background_update()
@ -227,9 +227,7 @@ class CleanupExtremBackgroundUpdateStoreTestCase(HomeserverTestCase):
latest_event_ids = self.get_success( latest_event_ids = self.get_success(
self.store.get_latest_event_ids_in_room(self.room_id) self.store.get_latest_event_ids_in_room(self.room_id)
) )
self.assertEqual( self.assertEqual(set(latest_event_ids), {event_id_a, event_id_b, event_id_c})
set(latest_event_ids), set((event_id_a, event_id_b, event_id_c))
)
# Run the background update and check it did the right thing # Run the background update and check it did the right thing
self.run_background_update() self.run_background_update()
@ -237,7 +235,7 @@ class CleanupExtremBackgroundUpdateStoreTestCase(HomeserverTestCase):
latest_event_ids = self.get_success( latest_event_ids = self.get_success(
self.store.get_latest_event_ids_in_room(self.room_id) self.store.get_latest_event_ids_in_room(self.room_id)
) )
self.assertEqual(set(latest_event_ids), set([event_id_b, event_id_c])) self.assertEqual(set(latest_event_ids), {event_id_b, event_id_c})
class CleanupExtremDummyEventsTestCase(HomeserverTestCase): class CleanupExtremDummyEventsTestCase(HomeserverTestCase):

View File

@ -59,8 +59,7 @@ class ExtremStatisticsTestCase(HomeserverTestCase):
) )
) )
expected = set( expected = {
[
b'synapse_forward_extremities_bucket{le="1.0"} 0.0', b'synapse_forward_extremities_bucket{le="1.0"} 0.0',
b'synapse_forward_extremities_bucket{le="2.0"} 2.0', b'synapse_forward_extremities_bucket{le="2.0"} 2.0',
b'synapse_forward_extremities_bucket{le="3.0"} 2.0', b'synapse_forward_extremities_bucket{le="3.0"} 2.0',
@ -76,7 +75,6 @@ class ExtremStatisticsTestCase(HomeserverTestCase):
b'synapse_forward_extremities_bucket{le="+Inf"} 3.0', b'synapse_forward_extremities_bucket{le="+Inf"} 3.0',
b"synapse_forward_extremities_count 3.0", b"synapse_forward_extremities_count 3.0",
b"synapse_forward_extremities_sum 10.0", b"synapse_forward_extremities_sum 10.0",
] }
)
self.assertEqual(items, expected) self.assertEqual(items, expected)

View File

@ -394,7 +394,7 @@ class StateStoreTestCase(tests.unittest.TestCase):
) = self.state_datastore._state_group_cache.get(group) ) = self.state_datastore._state_group_cache.get(group)
self.assertEqual(is_all, False) self.assertEqual(is_all, False)
self.assertEqual(known_absent, set([(e1.type, e1.state_key)])) self.assertEqual(known_absent, {(e1.type, e1.state_key)})
self.assertDictEqual(state_dict_ids, {(e1.type, e1.state_key): e1.event_id}) self.assertDictEqual(state_dict_ids, {(e1.type, e1.state_key): e1.event_id})
############################################ ############################################

View File

@ -254,9 +254,7 @@ class StateTestCase(unittest.TestCase):
ctx_d = context_store["D"] ctx_d = context_store["D"]
prev_state_ids = yield ctx_d.get_prev_state_ids() prev_state_ids = yield ctx_d.get_prev_state_ids()
self.assertSetEqual( self.assertSetEqual({"START", "A", "C"}, set(prev_state_ids.values()))
{"START", "A", "C"}, {e_id for e_id in prev_state_ids.values()}
)
self.assertEqual(ctx_c.state_group, ctx_d.state_group_before_event) self.assertEqual(ctx_c.state_group, ctx_d.state_group_before_event)
self.assertEqual(ctx_d.state_group_before_event, ctx_d.state_group) self.assertEqual(ctx_d.state_group_before_event, ctx_d.state_group)
@ -313,9 +311,7 @@ class StateTestCase(unittest.TestCase):
ctx_e = context_store["E"] ctx_e = context_store["E"]
prev_state_ids = yield ctx_e.get_prev_state_ids() prev_state_ids = yield ctx_e.get_prev_state_ids()
self.assertSetEqual( self.assertSetEqual({"START", "A", "B", "C"}, set(prev_state_ids.values()))
{"START", "A", "B", "C"}, {e for e in prev_state_ids.values()}
)
self.assertEqual(ctx_c.state_group, ctx_e.state_group_before_event) self.assertEqual(ctx_c.state_group, ctx_e.state_group_before_event)
self.assertEqual(ctx_e.state_group_before_event, ctx_e.state_group) self.assertEqual(ctx_e.state_group_before_event, ctx_e.state_group)
@ -388,9 +384,7 @@ class StateTestCase(unittest.TestCase):
ctx_d = context_store["D"] ctx_d = context_store["D"]
prev_state_ids = yield ctx_d.get_prev_state_ids() prev_state_ids = yield ctx_d.get_prev_state_ids()
self.assertSetEqual( self.assertSetEqual({"A1", "A2", "A3", "A5", "B"}, set(prev_state_ids.values()))
{"A1", "A2", "A3", "A5", "B"}, {e for e in prev_state_ids.values()}
)
self.assertEqual(ctx_b.state_group, ctx_d.state_group_before_event) self.assertEqual(ctx_b.state_group, ctx_d.state_group_before_event)
self.assertEqual(ctx_d.state_group_before_event, ctx_d.state_group) self.assertEqual(ctx_d.state_group_before_event, ctx_d.state_group)
@ -482,7 +476,7 @@ class StateTestCase(unittest.TestCase):
current_state_ids = yield context.get_current_state_ids() current_state_ids = yield context.get_current_state_ids()
self.assertEqual( self.assertEqual(
set([e.event_id for e in old_state]), set(current_state_ids.values()) {e.event_id for e in old_state}, set(current_state_ids.values())
) )
self.assertEqual(group_name, context.state_group) self.assertEqual(group_name, context.state_group)
@ -513,9 +507,7 @@ class StateTestCase(unittest.TestCase):
prev_state_ids = yield context.get_prev_state_ids() prev_state_ids = yield context.get_prev_state_ids()
self.assertEqual( self.assertEqual({e.event_id for e in old_state}, set(prev_state_ids.values()))
set([e.event_id for e in old_state]), set(prev_state_ids.values())
)
self.assertIsNotNone(context.state_group) self.assertIsNotNone(context.state_group)

View File

@ -67,7 +67,7 @@ class StreamChangeCacheTests(unittest.TestCase):
# If we update an existing entity, it keeps the two existing entities # If we update an existing entity, it keeps the two existing entities
cache.entity_has_changed("bar@baz.net", 5) cache.entity_has_changed("bar@baz.net", 5)
self.assertEqual( self.assertEqual(
set(["bar@baz.net", "user@elsewhere.org"]), set(cache._entity_to_key) {"bar@baz.net", "user@elsewhere.org"}, set(cache._entity_to_key)
) )
def test_get_all_entities_changed(self): def test_get_all_entities_changed(self):
@ -137,7 +137,7 @@ class StreamChangeCacheTests(unittest.TestCase):
cache.get_entities_changed( cache.get_entities_changed(
["user@foo.com", "bar@baz.net", "user@elsewhere.org"], stream_pos=2 ["user@foo.com", "bar@baz.net", "user@elsewhere.org"], stream_pos=2
), ),
set(["bar@baz.net", "user@elsewhere.org"]), {"bar@baz.net", "user@elsewhere.org"},
) )
# Query all the entries mid-way through the stream, but include one # Query all the entries mid-way through the stream, but include one
@ -153,7 +153,7 @@ class StreamChangeCacheTests(unittest.TestCase):
], ],
stream_pos=2, stream_pos=2,
), ),
set(["bar@baz.net", "user@elsewhere.org"]), {"bar@baz.net", "user@elsewhere.org"},
) )
# Query all the entries, but before the first known point. We will get # Query all the entries, but before the first known point. We will get
@ -168,21 +168,13 @@ class StreamChangeCacheTests(unittest.TestCase):
], ],
stream_pos=0, stream_pos=0,
), ),
set( {"user@foo.com", "bar@baz.net", "user@elsewhere.org", "not@here.website"},
[
"user@foo.com",
"bar@baz.net",
"user@elsewhere.org",
"not@here.website",
]
),
) )
# Query a subset of the entries mid-way through the stream. We should # Query a subset of the entries mid-way through the stream. We should
# only get back the subset. # only get back the subset.
self.assertEqual( self.assertEqual(
cache.get_entities_changed(["bar@baz.net"], stream_pos=2), cache.get_entities_changed(["bar@baz.net"], stream_pos=2), {"bar@baz.net"},
set(["bar@baz.net"]),
) )
def test_max_pos(self): def test_max_pos(self):

View File

@ -123,6 +123,7 @@ skip_install = True
basepython = python3.6 basepython = python3.6
deps = deps =
flake8 flake8
flake8-comprehensions
black==19.10b0 # We pin so that our tests don't start failing on new releases of black. black==19.10b0 # We pin so that our tests don't start failing on new releases of black.
commands = commands =
python -m black --check --diff . python -m black --check --diff .