From 232391c6b262f759f7422764dc2fc58f2d345094 Mon Sep 17 00:00:00 2001 From: Benjamin Bouvier Date: Thu, 14 Nov 2024 17:14:40 +0100 Subject: [PATCH] task(send queue): move some assertions back to logged errors Better safe than panicky. --- crates/matrix-sdk/src/send_queue.rs | 35 ++++++++++++++++++----------- 1 file changed, 22 insertions(+), 13 deletions(-) diff --git a/crates/matrix-sdk/src/send_queue.rs b/crates/matrix-sdk/src/send_queue.rs index 9f7befe4df5..b8a77ca8f05 100644 --- a/crates/matrix-sdk/src/send_queue.rs +++ b/crates/matrix-sdk/src/send_queue.rs @@ -958,7 +958,13 @@ impl QueueStorage { transaction_id: request.transaction_id.clone(), cancel_upload: cancel_upload_tx, }); - assert!(prev.is_none()); + + if let Some(prev) = prev { + error!( + prev_txn = ?prev.transaction_id, + "a previous request was still active while picking a new one" + ); + } Ok(Some((request.clone(), cancel_upload_rx))) } else { @@ -971,10 +977,11 @@ impl QueueStorage { /// be removed from the queue later. async fn mark_as_not_being_sent(&self, transaction_id: &TransactionId) { let was_being_sent = self.being_sent.write().await.take(); - assert_eq!( - was_being_sent.as_ref().map(|info| info.transaction_id.as_ref()), - Some(transaction_id) - ); + + let prev_txn = was_being_sent.as_ref().map(|info| info.transaction_id.as_ref()); + if prev_txn != Some(transaction_id) { + error!(prev_txn = ?prev_txn, "previous active request didn't match that we expect (after transient error)"); + } } /// Marks a request popped with [`Self::peek_next_to_send`] and identified @@ -988,10 +995,11 @@ impl QueueStorage { // Keep the lock until we're done touching the storage. let mut being_sent = self.being_sent.write().await; let was_being_sent = being_sent.take(); - assert_eq!( - was_being_sent.as_ref().map(|info| info.transaction_id.as_ref()), - Some(transaction_id) - ); + + let prev_txn = was_being_sent.as_ref().map(|info| info.transaction_id.as_ref()); + if prev_txn != Some(transaction_id) { + error!(prev_txn = ?prev_txn, "previous active request didn't match that we expect (after permanent error)"); + } Ok(self .client()? @@ -1023,10 +1031,11 @@ impl QueueStorage { // Keep the lock until we're done touching the storage. let mut being_sent = self.being_sent.write().await; let was_being_sent = being_sent.take(); - assert_eq!( - was_being_sent.as_ref().map(|info| info.transaction_id.as_ref()), - Some(transaction_id) - ); + + let prev_txn = was_being_sent.as_ref().map(|info| info.transaction_id.as_ref()); + if prev_txn != Some(transaction_id) { + error!(prev_txn = ?prev_txn, "previous active request didn't match that we expect (after successful send"); + } let client = self.client()?; let store = client.store();