import { mount } from '@vue/test-utils'; import orderedLayout from '~/vue_shared/components/ordered_layout.vue'; const children = ` `; const TestComponent = { components: { orderedLayout }, template: `
${children}
`, }; const regularSlotOrder = ['header', 'footer']; describe('Ordered Layout', () => { let wrapper; const verifyOrder = () => wrapper.findAll('footer,header').wrappers.map(x => (x.is('footer') ? 'footer' : 'header')); const createComponent = (props = {}) => { wrapper = mount(TestComponent, { propsData: props, }); }; afterEach(() => { wrapper.destroy(); }); describe('when slotKeys are in initial slot order', () => { beforeEach(() => { createComponent({ slotKeys: regularSlotOrder }); }); it('confirms order of the component is reflective of slotKeys', () => { expect(verifyOrder()).toEqual(regularSlotOrder); }); }); describe('when slotKeys reverse the order of the props', () => { const reversedSlotOrder = regularSlotOrder.reverse(); beforeEach(() => { createComponent({ slotKeys: reversedSlotOrder }); }); it('confirms order of the component is reflective of slotKeys', () => { expect(verifyOrder()).toEqual(reversedSlotOrder); }); }); });