mirror of
https://github.com/primefaces/primevue.git
synced 2025-05-09 00:42:36 +00:00
Fixed #3802 - Improve folder structure for nuxt configurations
This commit is contained in:
parent
851950270b
commit
f5fe822afb
563 changed files with 1703 additions and 1095 deletions
122
components/lib/sidebar/Sidebar.spec.js
Normal file
122
components/lib/sidebar/Sidebar.spec.js
Normal file
|
@ -0,0 +1,122 @@
|
|||
import { mount } from '@vue/test-utils';
|
||||
import PrimeVue from 'primevue/config';
|
||||
import { describe, expect, it } from 'vitest';
|
||||
import DomHandler from '../utils/DomHandler';
|
||||
import Sidebar from './Sidebar.vue';
|
||||
describe('Sidebar.vue', () => {
|
||||
let wrapper;
|
||||
|
||||
beforeEach(async () => {
|
||||
wrapper = mount(Sidebar, {
|
||||
global: {
|
||||
plugins: [PrimeVue],
|
||||
stubs: {
|
||||
teleport: true
|
||||
}
|
||||
},
|
||||
props: {
|
||||
visible: true,
|
||||
bazeZIndex: 1000
|
||||
},
|
||||
slots: {
|
||||
default: `<h3>Left Sidebar</h3>`,
|
||||
header: `<span class="header">Header Template</span>`
|
||||
}
|
||||
});
|
||||
});
|
||||
|
||||
afterEach(() => {
|
||||
vi.clearAllMocks();
|
||||
});
|
||||
|
||||
it('When mask element triggered, sidebar should be hide', async () => {
|
||||
const hideSpy = vi.spyOn(wrapper.vm, 'hide');
|
||||
|
||||
await wrapper.find('.p-sidebar-mask').trigger('mousedown');
|
||||
|
||||
expect(wrapper.emitted()['update:visible'].length).toBe(1);
|
||||
expect(hideSpy).toHaveBeenCalled();
|
||||
});
|
||||
|
||||
it('When transition trigger to onEnter, sidebar should be visible', async () => {
|
||||
const focusSpy = vi.spyOn(wrapper.vm, 'focus');
|
||||
|
||||
await wrapper.vm.onEnter();
|
||||
|
||||
expect(wrapper.emitted().show.length).toBe(1);
|
||||
expect(wrapper.vm.containerVisible).toBeTruthy();
|
||||
expect(focusSpy).toHaveBeenCalled();
|
||||
});
|
||||
|
||||
it('When transition trigger to onLeave, hide should be triggered', async () => {
|
||||
await wrapper.vm.onLeave();
|
||||
|
||||
expect(wrapper.emitted().hide.length).toBe(1);
|
||||
});
|
||||
|
||||
it('When transition trigger to onAfterEnter, enableDocumentSettings should be triggered', async () => {
|
||||
const enableDocumentSettingsSpy = vi.spyOn(wrapper.vm, 'enableDocumentSettings');
|
||||
|
||||
await wrapper.vm.onAfterEnter();
|
||||
|
||||
expect(enableDocumentSettingsSpy).toHaveBeenCalled();
|
||||
});
|
||||
|
||||
it('When keydown is triggered , hide method should be triggered', async () => {
|
||||
const hideSpy = vi.spyOn(wrapper.vm, 'hide');
|
||||
|
||||
await wrapper.find('.p-sidebar').trigger('keydown', { code: 'Escape' });
|
||||
|
||||
expect(hideSpy).toHaveBeenCalled();
|
||||
});
|
||||
|
||||
it('When keydown is triggered , hide method should be triggered', async () => {
|
||||
const hideSpy = vi.spyOn(wrapper.vm, 'hide');
|
||||
|
||||
await wrapper.find('.p-sidebar-close').trigger('click');
|
||||
|
||||
expect(hideSpy).toHaveBeenCalled();
|
||||
});
|
||||
|
||||
it('When component is unmount , unbindOutsideClickListenerSpy method should be triggered', async () => {
|
||||
const unbindOutsideClickListenerSpy = vi.spyOn(wrapper.vm, 'unbindOutsideClickListener');
|
||||
|
||||
await wrapper.unmount();
|
||||
|
||||
expect(unbindOutsideClickListenerSpy).toHaveBeenCalled();
|
||||
expect(Sidebar.container).toBe(null);
|
||||
});
|
||||
|
||||
it('When hide is triggered , removeClass util should be called', async () => {
|
||||
const removeClassSpy = vi.spyOn(DomHandler, 'removeClass');
|
||||
|
||||
await wrapper.setProps({ blockScroll: true });
|
||||
wrapper.vm.disableDocumentSettings();
|
||||
|
||||
expect(removeClassSpy).toHaveBeenCalled();
|
||||
});
|
||||
|
||||
it('When onEnter is triggered , addClass util should be called', async () => {
|
||||
const addClassSpy = vi.spyOn(DomHandler, 'addClass');
|
||||
|
||||
await wrapper.setProps({ blockScroll: true });
|
||||
wrapper.vm.enableDocumentSettings();
|
||||
|
||||
expect(addClassSpy).toHaveBeenCalled();
|
||||
});
|
||||
|
||||
it('When onBeforeLeave is triggered , addClass util should be called', async () => {
|
||||
const addClassSpy = vi.spyOn(DomHandler, 'addClass');
|
||||
|
||||
await wrapper.setProps({ modal: true });
|
||||
wrapper.vm.onBeforeLeave();
|
||||
|
||||
expect(addClassSpy).toHaveBeenCalled();
|
||||
});
|
||||
|
||||
it('When onAfterLeave is triggered , containerVisible should be false', async () => {
|
||||
wrapper.vm.onAfterLeave();
|
||||
|
||||
expect(wrapper.vm.containerVisible).toBeFalsy();
|
||||
});
|
||||
});
|
Loading…
Add table
Add a link
Reference in a new issue