summaryrefslogtreecommitdiff
path: root/src/components/inline-link.test.tsx
diff options
context:
space:
mode:
authorBertrand Yuan <noreply@bertyuan.com>2026-03-26 00:02:16 +0800
committerBertrand Yuan <noreply@bertyuan.com>2026-03-26 00:02:16 +0800
commit8a6a6712e7554f110b5ef951f270d88fd010e040 (patch)
tree12cb86b1ede55e15600ef7f139ef7ec91b9fa8a1 /src/components/inline-link.test.tsx
parentf7a02fe0e112cf108fc5f22872f1efc077e99fe8 (diff)
add more tests
Diffstat (limited to 'src/components/inline-link.test.tsx')
-rw-r--r--src/components/inline-link.test.tsx41
1 files changed, 41 insertions, 0 deletions
diff --git a/src/components/inline-link.test.tsx b/src/components/inline-link.test.tsx
new file mode 100644
index 0000000..ad9813d
--- /dev/null
+++ b/src/components/inline-link.test.tsx
@@ -0,0 +1,41 @@
+import { render, screen } from '@testing-library/react';
+import type { ReactNode } from 'react';
+import { describe, expect, test, vi } from 'vitest';
+import { InlineLink } from './inline-link';
+
+vi.mock('next/link', () => ({
+ default: ({
+ href,
+ children,
+ ...props
+ }: {
+ href: string;
+ children: ReactNode;
+ }) => (
+ <a href={href} {...props}>
+ {children}
+ </a>
+ ),
+}));
+
+describe('InlineLink', () => {
+ test('renders as a normal link by default', () => {
+ render(<InlineLink href='/posts'>Posts</InlineLink>);
+
+ const link = screen.getByRole('link', { name: 'Posts' });
+ expect(link).toHaveAttribute('href', '/posts');
+ expect(link).not.toHaveAttribute('target', '_blank');
+ });
+
+ test('sets target blank when blank prop is true', () => {
+ render(
+ <InlineLink href='https://example.com' blank>
+ External
+ </InlineLink>,
+ );
+
+ const link = screen.getByRole('link', { name: 'External' });
+ expect(link).toHaveAttribute('href', 'https://example.com');
+ expect(link).toHaveAttribute('target', '_blank');
+ });
+});