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.element.tagName === '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); }); }); });