Skip to content
This repository has been archived by the owner on Apr 26, 2024. It is now read-only.

Commit

Permalink
Merge pull request #4798 from matrix-org/rav/rr_debug
Browse files Browse the repository at this point in the history
Add some debug about processing read receipts.
  • Loading branch information
richvdh authored Mar 4, 2019
2 parents cd7110c + 2db49ea commit 48583ce
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 6 deletions.
1 change: 1 addition & 0 deletions changelog.d/4798.misc
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Add some debug about processing read receipts.
26 changes: 20 additions & 6 deletions synapse/storage/receipts.py
Original file line number Diff line number Diff line change
Expand Up @@ -346,15 +346,23 @@ def get_max_receipt_stream_id(self):

def insert_linearized_receipt_txn(self, txn, room_id, receipt_type,
user_id, event_id, data, stream_id):
"""Inserts a read-receipt into the database if it's newer than the current RR
Returns: int|None
None if the RR is older than the current RR
otherwise, the rx timestamp of the event that the RR corresponds to
(or 0 if the event is unknown)
"""
res = self._simple_select_one_txn(
txn,
table="events",
retcols=["topological_ordering", "stream_ordering"],
retcols=["stream_ordering", "received_ts"],
keyvalues={"event_id": event_id},
allow_none=True
)

stream_ordering = int(res["stream_ordering"]) if res else None
rx_ts = res["received_ts"] if res else 0

# We don't want to clobber receipts for more recent events, so we
# have to compare orderings of existing receipts
Expand All @@ -373,7 +381,7 @@ def insert_linearized_receipt_txn(self, txn, room_id, receipt_type,
"one for later event %s",
event_id, eid,
)
return False
return None

txn.call_after(
self.get_receipts_for_room.invalidate, (room_id, receipt_type)
Expand Down Expand Up @@ -429,7 +437,7 @@ def insert_linearized_receipt_txn(self, txn, room_id, receipt_type,
stream_ordering=stream_ordering,
)

return True
return rx_ts

@defer.inlineCallbacks
def insert_receipt(self, room_id, receipt_type, user_id, event_ids, data):
Expand Down Expand Up @@ -466,16 +474,22 @@ def graph_to_linear(txn):

stream_id_manager = self._receipts_id_gen.get_next()
with stream_id_manager as stream_id:
have_persisted = yield self.runInteraction(
event_ts = yield self.runInteraction(
"insert_linearized_receipt",
self.insert_linearized_receipt_txn,
room_id, receipt_type, user_id, linearized_event_id,
data,
stream_id=stream_id,
)

if not have_persisted:
defer.returnValue(None)
if event_ts is None:
defer.returnValue(None)

now = self._clock.time_msec()
logger.debug(
"RR for event %s in %s (%i ms old)",
linearized_event_id, room_id, now - event_ts,
)

yield self.insert_graph_receipt(
room_id, receipt_type, user_id, event_ids, data
Expand Down

0 comments on commit 48583ce

Please sign in to comment.