mirror of
https://github.com/grafana/grafana.git
synced 2025-02-25 18:55:37 -06:00
Teams page replace mobx (#13219)
* creating types, actions, reducer * load teams and store in redux * delete team * set search query action and tests * Teampages page * team members, bug in fetching team * flattened team state, tests for TeamMembers * test for team member selector * team settings * actions for group sync * tests for team groups * removed comment * remove old stores * fix: formating of datasource.go * fix: minor changes to imports * adding debounce and fixing issue in teamlist * refactoring: moving types to their own files
This commit is contained in:
committed by
Torkel Ödegaard
parent
1ce9001141
commit
9f73f13091
63
public/app/features/teams/TeamGroupSync.test.tsx
Normal file
63
public/app/features/teams/TeamGroupSync.test.tsx
Normal file
@@ -0,0 +1,63 @@
|
||||
import React from 'react';
|
||||
import { shallow } from 'enzyme';
|
||||
import { Props, TeamGroupSync } from './TeamGroupSync';
|
||||
import { TeamGroup } from '../../types';
|
||||
import { getMockTeamGroups } from './__mocks__/teamMocks';
|
||||
|
||||
const setup = (propOverrides?: object) => {
|
||||
const props: Props = {
|
||||
groups: [] as TeamGroup[],
|
||||
loadTeamGroups: jest.fn(),
|
||||
addTeamGroup: jest.fn(),
|
||||
removeTeamGroup: jest.fn(),
|
||||
};
|
||||
|
||||
Object.assign(props, propOverrides);
|
||||
|
||||
const wrapper = shallow(<TeamGroupSync {...props} />);
|
||||
const instance = wrapper.instance() as TeamGroupSync;
|
||||
|
||||
return {
|
||||
wrapper,
|
||||
instance,
|
||||
};
|
||||
};
|
||||
|
||||
describe('Render', () => {
|
||||
it('should render component', () => {
|
||||
const { wrapper } = setup();
|
||||
|
||||
expect(wrapper).toMatchSnapshot();
|
||||
});
|
||||
|
||||
it('should render groups table', () => {
|
||||
const { wrapper } = setup({
|
||||
groups: getMockTeamGroups(3),
|
||||
});
|
||||
|
||||
expect(wrapper).toMatchSnapshot();
|
||||
});
|
||||
});
|
||||
|
||||
describe('Functions', () => {
|
||||
it('should call add group', () => {
|
||||
const { instance } = setup();
|
||||
|
||||
instance.setState({ newGroupId: 'some/group' });
|
||||
const mockEvent = { preventDefault: jest.fn() };
|
||||
|
||||
instance.onAddGroup(mockEvent);
|
||||
|
||||
expect(instance.props.addTeamGroup).toHaveBeenCalledWith('some/group');
|
||||
});
|
||||
|
||||
it('should call remove group', () => {
|
||||
const { instance } = setup();
|
||||
|
||||
const mockGroup: TeamGroup = { teamId: 1, groupId: 'some/group' };
|
||||
|
||||
instance.onRemoveGroup(mockGroup);
|
||||
|
||||
expect(instance.props.removeTeamGroup).toHaveBeenCalledWith('some/group');
|
||||
});
|
||||
});
|
||||
Reference in New Issue
Block a user