-
-
Notifications
You must be signed in to change notification settings - Fork 2.1k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
The roomlist requires an extra message to reorder & highlight in encrypted rooms since 1.10.x #20859
Comments
I've been seeing this too. I'm unsure what semantics cause a room to behave this way, and visiting the room does not appear to fix it. Below is what I've managed to find so far. I've had it happen in unencrypted rooms too, though at less frequency. It can affect multiple rooms at a time. The room list does reorder to accept the message when using importance ordering, but in the idle rooms section. Read markers and/or receipts are not sent in the background either (thus doesn't appear to be a store losing state). If the message is a mention, a notification noise is played despite not appearing as such. Unsure on desktop notifications - those are disabled on my machine. It can happen in web or desktop. This started happening this week on nightly. Neither us or synapse have seemingly made changes in the area. I'm the only user on my homeserver. Things yet to check are:
Unfortunately I haven't seen any logging on web or synapse to indicate a problem. |
Just for more added context:
|
I can't get subsequent messages to be reliable in the rooms, but I have found that space hopping appears to kick things into working for some reason. It can take a few hops before rooms start to appear as unread. |
I don't think I can reproduce this issue either. However I was chatting about the problem with James earlier today and I believe some of the changes in https://github.com/matrix-org/matrix-js-sdk/pull/2132/files could have cause some disturbance here. |
@gsouquet that looks quite plausible. Is the way to test it to disable threading in labs and see if it helps? |
You definitely can do that. But I'm afraid that because I made some of those functions Regardless I will be playing around with that area and attempt to make it all synchronous as it used to be |
I don't think it's feasible to downgrade web or nightly like that, unfortunately. |
I'm taking Cannot Reproduce off of this because it's being encountered daily by people (many of which don't realize it until it's too late) |
from my debugging a week ago: If you have importance ordering (room list ordered by activity and "unread messages first" ticked), then the following can be used to identify problematic rooms: (function () {
// Assuming you're using Importance ordering on the tag
const alg = mxRoomListStore.algorithm.algorithms["im.vector.fake.recent"];
//const categorized = alg.categorizeRooms(mxMatrixClientPeg.get().getVisibleRooms());
const categorized = alg.categorizeRooms(mxRoomListStore.orderedLists["im.vector.fake.recent"]);
const unsent = categorized[4];
const red = categorized[3];
const grey = categorized[2];
const bold = categorized[1];
const none = categorized[0];
for (const room of unsent) {
if (room.getPendingEvents() <= 0) {
console.error(`@@ Failed: ${room.roomId} is UNSENT with no pending events`);
}
}
for (const room of red) {
if (room.getUnreadNotificationCount('highlight') <= 0) {
console.error(`@@ Failed: ${room.roomId} is RED with no highlted events`);
}
}
for (const room of grey) {
if (room.getUnreadNotificationCount('total') <= 0) {
console.error(`@@ Failed: ${room.roomId} is GREY with no events`);
}
}
const myUserId = mxMatrixClientPeg.get().getUserId();
for (const room of bold) {
const readUpTo = room.getEventReadUpTo(myUserId);
const lastEvent = room.timeline[room.timeline.length - 1];
if (lastEvent.getSender() == myUserId) continue;
// flip through the last events in the room
let found = false;
for (let i = room.timeline.length - 1; i >= 0; --i) {
const ev = room.timeline[i];
if (ev.getId() == readUpTo) {
found = true;
break;
} else if (ev.getType() === 'm.room.message' && !ev.isRelation('m.replace')) {
break;
}
}
if (found) {
console.error(`@@ Failed: ${room.roomId} is BOLD with no events`);
}
}
for (const room of none) {
const readUpTo = room.getEventReadUpTo(myUserId);
const lastEvent = room.timeline[room.timeline.length - 1];
if (lastEvent.getSender() == myUserId) continue;
// flip through the last events in the room
let found = false;
for (let i = room.timeline.length - 1; i >= 0; --i) {
const ev = room.timeline[i];
if (ev.getId() == readUpTo) {
found = true;
break;
} else if (ev.getType() === 'm.room.message' && !ev.isRelation('m.replace')) {
break;
}
}
if (!found) {
console.error(`@@ Failed: ${room.roomId} is IDLE with unread events`);
}
}
})(); It's not perfect and doesn't handle a ton of edge cases, but it's good enough to inspect the room IDs it spat out and see if it was encountering issues. One notable edge case is that membership/state events sent to the room which would not normally cause unread badges can cause the script to complain about that room (these rooms are irrelevant to the issue at hand - look for message events which cause problems). This doesn't really point to a cause yet, but it at least indicates that the notification state classes are holding the wrong value for the room, for some reason. |
I marked it as It is marked as |
I've also been seeing similar symptoms, though immediately reading this I can't say if it is only encrypted or also unencrypted rooms - though reading above that doesn't seem to be a defining factor for everyone. To me, it feels like rooms are ordered correctly as I've set them (ie based on activity). But the room just shows as "read" when I haven't actually read the room (which is also visible by going to the room and seeing my read counter above the latest message which should have marked the room unread for me. Whether a second message fixes the room status I can't say from my experience. I did a rageshake earlier for this: https://github.com/matrix-org/element-web-rageshakes/issues/10774 |
I can now reproduce this for threaded replies, but not for non-threaded:
This was trying to exercise this code path: https://github.com/matrix-org/matrix-js-sdk/pull/2132/files#diff-1b0cb46cd1fcdaacf73c771bf7eed6e00a12ee030da1dbcca4ae12842e1ecd81R1310 so would suggest there might a bug (race?) there. No idea how this could cause the issue for non-threaded replies though. |
@dbkr would that path be exercised on clients with threads disabled too? Something that's been troubling is that there's a lot of red flags in the threads paths, but with threads disabled they shouldn't be called (yet the issue persists) |
No, that shouldn't be called at all if threads are disabled |
I've just found a much simpler repro case for this bug, or at least some variant of it: [steps 1-3 as previous, except room 1 must be encrypted] |
Bingo. I think this was caused by matrix-org/matrix-react-sdk#7635 - specifically https://github.com/matrix-org/matrix-react-sdk/pull/7635/files#diff-9253e0a966fcccd855eb6ad3a2e0d1257b6d8e479f34fefbadaf4778c4b972aeR74 which adds a second 'room' argument to the handler, but the handler is also used for |
I'm removing the cannot-repro label now since we have a concrete repro case. However, this is only for encrypted rooms and there are reports of this happening for unencrypted room too. Since the original report was specific to encrypted rooms, I'm going to consider this to be that bug and we can open other issues as necessary. |
Fixes element-hq/element-web#20859 More detail on the issue
* Fix delayed badge update for mentions in encrypted rooms Fixes element-hq/element-web#20859 More detail on the issue * Remove unused import * Fix listener removal
Regression test for element-hq/element-web#20859
Regression test for element-hq/element-web#20859
* Fix delayed badge update for mentions in encrypted rooms Fixes element-hq/element-web#20859 More detail on the issue * Remove unused import * Fix listener removal
* Fix delayed badge update for mentions in encrypted rooms Fixes element-hq/element-web#20859 More detail on the issue * Remove unused import * Fix listener removal
Steps to reproduce
Outcome
What did you expect?
Unread messages in encrypted rooms cause the room to be reordered & highlighted as appropriate in the roomlist immediately
What happened instead?
Message previews for the room update, but the room is not reordered and not highlighted in the roomlist until a further message is sent.
Operating system
Ubuntu Linux
Application version
1.10.1
How did you install the app?
Debian
Homeserver
banzan.uk
Will you send logs?
Yes
The text was updated successfully, but these errors were encountered: