mirror of
https://github.com/vector-im/element-call.git
synced 2024-11-30 00:50:48 +08:00
Add tests for cases where we got a reaction from someone else.
This commit is contained in:
parent
21380c7791
commit
a9e6aa3d54
@ -99,9 +99,12 @@ export class MockRTCSession extends EventEmitter {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function createReaction(parentMemberEvent: string): MatrixEvent {
|
function createReaction(
|
||||||
|
parentMemberEvent: string,
|
||||||
|
overridenSender?: string,
|
||||||
|
): MatrixEvent {
|
||||||
return new MatrixEvent({
|
return new MatrixEvent({
|
||||||
sender: membership[parentMemberEvent],
|
sender: overridenSender ?? membership[parentMemberEvent],
|
||||||
type: EventType.Reaction,
|
type: EventType.Reaction,
|
||||||
origin_server_ts: new Date().getTime(),
|
origin_server_ts: new Date().getTime(),
|
||||||
content: {
|
content: {
|
||||||
@ -140,15 +143,20 @@ export class MockRoom extends EventEmitter {
|
|||||||
return {
|
return {
|
||||||
getChildEventsForEvent: (membershipEventId: string) => ({
|
getChildEventsForEvent: (membershipEventId: string) => ({
|
||||||
getRelations: (): MatrixEvent[] => {
|
getRelations: (): MatrixEvent[] => {
|
||||||
const sender = membership[membershipEventId];
|
return this.existingRelations.filter(
|
||||||
return this.existingRelations.filter((r) => r.getSender() === sender);
|
(r) =>
|
||||||
|
r.getContent()["m.relates_to"]?.event_id === membershipEventId,
|
||||||
|
);
|
||||||
},
|
},
|
||||||
}),
|
}),
|
||||||
} as unknown as Room["relations"];
|
} as unknown as Room["relations"];
|
||||||
}
|
}
|
||||||
|
|
||||||
public testSendReaction(parentMemberEvent: string): string {
|
public testSendReaction(
|
||||||
const evt = createReaction(parentMemberEvent);
|
parentMemberEvent: string,
|
||||||
|
overridenSender?: string,
|
||||||
|
): string {
|
||||||
|
const evt = createReaction(parentMemberEvent, overridenSender);
|
||||||
this.emit(RoomEvent.Timeline, evt, this, undefined, false, {
|
this.emit(RoomEvent.Timeline, evt, this, undefined, false, {
|
||||||
timeline: new EventTimeline(new EventTimelineSet(undefined)),
|
timeline: new EventTimeline(new EventTimelineSet(undefined)),
|
||||||
});
|
});
|
||||||
@ -238,4 +246,23 @@ describe("useReactions", () => {
|
|||||||
});
|
});
|
||||||
expect(queryByRole("list")?.children).to.have.lengthOf(0);
|
expect(queryByRole("list")?.children).to.have.lengthOf(0);
|
||||||
});
|
});
|
||||||
|
test("ignores invalid sender for historic event", () => {
|
||||||
|
const room = new MockRoom([
|
||||||
|
createReaction(memberEventAlice, memberUserIdBob),
|
||||||
|
]);
|
||||||
|
const rtcSession = new MockRTCSession(room);
|
||||||
|
const { queryByRole } = render(
|
||||||
|
<TestComponentWrapper rtcSession={rtcSession} />,
|
||||||
|
);
|
||||||
|
expect(queryByRole("list")?.children).to.have.lengthOf(0);
|
||||||
|
});
|
||||||
|
test("ignores invalid sender for new event", async () => {
|
||||||
|
const room = new MockRoom([]);
|
||||||
|
const rtcSession = new MockRTCSession(room);
|
||||||
|
const { queryByRole } = render(
|
||||||
|
<TestComponentWrapper rtcSession={rtcSession} />,
|
||||||
|
);
|
||||||
|
await act(() => room.testSendReaction(memberEventAlice, memberUserIdBob));
|
||||||
|
expect(queryByRole("list")?.children).to.have.lengthOf(0);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
@ -113,14 +113,17 @@ export const ReactionsProvider = ({
|
|||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
// Fetches the first reaction for a given event. We assume no more than
|
// Fetches the first reaction for a given event. We assume no more than
|
||||||
// one reaction on an event here.
|
// one reaction on an event here.
|
||||||
const getLastReactionEvent = (eventId: string): MatrixEvent | undefined => {
|
const getLastReactionEvent = (
|
||||||
|
eventId: string,
|
||||||
|
expectedSender: string,
|
||||||
|
): MatrixEvent | undefined => {
|
||||||
const relations = room.relations.getChildEventsForEvent(
|
const relations = room.relations.getChildEventsForEvent(
|
||||||
eventId,
|
eventId,
|
||||||
RelationType.Annotation,
|
RelationType.Annotation,
|
||||||
EventType.Reaction,
|
EventType.Reaction,
|
||||||
);
|
);
|
||||||
const allEvents = relations?.getRelations() ?? [];
|
const allEvents = relations?.getRelations() ?? [];
|
||||||
return allEvents.find((u) => u.sender === myUserId);
|
return allEvents.find((u) => u.event.sender === expectedSender);
|
||||||
};
|
};
|
||||||
|
|
||||||
// Remove any raised hands for users no longer joined to the call.
|
// Remove any raised hands for users no longer joined to the call.
|
||||||
@ -144,7 +147,7 @@ export const ReactionsProvider = ({
|
|||||||
// was raised, reset.
|
// was raised, reset.
|
||||||
removeRaisedHand(m.sender);
|
removeRaisedHand(m.sender);
|
||||||
}
|
}
|
||||||
const reaction = getLastReactionEvent(m.eventId);
|
const reaction = getLastReactionEvent(m.eventId, m.sender);
|
||||||
const eventId = reaction?.getId();
|
const eventId = reaction?.getId();
|
||||||
if (!eventId) {
|
if (!eventId) {
|
||||||
continue;
|
continue;
|
||||||
@ -160,14 +163,10 @@ export const ReactionsProvider = ({
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}, [
|
// Ignoring raisedHands here because we don't want to trigger each time the raised
|
||||||
room,
|
// hands set is updated.
|
||||||
memberships,
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
||||||
myUserId,
|
}, [room, memberships, myUserId, addRaisedHand, removeRaisedHand]);
|
||||||
raisedHands,
|
|
||||||
addRaisedHand,
|
|
||||||
removeRaisedHand,
|
|
||||||
]);
|
|
||||||
|
|
||||||
// This effect handles any *live* reaction/redactions in the room.
|
// This effect handles any *live* reaction/redactions in the room.
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
|
Loading…
Reference in New Issue
Block a user