Cypress tests for read receipts, threaded and unthreaded (#10872)
parent
f758cbd38a
commit
415fcde5e8
|
@ -36,15 +36,39 @@ describe("Read receipts", () => {
|
|||
return cy.botSendMessage(bot, otherRoomId, "Message");
|
||||
};
|
||||
|
||||
const fakeEventFromSent = (eventResponse: ISendEventResponse): MatrixEvent => {
|
||||
const botSendThreadMessage = (threadId: string): Cypress.Chainable<ISendEventResponse> => {
|
||||
return cy.botSendThreadMessage(bot, otherRoomId, threadId, "Message");
|
||||
};
|
||||
|
||||
const fakeEventFromSent = (eventResponse: ISendEventResponse, threadRootId: string | undefined): MatrixEvent => {
|
||||
return {
|
||||
getRoomId: () => otherRoomId,
|
||||
getId: () => eventResponse.event_id,
|
||||
threadRootId: undefined,
|
||||
threadRootId,
|
||||
getTs: () => 1,
|
||||
} as any as MatrixEvent;
|
||||
};
|
||||
|
||||
/**
|
||||
* Send a threaded receipt marking the message referred to in
|
||||
* eventResponse as read. If threadRootEventResponse is supplied, the
|
||||
* receipt will have its event_id as the thread root ID for the receipt.
|
||||
*/
|
||||
const sendThreadedReadReceipt = (
|
||||
eventResponse: ISendEventResponse,
|
||||
threadRootEventResponse: ISendEventResponse = undefined,
|
||||
) => {
|
||||
cy.sendReadReceipt(fakeEventFromSent(eventResponse, threadRootEventResponse?.event_id));
|
||||
};
|
||||
|
||||
/**
|
||||
* Send an unthreaded receipt marking the message referred to in
|
||||
* eventResponse as read.
|
||||
*/
|
||||
const sendUnthreadedReadReceipt = (eventResponse: ISendEventResponse) => {
|
||||
cy.sendReadReceipt(fakeEventFromSent(eventResponse, undefined), "m.read" as any as ReceiptType, true);
|
||||
};
|
||||
|
||||
beforeEach(() => {
|
||||
/*
|
||||
* Create 2 rooms:
|
||||
|
@ -88,7 +112,7 @@ describe("Read receipts", () => {
|
|||
});
|
||||
|
||||
it(
|
||||
"Considers room read if there's a receipt for main even if an earlier unthreaded receipt exists #24629",
|
||||
"With sync accumulator, considers main thread and unthreaded receipts #24629",
|
||||
{
|
||||
// When #24629 exists, the test fails the first time but passes later, so we disable retries
|
||||
// to be sure we are going to fail if the bug comes back.
|
||||
|
@ -108,8 +132,8 @@ describe("Read receipts", () => {
|
|||
|
||||
// When we send a threaded receipt for the last event in main
|
||||
// And an unthreaded receipt for an earlier event
|
||||
cy.sendReadReceipt(fakeEventFromSent(main3));
|
||||
cy.sendReadReceipt(fakeEventFromSent(main2), "m.read" as any as ReceiptType, true);
|
||||
sendThreadedReadReceipt(main3);
|
||||
sendUnthreadedReadReceipt(main2);
|
||||
|
||||
// (So the room has no unreads)
|
||||
cy.findByLabelText(`${otherRoomName}`).should("exist");
|
||||
|
@ -130,4 +154,118 @@ describe("Read receipts", () => {
|
|||
});
|
||||
},
|
||||
);
|
||||
|
||||
it("Recognises unread messages on main thread after receiving a receipt for earlier ones", () => {
|
||||
// Given we sent 3 events on the main thread
|
||||
botSendMessage();
|
||||
botSendMessage().then((main2) => {
|
||||
botSendMessage().then(() => {
|
||||
// (The room starts off unread)
|
||||
cy.findByLabelText(`${otherRoomName} 3 unread messages.`).should("exist");
|
||||
|
||||
// When we send a threaded receipt for the second-last event in main
|
||||
sendThreadedReadReceipt(main2);
|
||||
|
||||
// Then the room has only one unread
|
||||
cy.findByLabelText(`${otherRoomName} 1 unread message.`).should("exist");
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
it("Considers room read if there is only a main thread and we have a main receipt", () => {
|
||||
// Given we sent 3 events on the main thread
|
||||
botSendMessage();
|
||||
botSendMessage().then(() => {
|
||||
botSendMessage().then((main3) => {
|
||||
// (The room starts off unread)
|
||||
cy.findByLabelText(`${otherRoomName} 3 unread messages.`).should("exist");
|
||||
|
||||
// When we send a threaded receipt for the last event in main
|
||||
sendThreadedReadReceipt(main3);
|
||||
|
||||
// Then the room has no unreads
|
||||
cy.findByLabelText(`${otherRoomName}`).should("exist");
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
it("Recognises unread messages on other thread after receiving a receipt for earlier ones", () => {
|
||||
// Given we sent 3 events on the main thread
|
||||
botSendMessage().then((main1) => {
|
||||
botSendThreadMessage(main1.event_id).then((thread1a) => {
|
||||
botSendThreadMessage(main1.event_id).then((thread1b) => {
|
||||
// 1 unread on the main thread, 2 in the new thread
|
||||
cy.findByLabelText(`${otherRoomName} 3 unread messages.`).should("exist");
|
||||
|
||||
// When we send receipts for main, and the second-last in the thread
|
||||
sendThreadedReadReceipt(main1);
|
||||
sendThreadedReadReceipt(thread1a, main1);
|
||||
|
||||
// Then the room has only one unread - the one in the thread
|
||||
cy.findByLabelText(`${otherRoomName} 1 unread message.`).should("exist");
|
||||
});
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
it("Considers room read if there are receipts for main and other thread", () => {
|
||||
// Given we sent 3 events on the main thread
|
||||
botSendMessage().then((main1) => {
|
||||
botSendThreadMessage(main1.event_id).then((thread1a) => {
|
||||
botSendThreadMessage(main1.event_id).then((thread1b) => {
|
||||
// 1 unread on the main thread, 2 in the new thread
|
||||
cy.findByLabelText(`${otherRoomName} 3 unread messages.`).should("exist");
|
||||
|
||||
// When we send receipts for main, and the last in the thread
|
||||
sendThreadedReadReceipt(main1);
|
||||
sendThreadedReadReceipt(thread1b, main1);
|
||||
|
||||
// Then the room has no unreads
|
||||
cy.findByLabelText(`${otherRoomName}`).should("exist");
|
||||
});
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
it("Recognises unread messages on a thread after receiving a unthreaded receipt for earlier ones", () => {
|
||||
// Given we sent 3 events on the main thread
|
||||
botSendMessage().then((main1) => {
|
||||
botSendThreadMessage(main1.event_id).then((thread1a) => {
|
||||
botSendThreadMessage(main1.event_id).then(() => {
|
||||
// 1 unread on the main thread, 2 in the new thread
|
||||
cy.findByLabelText(`${otherRoomName} 3 unread messages.`).should("exist");
|
||||
|
||||
// When we send an unthreaded receipt for the second-last in the thread
|
||||
sendUnthreadedReadReceipt(thread1a);
|
||||
|
||||
// Then the room has only one unread - the one in the
|
||||
// thread. The one in main is read because the unthreaded
|
||||
// receipt is for a later event.
|
||||
cy.findByLabelText(`${otherRoomName} 1 unread message.`).should("exist");
|
||||
});
|
||||
});
|
||||
});
|
||||
});
|
||||
|
||||
it("Recognises unread messages on main after receiving a unthreaded receipt for a thread message", () => {
|
||||
// Given we sent 3 events on the main thread
|
||||
botSendMessage().then((main1) => {
|
||||
botSendThreadMessage(main1.event_id).then(() => {
|
||||
botSendThreadMessage(main1.event_id).then((thread1b) => {
|
||||
botSendMessage().then(() => {
|
||||
// 2 unreads on the main thread, 2 in the new thread
|
||||
cy.findByLabelText(`${otherRoomName} 4 unread messages.`).should("exist");
|
||||
|
||||
// When we send an unthreaded receipt for the last in the thread
|
||||
sendUnthreadedReadReceipt(thread1b);
|
||||
|
||||
// Then the room has only one unread - the one in the
|
||||
// main thread, because it is later than the unthreaded
|
||||
// receipt.
|
||||
cy.findByLabelText(`${otherRoomName} 1 unread message.`).should("exist");
|
||||
});
|
||||
});
|
||||
});
|
||||
});
|
||||
});
|
||||
});
|
||||
|
|
|
@ -102,6 +102,19 @@ declare global {
|
|||
* @param message the message body to send
|
||||
*/
|
||||
botSendMessage(cli: MatrixClient, roomId: string, message: string): Chainable<ISendEventResponse>;
|
||||
/**
|
||||
* Send a message as a bot into a room in a specific thread
|
||||
* @param cli The bot's MatrixClient
|
||||
* @param threadId the thread within which this message should go
|
||||
* @param roomId ID of the room to join
|
||||
* @param message the message body to send
|
||||
*/
|
||||
botSendThreadMessage(
|
||||
cli: MatrixClient,
|
||||
roomId: string,
|
||||
threadId: string,
|
||||
message: string,
|
||||
): Chainable<ISendEventResponse>;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -249,3 +262,16 @@ Cypress.Commands.add(
|
|||
);
|
||||
},
|
||||
);
|
||||
|
||||
Cypress.Commands.add(
|
||||
"botSendThreadMessage",
|
||||
(cli: MatrixClient, roomId: string, threadId: string, message: string): Chainable<ISendEventResponse> => {
|
||||
return cy.wrap(
|
||||
cli.sendMessage(roomId, threadId, {
|
||||
msgtype: "m.text",
|
||||
body: message,
|
||||
}),
|
||||
{ log: false },
|
||||
);
|
||||
},
|
||||
);
|
||||
|
|
Loading…
Reference in New Issue