111 lines
3.2 KiB
JavaScript
111 lines
3.2 KiB
JavaScript
import { GlNav, GlNavItem, GlIcon } from '@gitlab/ui';
|
|
import { shallowMount } from '@vue/test-utils';
|
|
import Vue from 'vue';
|
|
import Vuex from 'vuex';
|
|
import { MOCK_QUERY, MOCK_NAVIGATION } from 'jest/search/mock_data';
|
|
import ScopeNavigation from '~/search/sidebar/components/scope_navigation.vue';
|
|
|
|
Vue.use(Vuex);
|
|
|
|
describe('ScopeNavigation', () => {
|
|
let wrapper;
|
|
|
|
const actionSpies = {
|
|
fetchSidebarCount: jest.fn(),
|
|
};
|
|
|
|
const createComponent = (initialState) => {
|
|
const store = new Vuex.Store({
|
|
state: {
|
|
urlQuery: MOCK_QUERY,
|
|
navigation: MOCK_NAVIGATION,
|
|
...initialState,
|
|
},
|
|
actions: actionSpies,
|
|
});
|
|
|
|
wrapper = shallowMount(ScopeNavigation, {
|
|
store,
|
|
});
|
|
};
|
|
|
|
afterEach(() => {
|
|
wrapper.destroy();
|
|
});
|
|
|
|
const findNavElement = () => wrapper.find('nav');
|
|
const findGlNav = () => wrapper.findComponent(GlNav);
|
|
const findGlNavItems = () => wrapper.findAllComponents(GlNavItem);
|
|
const findGlNavItemActive = () => findGlNavItems().wrappers.filter((w) => w.attributes('active'));
|
|
const findGlNavItemActiveLabel = () => findGlNavItemActive().at(0).findAll('span').at(0).text();
|
|
const findGlNavItemActiveCount = () => findGlNavItemActive().at(0).findAll('span').at(1);
|
|
|
|
describe('scope navigation', () => {
|
|
beforeEach(() => {
|
|
createComponent();
|
|
});
|
|
|
|
it('renders section', () => {
|
|
expect(findNavElement().exists()).toBe(true);
|
|
});
|
|
|
|
it('renders nav component', () => {
|
|
expect(findGlNav().exists()).toBe(true);
|
|
});
|
|
|
|
it('renders all nav item components', () => {
|
|
expect(findGlNavItems()).toHaveLength(9);
|
|
});
|
|
|
|
it('has all proper links', () => {
|
|
const linkAtPosition = 3;
|
|
const { link } = MOCK_NAVIGATION[Object.keys(MOCK_NAVIGATION)[linkAtPosition]];
|
|
|
|
expect(findGlNavItems().at(linkAtPosition).attributes('href')).toBe(link);
|
|
});
|
|
});
|
|
|
|
describe('scope navigation sets proper state with url scope set', () => {
|
|
beforeEach(() => {
|
|
createComponent();
|
|
});
|
|
|
|
it('has correct active item', () => {
|
|
expect(findGlNavItemActive()).toHaveLength(1);
|
|
expect(findGlNavItemActiveLabel()).toBe('Issues');
|
|
});
|
|
|
|
it('has correct active item count', () => {
|
|
expect(findGlNavItemActiveCount().text()).toBe('2.4K');
|
|
});
|
|
|
|
it('does not have plus sign after count text', () => {
|
|
expect(findGlNavItemActive().at(0).findComponent(GlIcon).exists()).toBe(false);
|
|
});
|
|
|
|
it('has count is highlighted correctly', () => {
|
|
expect(findGlNavItemActiveCount().classes('gl-text-gray-900')).toBe(true);
|
|
});
|
|
});
|
|
|
|
describe('scope navigation sets proper state with NO url scope set', () => {
|
|
beforeEach(() => {
|
|
createComponent({
|
|
urlQuery: {},
|
|
});
|
|
});
|
|
|
|
it('has correct active item', () => {
|
|
expect(findGlNavItems().at(0).attributes('active')).toBe('true');
|
|
expect(findGlNavItemActiveLabel()).toBe('Projects');
|
|
});
|
|
|
|
it('has correct active item count', () => {
|
|
expect(findGlNavItemActiveCount().text()).toBe('10K');
|
|
});
|
|
|
|
it('has correct active item count and over limit sign', () => {
|
|
expect(findGlNavItemActive().at(0).findComponent(GlIcon).exists()).toBe(true);
|
|
});
|
|
});
|
|
});
|