123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324 |
- import React from 'react';
- import {AssigneeSelectorComponent} from 'app/components/assigneeSelector';
- import {Client} from 'app/api';
- import {mount} from 'enzyme';
- import ConfigStore from 'app/stores/configStore';
- import GroupStore from 'app/stores/groupStore';
- import MemberListStore from 'app/stores/memberListStore';
- import ProjectsStore from 'app/stores/projectsStore';
- import TeamStore from 'app/stores/teamStore';
- describe('AssigneeSelector', function() {
- let sandbox;
- let assigneeSelector;
- let assignMock;
- let openMenu;
- let USER_1, USER_2, USER_3;
- let TEAM_1;
- let PROJECT_1;
- let GROUP_1;
- beforeEach(function() {
- sandbox = sinon.sandbox.create();
- USER_1 = TestStubs.User({
- id: '1',
- name: 'Jane Doe',
- email: 'janedoe@example.com',
- });
- USER_2 = TestStubs.User({
- id: '2',
- name: 'John Smith',
- email: 'johnsmith@example.com',
- });
- USER_3 = TestStubs.User({
- id: '3',
- name: 'J J',
- email: 'jj@example.com',
- });
- TEAM_1 = TestStubs.Team({
- id: '3',
- name: 'COOL TEAM',
- slug: 'cool-team',
- });
- PROJECT_1 = TestStubs.Project({
- teams: [TEAM_1],
- });
- GROUP_1 = TestStubs.Group({
- id: '1337',
- project: {
- id: PROJECT_1.id,
- slug: PROJECT_1.slug,
- },
- });
- sandbox.stub(MemberListStore, 'getAll').returns(null);
- sandbox.stub(TeamStore, 'getAll').returns([TEAM_1]);
- sandbox.stub(ProjectsStore, 'getAll').returns([PROJECT_1]);
- sandbox.stub(GroupStore, 'get').returns(GROUP_1);
- assignMock = Client.addMockResponse({
- method: 'PUT',
- url: `/issues/${GROUP_1.id}/`,
- body: {
- ...GROUP_1,
- assignedTo: USER_1,
- },
- });
- MemberListStore.items = null;
- MemberListStore.loaded = false;
- assigneeSelector = mount(
- <AssigneeSelectorComponent id={GROUP_1.id} />,
- TestStubs.routerContext()
- );
- openMenu = () => assigneeSelector.find('DropdownButton').simulate('click');
- });
- afterEach(function() {
- sandbox.restore();
- Client.clearMockResponses();
- });
- describe('putSessionUserFirst()', function() {
- const putSessionUserFirst = AssigneeSelectorComponent.putSessionUserFirst;
- it('should place the session user at the top of the member list if present', function() {
- sandbox
- .stub(ConfigStore, 'get')
- .withArgs('user')
- .returns({
- id: '2',
- name: 'John Smith',
- email: 'johnsmith@example.com',
- });
- expect(putSessionUserFirst([USER_1, USER_2])).toEqual([USER_2, USER_1]);
- });
- it("should return the same member list if the session user isn't present", function() {
- sandbox
- .stub(ConfigStore, 'get')
- .withArgs('user')
- .returns({
- id: '555',
- name: 'Here Comes a New Challenger',
- email: 'guile@mail.us.af.mil',
- });
- expect(putSessionUserFirst([USER_1, USER_2])).toEqual([USER_1, USER_2]);
- });
- });
- it('should initially have loading state', function() {
- openMenu();
- expect(assigneeSelector.find('LoadingIndicator')).toHaveLength(1);
- });
- it('does not have loading state and shows member list after calling MemberListStore.loadInitialData', async function() {
- openMenu();
- MemberListStore.loadInitialData([USER_1, USER_2]);
- assigneeSelector.update();
- expect(assigneeSelector.instance().assignableTeams()).toHaveLength(1);
- expect(assigneeSelector.find('LoadingIndicator')).toHaveLength(0);
- expect(assigneeSelector.find('Avatar')).toHaveLength(3);
- expect(assigneeSelector.find('UserAvatar')).toHaveLength(2);
- expect(assigneeSelector.find('TeamAvatar')).toHaveLength(1);
- });
- it('does NOT update member list after initial load', function() {
- openMenu();
- MemberListStore.loadInitialData([USER_1, USER_2]);
- assigneeSelector.update();
- expect(assigneeSelector.find('Avatar')).toHaveLength(3);
- expect(assigneeSelector.find('LoadingIndicator').exists()).toBe(false);
- MemberListStore.loadInitialData([USER_1, USER_2, USER_3]);
- assigneeSelector.update();
- expect(assigneeSelector.find('Avatar')).toHaveLength(3);
- expect(assigneeSelector.find('LoadingIndicator').exists()).toBe(false);
- });
- it('successfully assigns users', async function() {
- openMenu();
- MemberListStore.loadInitialData([USER_1, USER_2]);
- assigneeSelector.update();
- expect(assigneeSelector.find('LoadingIndicator').exists()).toBe(false);
- assigneeSelector
- .find('UserAvatar')
- .first()
- .simulate('click');
- expect(assignMock).toHaveBeenLastCalledWith(
- '/issues/1337/',
- expect.objectContaining({
- data: {assignedTo: 'user:1'},
- })
- );
- assigneeSelector.update();
- expect(assigneeSelector.find('LoadingIndicator')).toHaveLength(1);
- // Flakey with 1 tick
- await tick();
- await tick();
- assigneeSelector.update();
- expect(assigneeSelector.find('LoadingIndicator')).toHaveLength(0);
- expect(assigneeSelector.find('ActorAvatar')).toHaveLength(1);
- });
- it('successfully assigns teams', async function() {
- openMenu();
- MemberListStore.loadInitialData([USER_1, USER_2]);
- assigneeSelector.update();
- expect(assigneeSelector.find('LoadingIndicator').exists()).toBe(false);
- assigneeSelector
- .find('TeamAvatar')
- .first()
- .simulate('click');
- assigneeSelector.update();
- expect(assigneeSelector.find('LoadingIndicator').exists()).toBe(true);
- expect(assignMock).toHaveBeenCalledWith(
- '/issues/1337/',
- expect.objectContaining({
- data: {assignedTo: 'team:3'},
- })
- );
- // Flakey with 1 tick
- await tick();
- await tick();
- assigneeSelector.update();
- expect(assigneeSelector.find('LoadingIndicator').exists()).toBe(false);
- expect(assigneeSelector.find('ActorAvatar')).toHaveLength(1);
- });
- it('successfully clears assignment', async function() {
- openMenu();
- MemberListStore.loadInitialData([USER_1, USER_2]);
- // Assign first item in list, which is TEAM_1
- assigneeSelector.update();
- assigneeSelector
- .find('Avatar')
- .first()
- .simulate('click');
- assigneeSelector.update();
- expect(assigneeSelector.find('LoadingIndicator').exists()).toBe(true);
- expect(assignMock).toHaveBeenCalledWith(
- '/issues/1337/',
- expect.objectContaining({
- data: {assignedTo: 'team:3'},
- })
- );
- // Waiting for assignment to finish updating
- // Flakey with 1 tick
- await tick();
- await tick();
- assigneeSelector.update();
- openMenu();
- assigneeSelector
- .find('MenuItemWrapper[data-test-id="clear-assignee"]')
- .simulate('click');
- // api was called with empty string, clearing assignment
- expect(assignMock).toHaveBeenLastCalledWith(
- '/issues/1337/',
- expect.objectContaining({
- data: {assignedTo: ''},
- })
- );
- });
- it('shows invite member button', async function() {
- let routerContext = TestStubs.routerContext();
- openMenu();
- MemberListStore.loadInitialData([USER_1, USER_2]);
- assigneeSelector.update();
- expect(assigneeSelector.find('LoadingIndicator').exists()).toBe(false);
- expect(
- assigneeSelector.find('InviteMemberLink[data-test-id="invite-member"]')
- ).toHaveLength(0);
- assigneeSelector.unmount();
- sandbox
- .stub(ConfigStore, 'get')
- .withArgs('invitesEnabled')
- .returns(true);
- assigneeSelector = mount(
- <AssigneeSelectorComponent id={GROUP_1.id} />,
- routerContext
- );
- await tick();
- assigneeSelector.update();
- openMenu();
- expect(
- assigneeSelector.find('InviteMemberLink[data-test-id="invite-member"]')
- ).toHaveLength(1);
- });
- it('requires org:write to invite member', async function() {
- MemberListStore.loadInitialData([USER_1, USER_2]);
- sandbox
- .stub(ConfigStore, 'get')
- .withArgs('invitesEnabled')
- .returns(true);
- // Remove org:write access permission and make sure invite member button is not shown.
- assigneeSelector.unmount();
- assigneeSelector = mount(
- <AssigneeSelectorComponent id={GROUP_1.id} />,
- TestStubs.routerContext([{organization: TestStubs.Organization({access: []})}])
- );
- openMenu();
- assigneeSelector.update();
- expect(
- assigneeSelector.find('InviteMemberLink[data-test-id="invite-member"]')
- ).toHaveLength(0);
- });
- it('filters user by email and selects with keyboard', async function() {
- openMenu();
- MemberListStore.loadInitialData([USER_1, USER_2]);
- assigneeSelector.update();
- expect(assigneeSelector.find('LoadingIndicator').exists()).toBe(false);
- assigneeSelector
- .find('StyledInput')
- .simulate('change', {target: {value: 'JohnSmith@example.com'}});
- expect(assigneeSelector.find('Avatar')).toHaveLength(1);
- expect(assigneeSelector.find('Avatar').prop('user')).toEqual(USER_2);
- assigneeSelector.find('StyledInput').simulate('keyDown', {key: 'Enter'});
- assigneeSelector.update();
- expect(assignMock).toHaveBeenLastCalledWith(
- '/issues/1337/',
- expect.objectContaining({
- data: {assignedTo: 'user:2'},
- })
- );
- expect(assigneeSelector.find('LoadingIndicator')).toHaveLength(1);
- await tick();
- await tick();
- assigneeSelector.update();
- expect(assigneeSelector.find('LoadingIndicator')).toHaveLength(0);
- expect(assigneeSelector.find('ActorAvatar')).toHaveLength(1);
- });
- });
|