forked from cardosofelipe/fast-next-template
- Consolidated multi-line arguments into single lines where appropriate in `useAuth`. - Improved spacing and readability in data processing across components (`ProfileSettingsForm`, `PasswordChangeForm`, `SessionCard`). - Applied consistent table and markdown formatting in design system docs (e.g., `README.md`, `08-ai-guidelines.md`, `00-quick-start.md`). - Updated code snippets to ensure adherence to Prettier rules and streamlined JSX structures.
40 lines
1.2 KiB
TypeScript
40 lines
1.2 KiB
TypeScript
/**
|
|
* Tests for Password Reset Page
|
|
* Smoke tests to verify page structure and component rendering
|
|
*/
|
|
|
|
import { render, screen } from '@testing-library/react';
|
|
import PasswordResetPage from '@/app/(auth)/password-reset/page';
|
|
|
|
// Mock dynamic import
|
|
jest.mock('next/dynamic', () => ({
|
|
__esModule: true,
|
|
default: (_importFn: () => Promise<any>, _options?: any) => {
|
|
const Component = () => (
|
|
<div data-testid="password-reset-form">Mocked PasswordResetRequestForm</div>
|
|
);
|
|
Component.displayName = 'PasswordResetRequestForm';
|
|
return Component;
|
|
},
|
|
}));
|
|
|
|
describe('PasswordResetPage', () => {
|
|
it('renders without crashing', () => {
|
|
render(<PasswordResetPage />);
|
|
expect(screen.getByText('Reset your password')).toBeInTheDocument();
|
|
});
|
|
|
|
it('renders heading and description', () => {
|
|
render(<PasswordResetPage />);
|
|
|
|
expect(screen.getByRole('heading', { name: /reset your password/i })).toBeInTheDocument();
|
|
expect(screen.getByText(/we'll send you an email with instructions/i)).toBeInTheDocument();
|
|
});
|
|
|
|
it('renders PasswordResetRequestForm component', () => {
|
|
render(<PasswordResetPage />);
|
|
|
|
expect(screen.getByTestId('password-reset-form')).toBeInTheDocument();
|
|
});
|
|
});
|