1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
|
import testAction from 'helpers/vuex_action_helper';
import Api from '~/api';
import createState from '~/feature_flags/store/gitlab_user_list/state';
import { fetchUserLists, setFilter } from '~/feature_flags/store/gitlab_user_list/actions';
import * as types from '~/feature_flags/store/gitlab_user_list/mutation_types';
import { userList } from '../../mock_data';
jest.mock('~/api');
describe('~/feature_flags/store/gitlab_user_list/actions', () => {
let mockedState;
beforeEach(() => {
mockedState = createState({ projectId: '1' });
mockedState.filter = 'test';
});
describe('fetchUserLists', () => {
it('should commit FETCH_USER_LISTS and RECEIEVE_USER_LISTS_SUCCESS on success', () => {
Api.searchFeatureFlagUserLists.mockResolvedValue({ data: [userList] });
return testAction(
fetchUserLists,
undefined,
mockedState,
[
{ type: types.FETCH_USER_LISTS },
{ type: types.RECEIVE_USER_LISTS_SUCCESS, payload: [userList] },
],
[],
() => expect(Api.searchFeatureFlagUserLists).toHaveBeenCalledWith('1', 'test'),
);
});
it('should commit FETCH_USER_LISTS and RECEIEVE_USER_LISTS_ERROR on success', () => {
Api.searchFeatureFlagUserLists.mockRejectedValue({ message: 'error' });
return testAction(
fetchUserLists,
undefined,
mockedState,
[
{ type: types.FETCH_USER_LISTS },
{ type: types.RECEIVE_USER_LISTS_ERROR, payload: ['error'] },
],
[],
() => expect(Api.searchFeatureFlagUserLists).toHaveBeenCalledWith('1', 'test'),
);
});
});
describe('setFilter', () => {
it('commits SET_FILTER and fetches new user lists', () =>
testAction(
setFilter,
'filter',
mockedState,
[{ type: types.SET_FILTER, payload: 'filter' }],
[{ type: 'fetchUserLists' }],
));
});
});
|