cal/packages/lib/hooks/useCompatSearchParams.test.ts
2023-11-16 13:38:27 -07:00

68 lines
2.5 KiB
TypeScript

import { renderHook } from "@testing-library/react-hooks";
import { vi } from "vitest";
import { describe, expect, it } from "vitest";
import { useCompatSearchParams } from "./useCompatSearchParams";
vi.mock("next/navigation", () => ({
ReadonlyURLSearchParams: vi.fn((a) => a),
}));
describe("useCompatSearchParams hook", () => {
it("should return the searchParams in next@13.4.6 Pages Router, SSR", async () => {
const navigation = await import("next/navigation");
navigation.useSearchParams = vi.fn().mockReturnValue(new URLSearchParams("a=a&b=b"));
navigation.useParams = vi.fn().mockReturnValue(null);
const { result } = renderHook(() => useCompatSearchParams());
expect(result.current.toString()).toEqual("a=a&b=b");
});
it("should return both searchParams and params in next@13.4.6 App Router, SSR", async () => {
const navigation = await import("next/navigation");
navigation.useSearchParams = vi.fn().mockReturnValue(new URLSearchParams("a=a"));
navigation.useParams = vi.fn().mockReturnValue({ b: "b" });
const { result } = renderHook(() => useCompatSearchParams());
expect(result.current.toString()).toEqual("a=a&b=b");
});
it("params should always override searchParams in case of conflicting keys", async () => {
const navigation = await import("next/navigation");
navigation.useSearchParams = vi.fn().mockReturnValue(new URLSearchParams("a=a"));
navigation.useParams = vi.fn().mockReturnValue({ a: "b" });
const { result } = renderHook(() => useCompatSearchParams());
expect(result.current.toString()).toEqual("a=b");
});
it("should split paramsseparated with '/' (catch-all segments) in next@13.4.6 App Router, SSR", async () => {
const navigation = await import("next/navigation");
navigation.useSearchParams = vi.fn().mockReturnValue(new URLSearchParams());
// in next@13.4.6 useParams will return params separated by `/`
navigation.useParams = vi.fn().mockReturnValue({ a: "a/b/c" });
const { result } = renderHook(() => useCompatSearchParams());
expect(result.current.getAll("a")).toEqual(["a", "b", "c"]);
});
it("should include params and searchParams in next@13.5.4, Pages/App Router, SSR", async () => {
const navigation = await import("next/navigation");
navigation.useSearchParams = vi.fn().mockReturnValue(new URLSearchParams("a=a"));
navigation.useParams = vi.fn().mockReturnValue({ b: "b" });
const { result } = renderHook(() => useCompatSearchParams());
expect(result.current.toString()).toEqual("a=a&b=b");
});
});