28acbe549a
Co-authored-by: zomars <zomars@me.com>
68 lines
2.5 KiB
TypeScript
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");
|
|
});
|
|
});
|