2025-07-17 17:18:58 +00:00
|
|
|
import { render, screen } from '@testing-library/react';
|
|
|
|
import { describe, it, expect, vi } from 'vitest';
|
|
|
|
import { ErrorBoundary } from '@/components/ErrorBoundary';
|
|
|
|
|
2025-07-17 22:19:12 +00:00
|
|
|
|
2025-07-17 17:18:58 +00:00
|
|
|
|
|
|
|
// Test component that throws an error
|
|
|
|
const ThrowError = ({ shouldThrow }: { shouldThrow: boolean }) => {
|
|
|
|
if (shouldThrow) {
|
|
|
|
throw new Error('Test error');
|
|
|
|
}
|
|
|
|
return <div>No error</div>;
|
|
|
|
};
|
|
|
|
|
|
|
|
describe('ErrorBoundary', () => {
|
|
|
|
it('renders children when no error occurs', () => {
|
|
|
|
render(
|
|
|
|
<ErrorBoundary>
|
|
|
|
<div>Test content</div>
|
|
|
|
</ErrorBoundary>
|
|
|
|
);
|
|
|
|
|
|
|
|
expect(screen.getByText('Test content')).toBeInTheDocument();
|
|
|
|
});
|
|
|
|
|
|
|
|
it('catches and displays error when child throws', () => {
|
|
|
|
// Suppress console.error for this test
|
|
|
|
const consoleSpy = vi.spyOn(console, 'error').mockImplementation(() => {});
|
|
|
|
|
|
|
|
render(
|
|
|
|
<ErrorBoundary>
|
|
|
|
<ThrowError shouldThrow={true} />
|
|
|
|
</ErrorBoundary>
|
|
|
|
);
|
|
|
|
|
|
|
|
expect(screen.getByText('Something went wrong')).toBeInTheDocument();
|
|
|
|
expect(screen.getByText('An unexpected error occurred. The error has been reported.')).toBeInTheDocument();
|
|
|
|
|
|
|
|
consoleSpy.mockRestore();
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
it('uses custom fallback when provided', () => {
|
|
|
|
const customFallback = <div>Custom error message</div>;
|
|
|
|
|
|
|
|
// Suppress console.error for this test
|
|
|
|
const consoleSpy = vi.spyOn(console, 'error').mockImplementation(() => {});
|
|
|
|
|
|
|
|
render(
|
|
|
|
<ErrorBoundary fallback={customFallback}>
|
|
|
|
<ThrowError shouldThrow={true} />
|
|
|
|
</ErrorBoundary>
|
|
|
|
);
|
|
|
|
|
|
|
|
expect(screen.getByText('Custom error message')).toBeInTheDocument();
|
|
|
|
|
|
|
|
consoleSpy.mockRestore();
|
|
|
|
});
|
|
|
|
});
|