UNPKG

bootstrap-vue

Version:

With more than 85 components, over 45 available plugins, several directives, and 1000+ icons, BootstrapVue provides one of the most comprehensive implementations of the Bootstrap v4 component and grid system available for Vue.js v2.6, complete with extens

163 lines (138 loc) 5.08 kB
import { mount } from '@vue/test-utils' import { BMedia } from './media' describe('media', () => { it('has expected default structure', async () => { const wrapper = mount(BMedia) expect(wrapper.element.tagName).toBe('DIV') expect(wrapper.classes()).toContain('media') expect(wrapper.classes().length).toBe(1) expect(wrapper.findAll('.media-body').length).toBe(1) expect(wrapper.findAll('.d-flex').length).toBe(0) expect(wrapper.text()).toEqual('') // Should have only one child element expect(wrapper.findAll('.media > *').length).toBe(1) wrapper.destroy() }) it('renders custom root element when tag prop set', async () => { const wrapper = mount(BMedia, { propsData: { tag: 'section' } }) expect(wrapper.element.tagName).toBe('SECTION') expect(wrapper.classes()).toContain('media') expect(wrapper.classes().length).toBe(1) wrapper.destroy() }) it('has expected structure when slot aside present', async () => { const wrapper = mount(BMedia, { slots: { aside: 'foobar' } }) expect(wrapper.element.tagName).toBe('DIV') expect(wrapper.classes()).toContain('media') expect(wrapper.classes().length).toBe(1) expect(wrapper.findAll('.media-body').length).toBe(1) expect(wrapper.findAll('.d-flex').length).toBe(1) // Should have only two child elements expect(wrapper.findAll('.media > *').length).toBe(2) // Has expected child order expect(wrapper.find('.media > .d-flex + .media-body').exists()).toBe(true) expect(wrapper.find('.media > .media-body + .d-flex').exists()).toBe(false) // Aside has extra classes expect(wrapper.find('.d-flex').classes()).toContain('mr-3') wrapper.destroy() }) it('has expected structure when prop right-align is set and slot aside present', async () => { const wrapper = mount(BMedia, { propsData: { rightAlign: true }, slots: { aside: 'foobar' } }) expect(wrapper.element.tagName).toBe('DIV') expect(wrapper.classes()).toContain('media') expect(wrapper.classes().length).toBe(1) expect(wrapper.findAll('.media-body').length).toBe(1) expect(wrapper.findAll('.d-flex').length).toBe(1) // Should have only two child elements expect(wrapper.findAll('.media > *').length).toBe(2) // Has expected child order expect(wrapper.find('.media > .media-body + .d-flex').exists()).toBe(true) expect(wrapper.find('.media > .d-flex + .media-body').exists()).toBe(false) // Aside has extra classes expect(wrapper.find('.d-flex').classes()).toContain('ml-3') wrapper.destroy() }) it('places default slot inside media-body', async () => { const wrapper = mount(BMedia, { slots: { default: '<b>foobar</b>' } }) expect(wrapper.element.tagName).toBe('DIV') expect(wrapper.classes()).toContain('media') expect(wrapper.classes().length).toBe(1) expect(wrapper.findAll('.media-body').length).toBe(1) expect(wrapper.text()).toEqual('foobar') expect(wrapper.find('.media-body').text()).toEqual('foobar') wrapper.destroy() }) it('does not have child media-body is prop no-body set', async () => { const wrapper = mount(BMedia, { propsData: { noBody: true } }) expect(wrapper.element.tagName).toBe('DIV') expect(wrapper.classes()).toContain('media') expect(wrapper.classes().length).toBe(1) expect(wrapper.findAll('.media-body').length).toBe(0) expect(wrapper.text()).toEqual('') // Should have no child elements expect(wrapper.findAll('.media > *').length).toBe(0) wrapper.destroy() }) it('places default slot inside self when no-body set', async () => { const wrapper = mount(BMedia, { propsData: { noBody: true }, slots: { default: '<b>foobar</b>' } }) expect(wrapper.element.tagName).toBe('DIV') expect(wrapper.classes()).toContain('media') expect(wrapper.classes().length).toBe(1) expect(wrapper.findAll('.media-body').length).toBe(0) expect(wrapper.text()).toEqual('foobar') wrapper.destroy() }) it('sets verticalAlign prop on media-aside child', async () => { const wrapper = mount(BMedia, { propsData: { verticalAlign: 'bottom' }, slots: { aside: 'foobar' } }) expect(wrapper.element.tagName).toBe('DIV') expect(wrapper.classes()).toContain('media') expect(wrapper.classes().length).toBe(1) expect(wrapper.findAll('.media-body').length).toBe(1) expect(wrapper.findAll('.d-flex').length).toBe(1) expect(wrapper.text()).toEqual('foobar') // Should have only two child elements expect(wrapper.findAll('.media > *').length).toBe(2) // Should have media aside with self align bottom expect(wrapper.find('.d-flex').classes()).toContain('align-self-end') // Should have content in aside expect(wrapper.find('.d-flex').text()).toEqual('foobar') wrapper.destroy() }) })