debian-mirror-gitlab/spec/javascripts/frequent_items/components/frequent_items_list_item_spec.js

96 lines
3.1 KiB
JavaScript
Raw Normal View History

2018-03-17 18:26:18 +05:30
import Vue from 'vue';
2018-11-08 19:23:39 +05:30
import frequentItemsListItemComponent from '~/frequent_items/components/frequent_items_list_item.vue';
2019-07-07 11:18:12 +05:30
import { shallowMount } from '@vue/test-utils';
import { trimText } from 'spec/helpers/vue_component_helper';
2018-11-08 19:23:39 +05:30
import { mockProject } from '../mock_data'; // can also use 'mockGroup', but not useful to test here
2018-03-17 18:26:18 +05:30
const createComponent = () => {
2018-11-08 19:23:39 +05:30
const Component = Vue.extend(frequentItemsListItemComponent);
2018-03-17 18:26:18 +05:30
2019-07-07 11:18:12 +05:30
return shallowMount(Component, {
propsData: {
itemId: mockProject.id,
itemName: mockProject.name,
namespace: mockProject.namespace,
webUrl: mockProject.webUrl,
avatarUrl: mockProject.avatarUrl,
},
2018-03-17 18:26:18 +05:30
});
};
2018-11-08 19:23:39 +05:30
describe('FrequentItemsListItemComponent', () => {
2019-07-07 11:18:12 +05:30
let wrapper;
2018-03-17 18:26:18 +05:30
let vm;
beforeEach(() => {
2019-07-07 11:18:12 +05:30
wrapper = createComponent();
({ vm } = wrapper);
2018-03-17 18:26:18 +05:30
});
afterEach(() => {
vm.$destroy();
});
describe('computed', () => {
describe('hasAvatar', () => {
it('should return `true` or `false` if whether avatar is present or not', () => {
2019-07-07 11:18:12 +05:30
wrapper.setProps({ avatarUrl: 'path/to/avatar.png' });
2018-12-13 13:39:08 +05:30
2018-11-08 19:23:39 +05:30
expect(vm.hasAvatar).toBe(true);
2018-03-17 18:26:18 +05:30
2019-07-07 11:18:12 +05:30
wrapper.setProps({ avatarUrl: null });
2018-12-13 13:39:08 +05:30
2018-11-08 19:23:39 +05:30
expect(vm.hasAvatar).toBe(false);
2018-03-17 18:26:18 +05:30
});
});
2018-11-08 19:23:39 +05:30
describe('highlightedItemName', () => {
2018-03-17 18:26:18 +05:30
it('should enclose part of project name in <b> & </b> which matches with `matcher` prop', () => {
2019-07-07 11:18:12 +05:30
wrapper.setProps({ matcher: 'lab' });
2018-12-13 13:39:08 +05:30
2019-07-07 11:18:12 +05:30
expect(wrapper.find('.js-frequent-items-item-title').html()).toContain(
'<b>L</b><b>a</b><b>b</b>',
);
2018-03-17 18:26:18 +05:30
});
it('should return project name as it is if `matcher` is not available', () => {
2019-07-07 11:18:12 +05:30
wrapper.setProps({ matcher: null });
2018-12-13 13:39:08 +05:30
2019-07-07 11:18:12 +05:30
expect(trimText(wrapper.find('.js-frequent-items-item-title').text())).toBe(
mockProject.name,
);
2018-03-17 18:26:18 +05:30
});
});
describe('truncatedNamespace', () => {
it('should truncate project name from namespace string', () => {
2019-07-07 11:18:12 +05:30
wrapper.setProps({ namespace: 'platform / nokia-3310' });
2018-12-13 13:39:08 +05:30
2019-07-07 11:18:12 +05:30
expect(trimText(wrapper.find('.js-frequent-items-item-namespace').text())).toBe('platform');
2018-03-17 18:26:18 +05:30
});
it('should truncate namespace string from the middle if it includes more than two groups in path', () => {
2019-07-07 11:18:12 +05:30
wrapper.setProps({
namespace: 'platform / hardware / broadcom / Wifi Group / Mobile Chipset / nokia-3310',
});
2018-12-13 13:39:08 +05:30
2019-07-07 11:18:12 +05:30
expect(trimText(wrapper.find('.js-frequent-items-item-namespace').text())).toBe(
'platform / ... / Mobile Chipset',
);
2018-03-17 18:26:18 +05:30
});
});
});
describe('template', () => {
it('should render component element', () => {
2019-07-07 11:18:12 +05:30
expect(wrapper.classes()).toContain('frequent-items-list-item-container');
expect(wrapper.findAll('a').length).toBe(1);
expect(wrapper.findAll('.frequent-items-item-avatar-container').length).toBe(1);
expect(wrapper.findAll('.frequent-items-item-metadata-container').length).toBe(1);
expect(wrapper.findAll('.frequent-items-item-title').length).toBe(1);
expect(wrapper.findAll('.frequent-items-item-namespace').length).toBe(1);
2018-03-17 18:26:18 +05:30
});
});
});