I have this custom hook
import { useLocation, useNavigate, useSearchParams } from "react-router-dom";
const useZRoutes = () => {
const navigate = useNavigate();
const { search, hash } = useLocation();
const [searchParams, setSearchParams] = useSearchParams();
return {
getQueryParam: <T>(key: string): T | null => {
if (searchParams.has(key)) {
const value = searchParams.get(key);
return value as unknown as T;
}
return null;
},
deleteQueryParam: (key: string): void => {
if (searchParams.has(key)) {
searchParams.delete(key);
setSearchParams(searchParams);
}
},
extendsNavigate: (pathname: string) => navigate({ pathname, search, hash }),
};
};
export { useZRoutes };
Now, I need to test the getQueryParam
function but I can't update the URL with query param.
I tried to mock useSearchParams with Object.defineProperty
and with
jest.mock('react-router-dom', () => ({ ...jest.requireActual('react-router-dom'), // use actual for all non-hook parts useSearchParams: () => ("pid=123"), }));
and my test isn't passed. what should I do?
Instead of attempting to mock useSearchParams
, I would recommend wrapping a component that is using your custom hook with a MemoryRouter
and passing in your search params as initialEntries
.
import { MemoryRouter } from 'react-router-dom'
import { render } from '@testing-library/react'
describe('My component using the useZRoutes hook', () => {
it('should do something', () => {
render(
<MemoryRouter initialEntries={["?pid=123"]}>
<TestComponentUsingHook />
</MemoryRouter>
)
// expect something
})
})
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With