Add forms for profile and password settings; improve tests for settings pages
- Implement `ProfileSettingsForm` and `PasswordChangeForm` components to manage user profile and password updates. - Add `SessionCard` for session management and related API hooks (`useSession`). - Update settings page tests to include user state mock and React Query provider for better test reliability. - Enhance `PasswordSettingsPage` and `ProfileSettingsPage` tests to verify component rendering and user interaction. - Improve API hook structure with dedicated hooks for session and user profile management.
This commit is contained in:
@@ -1,26 +1,40 @@
|
||||
/**
|
||||
* Tests for Password Settings Page
|
||||
* Smoke tests for placeholder page
|
||||
* Smoke tests for page rendering
|
||||
*/
|
||||
|
||||
import { render, screen } from '@testing-library/react';
|
||||
import { QueryClient, QueryClientProvider } from '@tanstack/react-query';
|
||||
import PasswordSettingsPage from '@/app/(authenticated)/settings/password/page';
|
||||
|
||||
describe('PasswordSettingsPage', () => {
|
||||
const queryClient = new QueryClient({
|
||||
defaultOptions: {
|
||||
queries: { retry: false },
|
||||
mutations: { retry: false },
|
||||
},
|
||||
});
|
||||
|
||||
const renderWithProvider = (component: React.ReactElement) => {
|
||||
return render(
|
||||
<QueryClientProvider client={queryClient}>
|
||||
{component}
|
||||
</QueryClientProvider>
|
||||
);
|
||||
};
|
||||
|
||||
it('renders without crashing', () => {
|
||||
render(<PasswordSettingsPage />);
|
||||
renderWithProvider(<PasswordSettingsPage />);
|
||||
expect(screen.getByText('Password Settings')).toBeInTheDocument();
|
||||
});
|
||||
|
||||
it('renders heading', () => {
|
||||
render(<PasswordSettingsPage />);
|
||||
|
||||
renderWithProvider(<PasswordSettingsPage />);
|
||||
expect(screen.getByRole('heading', { name: /password settings/i })).toBeInTheDocument();
|
||||
});
|
||||
|
||||
it('shows placeholder text', () => {
|
||||
render(<PasswordSettingsPage />);
|
||||
|
||||
it('shows description text', () => {
|
||||
renderWithProvider(<PasswordSettingsPage />);
|
||||
expect(screen.getByText(/change your password/i)).toBeInTheDocument();
|
||||
});
|
||||
});
|
||||
|
||||
@@ -1,26 +1,66 @@
|
||||
/**
|
||||
* Tests for Profile Settings Page
|
||||
* Smoke tests for placeholder page
|
||||
* Smoke tests for page rendering
|
||||
*/
|
||||
|
||||
import { render, screen } from '@testing-library/react';
|
||||
import { QueryClient, QueryClientProvider } from '@tanstack/react-query';
|
||||
import ProfileSettingsPage from '@/app/(authenticated)/settings/profile/page';
|
||||
import { useAuthStore } from '@/lib/stores/authStore';
|
||||
|
||||
// Mock authStore
|
||||
jest.mock('@/lib/stores/authStore');
|
||||
const mockUseAuthStore = useAuthStore as jest.MockedFunction<typeof useAuthStore>;
|
||||
|
||||
describe('ProfileSettingsPage', () => {
|
||||
const queryClient = new QueryClient({
|
||||
defaultOptions: {
|
||||
queries: { retry: false },
|
||||
mutations: { retry: false },
|
||||
},
|
||||
});
|
||||
|
||||
const mockUser = {
|
||||
id: '1',
|
||||
email: 'test@example.com',
|
||||
first_name: 'Test',
|
||||
last_name: 'User',
|
||||
is_active: true,
|
||||
is_superuser: false,
|
||||
created_at: '2024-01-01T00:00:00Z',
|
||||
};
|
||||
|
||||
beforeEach(() => {
|
||||
// Mock useAuthStore to return user data
|
||||
mockUseAuthStore.mockImplementation((selector: unknown) => {
|
||||
if (typeof selector === 'function') {
|
||||
const mockState = { user: mockUser };
|
||||
return selector(mockState);
|
||||
}
|
||||
return mockUser;
|
||||
});
|
||||
});
|
||||
|
||||
const renderWithProvider = (component: React.ReactElement) => {
|
||||
return render(
|
||||
<QueryClientProvider client={queryClient}>
|
||||
{component}
|
||||
</QueryClientProvider>
|
||||
);
|
||||
};
|
||||
|
||||
it('renders without crashing', () => {
|
||||
render(<ProfileSettingsPage />);
|
||||
renderWithProvider(<ProfileSettingsPage />);
|
||||
expect(screen.getByText('Profile Settings')).toBeInTheDocument();
|
||||
});
|
||||
|
||||
it('renders heading', () => {
|
||||
render(<ProfileSettingsPage />);
|
||||
|
||||
renderWithProvider(<ProfileSettingsPage />);
|
||||
expect(screen.getByRole('heading', { name: /profile settings/i })).toBeInTheDocument();
|
||||
});
|
||||
|
||||
it('shows placeholder text', () => {
|
||||
render(<ProfileSettingsPage />);
|
||||
|
||||
it('shows description text', () => {
|
||||
renderWithProvider(<ProfileSettingsPage />);
|
||||
expect(screen.getByText(/manage your profile information/i)).toBeInTheDocument();
|
||||
});
|
||||
});
|
||||
|
||||
@@ -1,26 +1,56 @@
|
||||
/**
|
||||
* Tests for Sessions Page
|
||||
* Smoke tests for placeholder page
|
||||
* Smoke tests for page rendering
|
||||
*/
|
||||
|
||||
import { render, screen } from '@testing-library/react';
|
||||
import { render, screen, waitFor } from '@testing-library/react';
|
||||
import { QueryClient, QueryClientProvider } from '@tanstack/react-query';
|
||||
import SessionsPage from '@/app/(authenticated)/settings/sessions/page';
|
||||
|
||||
// Mock the API client
|
||||
jest.mock('@/lib/api/client', () => ({
|
||||
...jest.requireActual('@/lib/api/client'),
|
||||
listMySessions: jest.fn(() =>
|
||||
Promise.resolve({
|
||||
data: {
|
||||
sessions: [],
|
||||
total: 0,
|
||||
},
|
||||
})
|
||||
),
|
||||
}));
|
||||
|
||||
describe('SessionsPage', () => {
|
||||
const queryClient = new QueryClient({
|
||||
defaultOptions: {
|
||||
queries: { retry: false },
|
||||
mutations: { retry: false },
|
||||
},
|
||||
});
|
||||
|
||||
const renderWithProvider = (component: React.ReactElement) => {
|
||||
return render(
|
||||
<QueryClientProvider client={queryClient}>
|
||||
{component}
|
||||
</QueryClientProvider>
|
||||
);
|
||||
};
|
||||
|
||||
it('renders without crashing', () => {
|
||||
render(<SessionsPage />);
|
||||
expect(screen.getByText('Active Sessions')).toBeInTheDocument();
|
||||
renderWithProvider(<SessionsPage />);
|
||||
// Check for the main heading
|
||||
expect(screen.getByRole('heading', { level: 2 })).toBeInTheDocument();
|
||||
});
|
||||
|
||||
it('renders heading', () => {
|
||||
render(<SessionsPage />);
|
||||
|
||||
renderWithProvider(<SessionsPage />);
|
||||
// The heading text
|
||||
expect(screen.getByRole('heading', { name: /active sessions/i })).toBeInTheDocument();
|
||||
});
|
||||
|
||||
it('shows placeholder text', () => {
|
||||
render(<SessionsPage />);
|
||||
|
||||
expect(screen.getByText(/manage your active sessions/i)).toBeInTheDocument();
|
||||
it('shows description text', () => {
|
||||
renderWithProvider(<SessionsPage />);
|
||||
// Description under the heading
|
||||
expect(screen.getByText(/view and manage devices/i)).toBeInTheDocument();
|
||||
});
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user