mirror of
https://github.com/element-hq/element-web.git
synced 2024-12-12 05:00:31 +03:00
4574c665ea
* Conform more code to strict null checking * Delint * Iterate PR based on feedback
191 lines
6 KiB
TypeScript
191 lines
6 KiB
TypeScript
/*
|
|
Copyright 2022 The Matrix.org Foundation C.I.C.
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
import { IContent, MatrixEvent, MsgType } from "matrix-js-sdk/src/matrix";
|
|
import { M_BEACON_INFO } from "matrix-js-sdk/src/@types/beacon";
|
|
import { LocationAssetType, M_ASSET } from "matrix-js-sdk/src/@types/location";
|
|
import { M_POLL_END } from "matrix-js-sdk/src/@types/polls";
|
|
|
|
import {
|
|
getNestedReplyText,
|
|
getParentEventId,
|
|
shouldDisplayReply,
|
|
stripHTMLReply,
|
|
stripPlainReply,
|
|
} from "../src/utils/Reply";
|
|
import { mkEvent } from "./test-utils";
|
|
import { RoomPermalinkCreator } from "../src/utils/permalinks/Permalinks";
|
|
|
|
function makeTestEvent(type: string, content: IContent): MatrixEvent {
|
|
return mkEvent({
|
|
event: true,
|
|
type: type,
|
|
user: "@user1:server",
|
|
room: "!room1:server",
|
|
content,
|
|
});
|
|
}
|
|
|
|
const mockPermalinkGenerator = {
|
|
forEvent(eventId: string): string {
|
|
return "$$permalink$$";
|
|
},
|
|
} as RoomPermalinkCreator;
|
|
|
|
// don't litter test console with logs
|
|
jest.mock("matrix-js-sdk/src/logger");
|
|
|
|
describe("Reply", () => {
|
|
describe("getParentEventId", () => {
|
|
it("returns undefined if given a falsey value", async () => {
|
|
expect(getParentEventId()).toBeUndefined();
|
|
});
|
|
it("returns undefined if given a redacted event", async () => {
|
|
const event = mkEvent({
|
|
event: true,
|
|
type: "m.room.message",
|
|
user: "@user1:server",
|
|
room: "!room1:server",
|
|
content: {},
|
|
});
|
|
event.makeRedacted(event);
|
|
|
|
expect(getParentEventId(event)).toBeUndefined();
|
|
});
|
|
it("returns undefined if the given event is not a reply", async () => {
|
|
const event = mkEvent({
|
|
event: true,
|
|
type: "m.room.message",
|
|
user: "@user1:server",
|
|
room: "!room1:server",
|
|
content: {},
|
|
});
|
|
|
|
expect(getParentEventId(event)).toBeUndefined();
|
|
});
|
|
it("returns id of the event being replied to", async () => {
|
|
const event = mkEvent({
|
|
event: true,
|
|
type: "m.room.message",
|
|
user: "@user1:server",
|
|
room: "!room1:server",
|
|
content: {
|
|
"m.relates_to": {
|
|
"m.in_reply_to": {
|
|
event_id: "$event1",
|
|
},
|
|
},
|
|
},
|
|
});
|
|
|
|
expect(getParentEventId(event)).toBe("$event1");
|
|
});
|
|
});
|
|
|
|
describe("stripPlainReply", () => {
|
|
it("Removes leading quotes until the first blank line", () => {
|
|
expect(
|
|
stripPlainReply(
|
|
`
|
|
> This is part
|
|
> of the quote
|
|
|
|
But this is not
|
|
`.trim(),
|
|
),
|
|
).toBe("But this is not");
|
|
});
|
|
});
|
|
|
|
describe("stripHTMLReply", () => {
|
|
it("Removes <mx-reply> from the input", () => {
|
|
expect(
|
|
stripHTMLReply(`
|
|
<mx-reply>
|
|
This is part
|
|
of the quote
|
|
</mx-reply>
|
|
But this is not
|
|
`).trim(),
|
|
).toBe("But this is not");
|
|
});
|
|
});
|
|
|
|
describe("getNestedReplyText", () => {
|
|
it("Returns valid reply fallback text for m.text msgtypes", () => {
|
|
const event = makeTestEvent(MsgType.Text, {
|
|
body: "body",
|
|
msgtype: "m.text",
|
|
});
|
|
|
|
expect(getNestedReplyText(event, mockPermalinkGenerator)).toMatchSnapshot();
|
|
});
|
|
|
|
(
|
|
[
|
|
["m.room.message", MsgType.Location, LocationAssetType.Pin],
|
|
["m.room.message", MsgType.Location, LocationAssetType.Self],
|
|
[M_BEACON_INFO.name, undefined, LocationAssetType.Pin],
|
|
[M_BEACON_INFO.name, undefined, LocationAssetType.Self],
|
|
] as const
|
|
).forEach(([type, msgType, assetType]) => {
|
|
it(`should create the expected fallback text for ${assetType} ${type}/${msgType}`, () => {
|
|
const event = makeTestEvent(type, {
|
|
body: "body",
|
|
msgtype: msgType,
|
|
[M_ASSET.name]: { type: assetType },
|
|
});
|
|
|
|
expect(getNestedReplyText(event, mockPermalinkGenerator)).toMatchSnapshot();
|
|
});
|
|
});
|
|
|
|
it("should create the expected fallback text for poll end events", () => {
|
|
const event = makeTestEvent(M_POLL_END.name, {
|
|
body: "body",
|
|
});
|
|
|
|
expect(getNestedReplyText(event, mockPermalinkGenerator)).toMatchSnapshot();
|
|
});
|
|
});
|
|
|
|
describe("shouldDisplayReply", () => {
|
|
it("Returns false for redacted events", () => {
|
|
const event = mkEvent({
|
|
event: true,
|
|
type: "m.room.message",
|
|
user: "@user1:server",
|
|
room: "!room1:server",
|
|
content: {},
|
|
});
|
|
event.makeRedacted(event);
|
|
|
|
expect(shouldDisplayReply(event)).toBe(false);
|
|
});
|
|
|
|
it("Returns false for non-reply events", () => {
|
|
const event = mkEvent({
|
|
event: true,
|
|
type: "m.room.message",
|
|
user: "@user1:server",
|
|
room: "!room1:server",
|
|
content: {},
|
|
});
|
|
|
|
expect(shouldDisplayReply(event)).toBe(false);
|
|
});
|
|
});
|
|
});
|