summaryrefslogtreecommitdiff
path: root/src/components/active-link.test.tsx
diff options
context:
space:
mode:
authorBertrand Yuan <189593334+bertyuan@users.noreply.github.com>2026-03-26 00:19:31 +0800
committerGitHub <noreply@github.com>2026-03-26 00:19:31 +0800
commitf247a8c4a863ec430f4a705b5c493d652c8429bd (patch)
tree71d0985970984c105582f6e3c370b254f38e9bbe /src/components/active-link.test.tsx
parentf7a02fe0e112cf108fc5f22872f1efc077e99fe8 (diff)
parentcd3c4bc89c169616b38bdb7443bb4eb7571b020c (diff)
Merge pull request #12 from bertyuan/fix-vitestv1.1
Fix vitest
Diffstat (limited to 'src/components/active-link.test.tsx')
-rw-r--r--src/components/active-link.test.tsx57
1 files changed, 57 insertions, 0 deletions
diff --git a/src/components/active-link.test.tsx b/src/components/active-link.test.tsx
new file mode 100644
index 0000000..0c603cb
--- /dev/null
+++ b/src/components/active-link.test.tsx
@@ -0,0 +1,57 @@
+import { render, screen } from '@testing-library/react';
+import type { ReactNode } from 'react';
+import { describe, expect, test, vi } from 'vitest';
+import { ActiveLink } from './active-link';
+import { usePathname } from 'next/navigation';
+
+vi.mock('next/navigation', () => ({
+ usePathname: vi.fn(),
+}));
+
+vi.mock('next/link', () => ({
+ default: ({
+ href,
+ children,
+ ...props
+ }: {
+ href: string;
+ children: ReactNode;
+ }) => (
+ <a href={href} {...props}>
+ {children}
+ </a>
+ ),
+}));
+
+describe('ActiveLink', () => {
+ test('applies active styles when pathname matches href', () => {
+ vi.mocked(usePathname).mockReturnValue('/posts');
+
+ render(<ActiveLink href='/posts'>Posts</ActiveLink>);
+
+ const link = screen.getByRole('link', { name: 'Posts' });
+ expect(link).toHaveClass('font-medium');
+ });
+
+ test('does not apply active styles for non-matching paths', () => {
+ vi.mocked(usePathname).mockReturnValue('/tags');
+
+ render(<ActiveLink href='/posts'>Posts</ActiveLink>);
+
+ const link = screen.getByRole('link', { name: 'Posts' });
+ expect(link).not.toHaveClass('font-medium');
+ });
+
+ test('supports nested path matching when nested prop is enabled', () => {
+ vi.mocked(usePathname).mockReturnValue('/posts/testing-vitest');
+
+ render(
+ <ActiveLink href='/posts' nested>
+ Posts
+ </ActiveLink>,
+ );
+
+ const link = screen.getByRole('link', { name: 'Posts' });
+ expect(link).toHaveClass('font-medium');
+ });
+});