Files
syndarix/frontend/tests/app/(authenticated)/settings/sessions/page.test.tsx
Felipe Cardoso b2f3ec8f25 Refactor ESLint configuration and update test rules for clarity and consistency
- Consolidated and modularized `eslint.config.mjs` with defined rules for source, test, E2E, and scripts.
- Improved test and E2E rules with relaxed settings for flexibility and enhanced mocking.
- Standardized variable naming and removed redundant imports in unit and E2E tests.
- Updated error handling and comments to align with modern TypeScript best practices (e.g., `@ts-expect-error`).
2025-11-10 10:57:43 +01:00

57 lines
1.5 KiB
TypeScript

/**
* Tests for Sessions Page
* Smoke tests for page rendering
*/
import { render, screen } 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', () => {
renderWithProvider(<SessionsPage />);
// Check for the main heading
expect(screen.getByRole('heading', { level: 2 })).toBeInTheDocument();
});
it('renders heading', () => {
renderWithProvider(<SessionsPage />);
// The heading text
expect(screen.getByRole('heading', { name: /active sessions/i })).toBeInTheDocument();
});
it('shows description text', () => {
renderWithProvider(<SessionsPage />);
// Description under the heading
expect(screen.getByText(/view and manage devices/i)).toBeInTheDocument();
});
});