1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-07-17 13:46:47 +02:00
unleash.unleash/frontend/src/component/project/ProjectList/ArchiveProjectList.test.tsx
Tymoteusz Czech f2e2952c31
fix: projects archive search (#7898)
Filter projects when searching
2024-08-15 16:19:29 +02:00

53 lines
1.5 KiB
TypeScript

import { screen, waitFor } from '@testing-library/react';
import { render } from 'utils/testRenderer';
import { testServerRoute, testServerSetup } from 'utils/testServer';
import { ArchiveProjectList } from './ArchiveProjectList';
import userEvent from '@testing-library/user-event';
const server = testServerSetup();
const setupApi = () => {
testServerRoute(server, '/api/admin/projects', {
projects: [
{ id: 'testid-1', name: 'Project One', archived: true },
{ id: 'testid-2', name: 'Project Two', archived: true },
],
});
testServerRoute(server, '/api/admin/ui-config', {
flags: {
archiveFeature: true,
},
versionInfo: {
current: { enterprise: 'version' },
},
});
};
beforeEach(() => {
setupApi();
});
test('displays archived projects correctly', async () => {
render(<ArchiveProjectList />);
await waitFor(() => {
expect(screen.getByText('Project One')).toBeInTheDocument();
expect(screen.getByText('Project Two')).toBeInTheDocument();
});
});
test('search in header works', async () => {
render(<ArchiveProjectList />);
const searchInput = screen.getByPlaceholderText(/^Search/);
expect(searchInput).toBeInTheDocument();
await userEvent.type(searchInput, 'One');
await waitFor(() => {
expect(screen.queryByTestId('testid-1')).toBeInTheDocument();
expect(screen.queryByTestId('testid-2')).not.toBeInTheDocument();
});
});