2024-05-13 17:58:27 +01:00
|
|
|
import { screen } from '@testing-library/react';
|
|
|
|
|
import { Route, Router } from 'react-router-dom';
|
|
|
|
|
import { render } from 'test/test-utils';
|
2022-04-22 14:33:13 +01:00
|
|
|
|
2024-05-13 17:58:27 +01:00
|
|
|
import { locationService } from '@grafana/runtime';
|
2022-04-22 14:33:13 +01:00
|
|
|
|
2024-05-13 17:58:27 +01:00
|
|
|
import TeamPages from './TeamPages';
|
2022-04-22 14:33:13 +01:00
|
|
|
import { getMockTeam } from './__mocks__/teamMocks';
|
2018-09-11 14:14:03 +02:00
|
|
|
|
2022-06-08 19:05:27 +03:00
|
|
|
jest.mock('app/core/components/Select/UserPicker', () => {
|
|
|
|
|
return { UserPicker: () => null };
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
jest.mock('app/core/services/context_srv', () => ({
|
|
|
|
|
contextSrv: {
|
2023-10-09 10:32:44 +01:00
|
|
|
accessControlEnabled: () => true,
|
|
|
|
|
hasPermissionInMetadata: () => true,
|
2022-06-08 19:05:27 +03:00
|
|
|
user: {},
|
|
|
|
|
},
|
|
|
|
|
}));
|
|
|
|
|
|
|
|
|
|
jest.mock('@grafana/runtime', () => ({
|
|
|
|
|
...jest.requireActual('@grafana/runtime'),
|
|
|
|
|
getBackendSrv: () => ({
|
2024-05-13 17:58:27 +01:00
|
|
|
get: jest.fn().mockResolvedValue(getMockTeam()),
|
2022-06-08 19:05:27 +03:00
|
|
|
}),
|
2022-01-07 15:11:23 -05:00
|
|
|
config: {
|
2024-02-06 13:43:11 +00:00
|
|
|
...jest.requireActual('@grafana/runtime').config,
|
2022-01-24 16:08:05 +01:00
|
|
|
licenseInfo: {
|
|
|
|
|
enabledFeatures: { teamsync: true },
|
2022-06-08 19:05:27 +03:00
|
|
|
stateInfo: '',
|
|
|
|
|
licenseUrl: '',
|
2022-01-24 16:08:05 +01:00
|
|
|
},
|
2023-10-09 10:32:44 +01:00
|
|
|
featureToggles: { accesscontrol: true },
|
2022-06-08 19:05:27 +03:00
|
|
|
bootData: { navTree: [], user: {} },
|
|
|
|
|
buildInfo: {
|
|
|
|
|
edition: 'Open Source',
|
2022-09-02 14:35:27 +04:30
|
|
|
version: '7.5.0',
|
|
|
|
|
commit: 'abc123',
|
|
|
|
|
env: 'production',
|
|
|
|
|
latestVersion: '',
|
|
|
|
|
hasUpdate: false,
|
|
|
|
|
hideVersion: false,
|
2022-06-08 19:05:27 +03:00
|
|
|
},
|
|
|
|
|
appSubUrl: '',
|
2020-08-20 02:32:10 -07:00
|
|
|
},
|
2022-06-08 19:05:27 +03:00
|
|
|
featureEnabled: () => true,
|
2018-09-11 14:14:03 +02:00
|
|
|
}));
|
|
|
|
|
|
2022-06-08 19:05:27 +03:00
|
|
|
// Mock connected child components instead of rendering them
|
|
|
|
|
jest.mock('./TeamSettings', () => {
|
|
|
|
|
//eslint-disable-next-line
|
|
|
|
|
return () => <div>Team settings</div>;
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
jest.mock('./TeamGroupSync', () => {
|
|
|
|
|
//eslint-disable-next-line
|
|
|
|
|
return () => <div>Team group sync</div>;
|
|
|
|
|
});
|
|
|
|
|
|
2024-05-13 17:58:27 +01:00
|
|
|
const setup = (propOverrides: { teamId?: number; pageName?: string } = {}) => {
|
|
|
|
|
const pageName = propOverrides.pageName ?? 'members';
|
|
|
|
|
const teamId = propOverrides.teamId ?? 1;
|
|
|
|
|
locationService.push({ pathname: `/org/teams/edit/${teamId}/${pageName}` });
|
2018-09-11 14:14:03 +02:00
|
|
|
|
2022-06-08 19:05:27 +03:00
|
|
|
render(
|
2024-05-13 17:58:27 +01:00
|
|
|
<Router history={locationService.getHistory()}>
|
|
|
|
|
<Route path="/org/teams/edit/:id/:page?">
|
|
|
|
|
<TeamPages />
|
|
|
|
|
</Route>
|
|
|
|
|
</Router>
|
2022-06-08 19:05:27 +03:00
|
|
|
);
|
2018-09-11 14:14:03 +02:00
|
|
|
};
|
|
|
|
|
|
2022-09-02 14:35:27 +04:30
|
|
|
describe('TeamPages', () => {
|
2022-06-08 19:05:27 +03:00
|
|
|
it('should render settings and preferences page', async () => {
|
|
|
|
|
setup({
|
2018-09-11 14:14:03 +02:00
|
|
|
pageName: 'settings',
|
|
|
|
|
});
|
|
|
|
|
|
2022-06-08 19:05:27 +03:00
|
|
|
expect(await screen.findByText('Team settings')).toBeInTheDocument();
|
2018-09-11 14:14:03 +02:00
|
|
|
});
|
|
|
|
|
|
2022-06-08 19:05:27 +03:00
|
|
|
it('should render group sync page', async () => {
|
|
|
|
|
setup({
|
2018-09-11 14:14:03 +02:00
|
|
|
pageName: 'groupsync',
|
|
|
|
|
});
|
|
|
|
|
|
2022-06-08 19:05:27 +03:00
|
|
|
expect(await screen.findByText('Team group sync')).toBeInTheDocument();
|
2018-09-11 14:14:03 +02:00
|
|
|
});
|
|
|
|
|
});
|