primevue-mirror/components/megamenu/MegaMenu.spec.js

91 lines
3.3 KiB
JavaScript
Raw Normal View History

2022-09-06 12:03:37 +00:00
import { mount } from '@vue/test-utils';
import MegaMenu from './MegaMenu.vue';
describe('MegaMenu.vue', () => {
let wrapper;
beforeEach(() => {
wrapper = mount(MegaMenu, {
global: {
stubs: {
'router-link': true
}
},
props: {
model: [
{
2022-09-14 11:26:01 +00:00
label: 'Videos',
icon: 'pi pi-fw pi-video',
2022-09-06 12:03:37 +00:00
items: [
[
{
label: 'Video 1',
2022-09-14 11:26:01 +00:00
items: [{ label: 'Video 1.1' }, { label: 'Video 1.2' }]
2022-09-06 12:03:37 +00:00
},
{
label: 'Video 2',
2022-09-14 11:26:01 +00:00
items: [{ label: 'Video 2.1' }, { label: 'Video 2.2' }]
2022-09-06 12:03:37 +00:00
}
]
]
},
{
2022-09-14 11:26:01 +00:00
label: 'Users',
icon: 'pi pi-fw pi-users',
2022-09-06 12:03:37 +00:00
items: [
[
{
label: 'User 1',
2022-09-14 11:26:01 +00:00
items: [{ label: 'User 1.1' }, { label: 'User 1.2' }]
2022-09-06 12:03:37 +00:00
}
],
[
{
label: 'User 2',
2022-09-14 11:26:01 +00:00
items: [{ label: 'User 2.1' }, { label: 'User 2.2' }]
2022-09-06 12:03:37 +00:00
},
{
label: 'User 3',
2022-09-14 11:26:01 +00:00
items: [{ label: 'User 3.1' }, { label: 'User 3.2' }]
2022-09-06 12:03:37 +00:00
}
]
]
}
]
}
});
});
it('should exists', () => {
expect(wrapper.find('.p-megamenu.p-component').exists()).toBe(true);
expect(wrapper.find('.p-megamenu-root-list').exists()).toBe(true);
expect(wrapper.findAll('ul.p-megamenu-submenu').length).toBe(5);
expect(wrapper.findAll('li.p-menuitem').length).toBe(12);
expect(wrapper.findAll('li.p-menuitem')[0].findAll('span.p-menuitem-text')[0].text()).toBe('Videos');
expect(wrapper.findAll('li.p-megamenu-submenu-header')[0].text()).toBe('Video 1');
expect(wrapper.findAll('li.p-menuitem')[1].findAll('span.p-menuitem-text')[0].text()).toBe('Video 1.1');
});
it('should select item', async () => {
const firstItem = wrapper.findAll('li.p-menuitem')[0];
await wrapper.vm.onCategoryClick({}, wrapper.vm.model[0]);
expect(firstItem.classes()).toContain('p-menuitem-active');
});
it('should deselect item', async () => {
const firstItem = wrapper.findAll('li.p-menuitem')[0];
await wrapper.vm.onCategoryClick({}, wrapper.vm.model[0].items[0][0].items[0]);
expect(firstItem.classes()).not.toContain('p-menuitem-active');
});
it('should orientation work', async () => {
await wrapper.setProps({ orientation: 'vertical' });
expect(wrapper.find('.p-megamenu-vertical').exists()).toBe(true);
});
2022-09-14 11:26:01 +00:00
});