2019-07-19 00:09:31 +08:00
|
|
|
/*
|
2024-09-09 21:57:16 +08:00
|
|
|
Copyright 2024 New Vector Ltd.
|
2019-07-19 00:09:31 +08:00
|
|
|
Copyright 2019 The Matrix.org Foundation C.I.C.
|
|
|
|
|
2024-09-09 21:57:16 +08:00
|
|
|
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only
|
|
|
|
Please see LICENSE files in the repository root for full details.
|
2019-07-19 00:09:31 +08:00
|
|
|
*/
|
|
|
|
|
2024-10-15 21:57:26 +08:00
|
|
|
import { diffDeletion, diffAtCaret } from "../../../src/editor/diff";
|
2019-07-19 00:09:31 +08:00
|
|
|
|
|
|
|
describe("editor/diff", function () {
|
|
|
|
describe("diffDeletion", function () {
|
2019-07-30 18:31:40 +08:00
|
|
|
describe("with a single character removed", function () {
|
|
|
|
it("at start of string", function () {
|
|
|
|
const diff = diffDeletion("hello", "ello");
|
|
|
|
expect(diff.at).toBe(0);
|
|
|
|
expect(diff.removed).toBe("h");
|
|
|
|
});
|
|
|
|
it("in middle of string", function () {
|
|
|
|
const diff = diffDeletion("hello", "hllo");
|
|
|
|
expect(diff.at).toBe(1);
|
|
|
|
expect(diff.removed).toBe("e");
|
|
|
|
});
|
|
|
|
it("in middle of string with duplicate character", function () {
|
|
|
|
const diff = diffDeletion("hello", "helo");
|
|
|
|
expect(diff.at).toBe(3);
|
|
|
|
expect(diff.removed).toBe("l");
|
|
|
|
});
|
|
|
|
it("at end of string", function () {
|
|
|
|
const diff = diffDeletion("hello", "hell");
|
|
|
|
expect(diff.at).toBe(4);
|
|
|
|
expect(diff.removed).toBe("o");
|
|
|
|
});
|
2019-07-19 00:09:31 +08:00
|
|
|
});
|
2019-07-30 18:31:40 +08:00
|
|
|
describe("with a multiple removed", function () {
|
|
|
|
it("at start of string", function () {
|
|
|
|
const diff = diffDeletion("hello", "llo");
|
|
|
|
expect(diff.at).toBe(0);
|
|
|
|
expect(diff.removed).toBe("he");
|
|
|
|
});
|
|
|
|
it("removing whole string", function () {
|
|
|
|
const diff = diffDeletion("hello", "");
|
|
|
|
expect(diff.at).toBe(0);
|
|
|
|
expect(diff.removed).toBe("hello");
|
|
|
|
});
|
|
|
|
it("in middle of string", function () {
|
|
|
|
const diff = diffDeletion("hello", "hlo");
|
|
|
|
expect(diff.at).toBe(1);
|
|
|
|
expect(diff.removed).toBe("el");
|
|
|
|
});
|
|
|
|
it("in middle of string with duplicate character", function () {
|
|
|
|
const diff = diffDeletion("hello", "heo");
|
|
|
|
expect(diff.at).toBe(2);
|
|
|
|
expect(diff.removed).toBe("ll");
|
|
|
|
});
|
|
|
|
it("at end of string", function () {
|
|
|
|
const diff = diffDeletion("hello", "hel");
|
|
|
|
expect(diff.at).toBe(3);
|
|
|
|
expect(diff.removed).toBe("lo");
|
|
|
|
});
|
2019-07-19 00:09:31 +08:00
|
|
|
});
|
|
|
|
});
|
2019-07-24 23:26:18 +08:00
|
|
|
describe("diffAtCaret", function () {
|
|
|
|
it("insert at start", function () {
|
|
|
|
const diff = diffAtCaret("world", "hello world", 6);
|
|
|
|
expect(diff.at).toBe(0);
|
|
|
|
expect(diff.added).toBe("hello ");
|
|
|
|
expect(diff.removed).toBeFalsy();
|
|
|
|
});
|
|
|
|
it("insert at end", function () {
|
|
|
|
const diff = diffAtCaret("hello", "hello world", 11);
|
|
|
|
expect(diff.at).toBe(5);
|
|
|
|
expect(diff.added).toBe(" world");
|
|
|
|
expect(diff.removed).toBeFalsy();
|
|
|
|
});
|
|
|
|
it("insert in middle", function () {
|
|
|
|
const diff = diffAtCaret("hello world", "hello cruel world", 12);
|
|
|
|
expect(diff.at).toBe(6);
|
|
|
|
expect(diff.added).toBe("cruel ");
|
|
|
|
expect(diff.removed).toBeFalsy();
|
|
|
|
});
|
|
|
|
it("replace at start", function () {
|
|
|
|
const diff = diffAtCaret("morning, world!", "afternoon, world!", 9);
|
|
|
|
expect(diff.at).toBe(0);
|
|
|
|
expect(diff.removed).toBe("morning");
|
|
|
|
expect(diff.added).toBe("afternoon");
|
|
|
|
});
|
|
|
|
it("replace at end", function () {
|
|
|
|
const diff = diffAtCaret("morning, world!", "morning, mars?", 14);
|
|
|
|
expect(diff.at).toBe(9);
|
|
|
|
expect(diff.removed).toBe("world!");
|
|
|
|
expect(diff.added).toBe("mars?");
|
|
|
|
});
|
|
|
|
it("replace in middle", function () {
|
|
|
|
const diff = diffAtCaret("morning, blue planet", "morning, red planet", 12);
|
|
|
|
expect(diff.at).toBe(9);
|
|
|
|
expect(diff.removed).toBe("blue");
|
|
|
|
expect(diff.added).toBe("red");
|
|
|
|
});
|
|
|
|
it("remove at start of string", function () {
|
|
|
|
const diff = diffAtCaret("hello", "ello", 0);
|
|
|
|
expect(diff.at).toBe(0);
|
|
|
|
expect(diff.removed).toBe("h");
|
|
|
|
expect(diff.added).toBeFalsy();
|
|
|
|
});
|
|
|
|
it("removing whole string", function () {
|
|
|
|
const diff = diffAtCaret("hello", "", 0);
|
|
|
|
expect(diff.at).toBe(0);
|
|
|
|
expect(diff.removed).toBe("hello");
|
|
|
|
expect(diff.added).toBeFalsy();
|
|
|
|
});
|
|
|
|
it("remove in middle of string", function () {
|
|
|
|
const diff = diffAtCaret("hello", "hllo", 1);
|
|
|
|
expect(diff.at).toBe(1);
|
|
|
|
expect(diff.removed).toBe("e");
|
|
|
|
expect(diff.added).toBeFalsy();
|
|
|
|
});
|
|
|
|
it("forwards remove in middle of string", function () {
|
|
|
|
const diff = diffAtCaret("hello", "hell", 4);
|
|
|
|
expect(diff.at).toBe(4);
|
|
|
|
expect(diff.removed).toBe("o");
|
|
|
|
expect(diff.added).toBeFalsy();
|
|
|
|
});
|
|
|
|
it("forwards remove in middle of string with duplicate character", function () {
|
|
|
|
const diff = diffAtCaret("hello", "helo", 3);
|
|
|
|
expect(diff.at).toBe(3);
|
|
|
|
expect(diff.removed).toBe("l");
|
|
|
|
expect(diff.added).toBeFalsy();
|
|
|
|
});
|
|
|
|
it("remove at end of string", function () {
|
|
|
|
const diff = diffAtCaret("hello", "hell", 4);
|
|
|
|
expect(diff.at).toBe(4);
|
|
|
|
expect(diff.removed).toBe("o");
|
|
|
|
expect(diff.added).toBeFalsy();
|
|
|
|
});
|
|
|
|
});
|
2019-07-19 00:09:31 +08:00
|
|
|
});
|