element-web/test/unit-tests/utils/SearchInput-test.ts

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

53 lines
1.8 KiB
TypeScript
Raw Normal View History

Allows search to recognize full room links (#8275) * fix matrix search link * fix matrix search link Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> * fix: allow full link search Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> * fix: allow full link search on new search feature Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> * improve transformSearchTerm function Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> * improve transformSearchTerm function Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> * add review changes * Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> added review correction changed the transformSearchTerm function to use parsePermaLink removed extra spaces * add angle brackets to copyright email title * removed extra space Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> * Update src/utils/SearchInput.ts Co-authored-by: Travis Ralston <travpc@gmail.com> * fixed spolight dialog search for room and user links * added tests for transformSearchTerm * removed transformSearchTerm from room search bar * replaces two test cases to one that should return the primaryEntityId if the search term was a permalink * corrected ts issues * changed type of transformSearchTerm to string * changed return value from empty string to the original search term if the primaryEntityId of the parsedLink is null * changed return value from empty string to the original search term if the primaryEntityId of the parsedLink is null * refactored transformSearchTerm and added a new test case * rewrote transformSearchTerm doc * changed mocked return values of test case - should return the original search term if the search term is a permalink and the primaryEntityId is null * lint corrections --------- Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> Co-authored-by: Boluwatife Omosowon <boluwatifeomosowon@Jesus-Loves-You.local> Co-authored-by: Travis Ralston <travpc@gmail.com>
2023-05-09 07:55:50 +00:00
/*
Copyright 2024 New Vector Ltd.
Allows search to recognize full room links (#8275) * fix matrix search link * fix matrix search link Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> * fix: allow full link search Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> * fix: allow full link search on new search feature Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> * improve transformSearchTerm function Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> * improve transformSearchTerm function Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> * add review changes * Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> added review correction changed the transformSearchTerm function to use parsePermaLink removed extra spaces * add angle brackets to copyright email title * removed extra space Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> * Update src/utils/SearchInput.ts Co-authored-by: Travis Ralston <travpc@gmail.com> * fixed spolight dialog search for room and user links * added tests for transformSearchTerm * removed transformSearchTerm from room search bar * replaces two test cases to one that should return the primaryEntityId if the search term was a permalink * corrected ts issues * changed type of transformSearchTerm to string * changed return value from empty string to the original search term if the primaryEntityId of the parsedLink is null * changed return value from empty string to the original search term if the primaryEntityId of the parsedLink is null * refactored transformSearchTerm and added a new test case * rewrote transformSearchTerm doc * changed mocked return values of test case - should return the original search term if the search term is a permalink and the primaryEntityId is null * lint corrections --------- Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> Co-authored-by: Boluwatife Omosowon <boluwatifeomosowon@Jesus-Loves-You.local> Co-authored-by: Travis Ralston <travpc@gmail.com>
2023-05-09 07:55:50 +00:00
Copyright 2023 Boluwatife Omosowon <boluomosowon@gmail.com>
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only
Please see LICENSE files in the repository root for full details.
Allows search to recognize full room links (#8275) * fix matrix search link * fix matrix search link Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> * fix: allow full link search Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> * fix: allow full link search on new search feature Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> * improve transformSearchTerm function Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> * improve transformSearchTerm function Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> * add review changes * Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> added review correction changed the transformSearchTerm function to use parsePermaLink removed extra spaces * add angle brackets to copyright email title * removed extra space Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> * Update src/utils/SearchInput.ts Co-authored-by: Travis Ralston <travpc@gmail.com> * fixed spolight dialog search for room and user links * added tests for transformSearchTerm * removed transformSearchTerm from room search bar * replaces two test cases to one that should return the primaryEntityId if the search term was a permalink * corrected ts issues * changed type of transformSearchTerm to string * changed return value from empty string to the original search term if the primaryEntityId of the parsedLink is null * changed return value from empty string to the original search term if the primaryEntityId of the parsedLink is null * refactored transformSearchTerm and added a new test case * rewrote transformSearchTerm doc * changed mocked return values of test case - should return the original search term if the search term is a permalink and the primaryEntityId is null * lint corrections --------- Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> Co-authored-by: Boluwatife Omosowon <boluwatifeomosowon@Jesus-Loves-You.local> Co-authored-by: Travis Ralston <travpc@gmail.com>
2023-05-09 07:55:50 +00:00
*/
import { mocked } from "jest-mock";
import { parsePermalink } from "../../src/utils/permalinks/Permalinks";
import { transformSearchTerm } from "../../src/utils/SearchInput";
jest.mock("../../src/utils/permalinks/Permalinks");
jest.mock("../../src/stores/WidgetStore");
jest.mock("../../src/stores/widgets/WidgetLayoutStore");
Allows search to recognize full room links (#8275) * fix matrix search link * fix matrix search link Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> * fix: allow full link search Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> * fix: allow full link search on new search feature Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> * improve transformSearchTerm function Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> * improve transformSearchTerm function Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> * add review changes * Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> added review correction changed the transformSearchTerm function to use parsePermaLink removed extra spaces * add angle brackets to copyright email title * removed extra space Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> * Update src/utils/SearchInput.ts Co-authored-by: Travis Ralston <travpc@gmail.com> * fixed spolight dialog search for room and user links * added tests for transformSearchTerm * removed transformSearchTerm from room search bar * replaces two test cases to one that should return the primaryEntityId if the search term was a permalink * corrected ts issues * changed type of transformSearchTerm to string * changed return value from empty string to the original search term if the primaryEntityId of the parsedLink is null * changed return value from empty string to the original search term if the primaryEntityId of the parsedLink is null * refactored transformSearchTerm and added a new test case * rewrote transformSearchTerm doc * changed mocked return values of test case - should return the original search term if the search term is a permalink and the primaryEntityId is null * lint corrections --------- Signed-off-by: Boluwatife Omosowon <boluomosowon@gmail.com> Co-authored-by: Boluwatife Omosowon <boluwatifeomosowon@Jesus-Loves-You.local> Co-authored-by: Travis Ralston <travpc@gmail.com>
2023-05-09 07:55:50 +00:00
describe("transforming search term", () => {
it("should return the primaryEntityId if the search term was a permalink", () => {
const roomLink = "https://matrix.to/#/#element-dev:matrix.org";
const parsedPermalink = "#element-dev:matrix.org";
mocked(parsePermalink).mockReturnValue({
primaryEntityId: parsedPermalink,
roomIdOrAlias: parsedPermalink,
eventId: "",
userId: "",
viaServers: [],
});
expect(transformSearchTerm(roomLink)).toBe(parsedPermalink);
});
it("should return the original search term if the search term is a permalink and the primaryEntityId is null", () => {
const searchTerm = "https://matrix.to/#/#random-link:matrix.org";
mocked(parsePermalink).mockReturnValue({
primaryEntityId: null,
roomIdOrAlias: null,
eventId: null,
userId: null,
viaServers: null,
});
expect(transformSearchTerm(searchTerm)).toBe(searchTerm);
});
it("should return the original search term if the search term was not a permalink", () => {
const searchTerm = "search term";
mocked(parsePermalink).mockReturnValue(null);
expect(transformSearchTerm(searchTerm)).toBe(searchTerm);
});
});