308 lines
12 KiB
JavaScript
308 lines
12 KiB
JavaScript
import * as getters from '~/header_search/store/getters';
|
|
import initState from '~/header_search/store/state';
|
|
import {
|
|
MOCK_USERNAME,
|
|
MOCK_SEARCH_PATH,
|
|
MOCK_ISSUE_PATH,
|
|
MOCK_MR_PATH,
|
|
MOCK_AUTOCOMPLETE_PATH,
|
|
MOCK_SEARCH_CONTEXT,
|
|
MOCK_DEFAULT_SEARCH_OPTIONS,
|
|
MOCK_SCOPED_SEARCH_OPTIONS,
|
|
MOCK_PROJECT,
|
|
MOCK_GROUP,
|
|
MOCK_ALL_PATH,
|
|
MOCK_SEARCH,
|
|
MOCK_AUTOCOMPLETE_OPTIONS,
|
|
MOCK_GROUPED_AUTOCOMPLETE_OPTIONS,
|
|
MOCK_SORTED_AUTOCOMPLETE_OPTIONS,
|
|
} from '../mock_data';
|
|
|
|
describe('Header Search Store Getters', () => {
|
|
let state;
|
|
|
|
const createState = (initialState) => {
|
|
state = initState({
|
|
searchPath: MOCK_SEARCH_PATH,
|
|
issuesPath: MOCK_ISSUE_PATH,
|
|
mrPath: MOCK_MR_PATH,
|
|
autocompletePath: MOCK_AUTOCOMPLETE_PATH,
|
|
searchContext: MOCK_SEARCH_CONTEXT,
|
|
...initialState,
|
|
});
|
|
};
|
|
|
|
afterEach(() => {
|
|
state = null;
|
|
});
|
|
|
|
describe.each`
|
|
group | project | scope | expectedPath
|
|
${null} | ${null} | ${null} | ${`${MOCK_SEARCH_PATH}?search=${MOCK_SEARCH}&nav_source=navbar`}
|
|
${MOCK_GROUP} | ${null} | ${null} | ${`${MOCK_SEARCH_PATH}?search=${MOCK_SEARCH}&nav_source=navbar&group_id=${MOCK_GROUP.id}`}
|
|
${null} | ${MOCK_PROJECT} | ${null} | ${`${MOCK_SEARCH_PATH}?search=${MOCK_SEARCH}&nav_source=navbar&project_id=${MOCK_PROJECT.id}`}
|
|
${MOCK_GROUP} | ${MOCK_PROJECT} | ${null} | ${`${MOCK_SEARCH_PATH}?search=${MOCK_SEARCH}&nav_source=navbar&project_id=${MOCK_PROJECT.id}&group_id=${MOCK_GROUP.id}`}
|
|
${MOCK_GROUP} | ${MOCK_PROJECT} | ${'issues'} | ${`${MOCK_SEARCH_PATH}?search=${MOCK_SEARCH}&nav_source=navbar&project_id=${MOCK_PROJECT.id}&group_id=${MOCK_GROUP.id}&scope=issues`}
|
|
`('searchQuery', ({ group, project, scope, expectedPath }) => {
|
|
describe(`when group is ${group?.name}, project is ${project?.name}, and scope is ${scope}`, () => {
|
|
beforeEach(() => {
|
|
createState({
|
|
searchContext: {
|
|
group,
|
|
project,
|
|
scope,
|
|
},
|
|
});
|
|
state.search = MOCK_SEARCH;
|
|
});
|
|
|
|
it(`should return ${expectedPath}`, () => {
|
|
expect(getters.searchQuery(state)).toBe(expectedPath);
|
|
});
|
|
});
|
|
});
|
|
|
|
describe.each`
|
|
project | ref | expectedPath
|
|
${null} | ${null} | ${`${MOCK_AUTOCOMPLETE_PATH}?term=${MOCK_SEARCH}`}
|
|
${MOCK_PROJECT} | ${null} | ${`${MOCK_AUTOCOMPLETE_PATH}?term=${MOCK_SEARCH}&project_id=${MOCK_PROJECT.id}`}
|
|
${null} | ${MOCK_PROJECT.id} | ${`${MOCK_AUTOCOMPLETE_PATH}?term=${MOCK_SEARCH}&project_ref=${MOCK_PROJECT.id}`}
|
|
${MOCK_PROJECT} | ${MOCK_PROJECT.id} | ${`${MOCK_AUTOCOMPLETE_PATH}?term=${MOCK_SEARCH}&project_id=${MOCK_PROJECT.id}&project_ref=${MOCK_PROJECT.id}`}
|
|
`('autocompleteQuery', ({ project, ref, expectedPath }) => {
|
|
describe(`when project is ${project?.name} and project ref is ${ref}`, () => {
|
|
beforeEach(() => {
|
|
createState({
|
|
searchContext: {
|
|
project,
|
|
ref,
|
|
},
|
|
});
|
|
state.search = MOCK_SEARCH;
|
|
});
|
|
|
|
it(`should return ${expectedPath}`, () => {
|
|
expect(getters.autocompleteQuery(state)).toBe(expectedPath);
|
|
});
|
|
});
|
|
});
|
|
|
|
describe.each`
|
|
group | group_metadata | project | project_metadata | expectedPath
|
|
${null} | ${null} | ${null} | ${null} | ${MOCK_ISSUE_PATH}
|
|
${{ name: 'Test Group' }} | ${{ issues_path: 'group/path' }} | ${null} | ${null} | ${'group/path'}
|
|
${{ name: 'Test Group' }} | ${{ issues_path: 'group/path' }} | ${{ name: 'Test Project' }} | ${{ issues_path: 'project/path' }} | ${'project/path'}
|
|
`('scopedIssuesPath', ({ group, group_metadata, project, project_metadata, expectedPath }) => {
|
|
describe(`when group is ${group?.name} and project is ${project?.name}`, () => {
|
|
beforeEach(() => {
|
|
createState({
|
|
searchContext: {
|
|
group,
|
|
group_metadata,
|
|
project,
|
|
project_metadata,
|
|
},
|
|
});
|
|
});
|
|
|
|
it(`should return ${expectedPath}`, () => {
|
|
expect(getters.scopedIssuesPath(state)).toBe(expectedPath);
|
|
});
|
|
});
|
|
});
|
|
|
|
describe.each`
|
|
group | group_metadata | project | project_metadata | expectedPath
|
|
${null} | ${null} | ${null} | ${null} | ${MOCK_MR_PATH}
|
|
${{ name: 'Test Group' }} | ${{ mr_path: 'group/path' }} | ${null} | ${null} | ${'group/path'}
|
|
${{ name: 'Test Group' }} | ${{ mr_path: 'group/path' }} | ${{ name: 'Test Project' }} | ${{ mr_path: 'project/path' }} | ${'project/path'}
|
|
`('scopedMRPath', ({ group, group_metadata, project, project_metadata, expectedPath }) => {
|
|
describe(`when group is ${group?.name} and project is ${project?.name}`, () => {
|
|
beforeEach(() => {
|
|
createState({
|
|
searchContext: {
|
|
group,
|
|
group_metadata,
|
|
project,
|
|
project_metadata,
|
|
},
|
|
});
|
|
});
|
|
|
|
it(`should return ${expectedPath}`, () => {
|
|
expect(getters.scopedMRPath(state)).toBe(expectedPath);
|
|
});
|
|
});
|
|
});
|
|
|
|
describe.each`
|
|
group | project | scope | expectedPath
|
|
${null} | ${null} | ${null} | ${`${MOCK_SEARCH_PATH}?search=${MOCK_SEARCH}&nav_source=navbar`}
|
|
${MOCK_GROUP} | ${null} | ${null} | ${`${MOCK_SEARCH_PATH}?search=${MOCK_SEARCH}&nav_source=navbar&group_id=${MOCK_GROUP.id}`}
|
|
${null} | ${MOCK_PROJECT} | ${null} | ${`${MOCK_SEARCH_PATH}?search=${MOCK_SEARCH}&nav_source=navbar&project_id=${MOCK_PROJECT.id}`}
|
|
${MOCK_GROUP} | ${MOCK_PROJECT} | ${null} | ${`${MOCK_SEARCH_PATH}?search=${MOCK_SEARCH}&nav_source=navbar&project_id=${MOCK_PROJECT.id}&group_id=${MOCK_GROUP.id}`}
|
|
${MOCK_GROUP} | ${MOCK_PROJECT} | ${'issues'} | ${`${MOCK_SEARCH_PATH}?search=${MOCK_SEARCH}&nav_source=navbar&project_id=${MOCK_PROJECT.id}&group_id=${MOCK_GROUP.id}&scope=issues`}
|
|
`('projectUrl', ({ group, project, scope, expectedPath }) => {
|
|
describe(`when group is ${group?.name}, project is ${project?.name}, and scope is ${scope}`, () => {
|
|
beforeEach(() => {
|
|
createState({
|
|
searchContext: {
|
|
group,
|
|
project,
|
|
scope,
|
|
},
|
|
});
|
|
state.search = MOCK_SEARCH;
|
|
});
|
|
|
|
it(`should return ${expectedPath}`, () => {
|
|
expect(getters.projectUrl(state)).toBe(expectedPath);
|
|
});
|
|
});
|
|
});
|
|
|
|
describe.each`
|
|
group | project | scope | expectedPath
|
|
${null} | ${null} | ${null} | ${`${MOCK_SEARCH_PATH}?search=${MOCK_SEARCH}&nav_source=navbar`}
|
|
${MOCK_GROUP} | ${null} | ${null} | ${`${MOCK_SEARCH_PATH}?search=${MOCK_SEARCH}&nav_source=navbar&group_id=${MOCK_GROUP.id}`}
|
|
${null} | ${MOCK_PROJECT} | ${null} | ${`${MOCK_SEARCH_PATH}?search=${MOCK_SEARCH}&nav_source=navbar`}
|
|
${MOCK_GROUP} | ${MOCK_PROJECT} | ${null} | ${`${MOCK_SEARCH_PATH}?search=${MOCK_SEARCH}&nav_source=navbar&group_id=${MOCK_GROUP.id}`}
|
|
${MOCK_GROUP} | ${MOCK_PROJECT} | ${'issues'} | ${`${MOCK_SEARCH_PATH}?search=${MOCK_SEARCH}&nav_source=navbar&group_id=${MOCK_GROUP.id}&scope=issues`}
|
|
`('groupUrl', ({ group, project, scope, expectedPath }) => {
|
|
describe(`when group is ${group?.name}, project is ${project?.name}, and scope is ${scope}`, () => {
|
|
beforeEach(() => {
|
|
createState({
|
|
searchContext: {
|
|
group,
|
|
project,
|
|
scope,
|
|
},
|
|
});
|
|
state.search = MOCK_SEARCH;
|
|
});
|
|
|
|
it(`should return ${expectedPath}`, () => {
|
|
expect(getters.groupUrl(state)).toBe(expectedPath);
|
|
});
|
|
});
|
|
});
|
|
|
|
describe.each`
|
|
group | project | scope | expectedPath
|
|
${null} | ${null} | ${null} | ${`${MOCK_SEARCH_PATH}?search=${MOCK_SEARCH}&nav_source=navbar`}
|
|
${MOCK_GROUP} | ${null} | ${null} | ${`${MOCK_SEARCH_PATH}?search=${MOCK_SEARCH}&nav_source=navbar`}
|
|
${null} | ${MOCK_PROJECT} | ${null} | ${`${MOCK_SEARCH_PATH}?search=${MOCK_SEARCH}&nav_source=navbar`}
|
|
${MOCK_GROUP} | ${MOCK_PROJECT} | ${null} | ${`${MOCK_SEARCH_PATH}?search=${MOCK_SEARCH}&nav_source=navbar`}
|
|
${MOCK_GROUP} | ${MOCK_PROJECT} | ${'issues'} | ${`${MOCK_SEARCH_PATH}?search=${MOCK_SEARCH}&nav_source=navbar&scope=issues`}
|
|
`('allUrl', ({ group, project, scope, expectedPath }) => {
|
|
describe(`when group is ${group?.name}, project is ${project?.name}, and scope is ${scope}`, () => {
|
|
beforeEach(() => {
|
|
createState({
|
|
searchContext: {
|
|
group,
|
|
project,
|
|
scope,
|
|
},
|
|
});
|
|
state.search = MOCK_SEARCH;
|
|
});
|
|
|
|
it(`should return ${expectedPath}`, () => {
|
|
expect(getters.allUrl(state)).toBe(expectedPath);
|
|
});
|
|
});
|
|
});
|
|
|
|
describe('defaultSearchOptions', () => {
|
|
const mockGetters = {
|
|
scopedIssuesPath: MOCK_ISSUE_PATH,
|
|
scopedMRPath: MOCK_MR_PATH,
|
|
};
|
|
|
|
beforeEach(() => {
|
|
createState();
|
|
window.gon.current_username = MOCK_USERNAME;
|
|
});
|
|
|
|
it('returns the correct array', () => {
|
|
expect(getters.defaultSearchOptions(state, mockGetters)).toStrictEqual(
|
|
MOCK_DEFAULT_SEARCH_OPTIONS,
|
|
);
|
|
});
|
|
});
|
|
|
|
describe('scopedSearchOptions', () => {
|
|
const mockGetters = {
|
|
projectUrl: MOCK_PROJECT.path,
|
|
groupUrl: MOCK_GROUP.path,
|
|
allUrl: MOCK_ALL_PATH,
|
|
};
|
|
|
|
beforeEach(() => {
|
|
createState({
|
|
searchContext: {
|
|
project: MOCK_PROJECT,
|
|
group: MOCK_GROUP,
|
|
},
|
|
});
|
|
});
|
|
|
|
it('returns the correct array', () => {
|
|
expect(getters.scopedSearchOptions(state, mockGetters)).toStrictEqual(
|
|
MOCK_SCOPED_SEARCH_OPTIONS,
|
|
);
|
|
});
|
|
});
|
|
|
|
describe('autocompleteGroupedSearchOptions', () => {
|
|
beforeEach(() => {
|
|
createState();
|
|
state.autocompleteOptions = MOCK_AUTOCOMPLETE_OPTIONS;
|
|
});
|
|
|
|
it('returns the correct grouped array', () => {
|
|
expect(getters.autocompleteGroupedSearchOptions(state)).toStrictEqual(
|
|
MOCK_GROUPED_AUTOCOMPLETE_OPTIONS,
|
|
);
|
|
});
|
|
});
|
|
|
|
describe.each`
|
|
search | defaultSearchOptions | scopedSearchOptions | autocompleteGroupedSearchOptions | expectedArray
|
|
${null} | ${MOCK_DEFAULT_SEARCH_OPTIONS} | ${MOCK_SCOPED_SEARCH_OPTIONS} | ${MOCK_GROUPED_AUTOCOMPLETE_OPTIONS} | ${MOCK_DEFAULT_SEARCH_OPTIONS}
|
|
${MOCK_SEARCH} | ${MOCK_DEFAULT_SEARCH_OPTIONS} | ${MOCK_SCOPED_SEARCH_OPTIONS} | ${[]} | ${MOCK_SCOPED_SEARCH_OPTIONS}
|
|
${MOCK_SEARCH} | ${MOCK_DEFAULT_SEARCH_OPTIONS} | ${[]} | ${MOCK_GROUPED_AUTOCOMPLETE_OPTIONS} | ${MOCK_SORTED_AUTOCOMPLETE_OPTIONS}
|
|
${MOCK_SEARCH} | ${MOCK_DEFAULT_SEARCH_OPTIONS} | ${MOCK_SCOPED_SEARCH_OPTIONS} | ${MOCK_GROUPED_AUTOCOMPLETE_OPTIONS} | ${MOCK_SCOPED_SEARCH_OPTIONS.concat(MOCK_SORTED_AUTOCOMPLETE_OPTIONS)}
|
|
`(
|
|
'searchOptions',
|
|
({
|
|
search,
|
|
defaultSearchOptions,
|
|
scopedSearchOptions,
|
|
autocompleteGroupedSearchOptions,
|
|
expectedArray,
|
|
}) => {
|
|
describe(`when search is ${search} and the defaultSearchOptions${
|
|
defaultSearchOptions.length ? '' : ' do not'
|
|
} exist, scopedSearchOptions${
|
|
scopedSearchOptions.length ? '' : ' do not'
|
|
} exist, and autocompleteGroupedSearchOptions${
|
|
autocompleteGroupedSearchOptions.length ? '' : ' do not'
|
|
} exist`, () => {
|
|
const mockGetters = {
|
|
defaultSearchOptions,
|
|
scopedSearchOptions,
|
|
autocompleteGroupedSearchOptions,
|
|
};
|
|
|
|
beforeEach(() => {
|
|
createState();
|
|
state.search = search;
|
|
});
|
|
|
|
it(`should return the correct combined array`, () => {
|
|
expect(getters.searchOptions(state, mockGetters)).toStrictEqual(expectedArray);
|
|
});
|
|
});
|
|
},
|
|
);
|
|
});
|