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

95 lines (87 loc) 2.75 kB
import { mount } from '@vue/test-utils' import { BTable } from './table' import { normalizeFields } from './helpers/normalize-fields' const testItems = [{ a: 1, b: 2, c: 3 }, { a: 5, b: 5, c: 6 }, { a: 7, b: 8, c: 9 }] const testFields = ['a', 'b', 'c'] describe('table > tbody bottom-row slot', () => { it('should not have bottom row by default', async () => { const wrapper = mount(BTable, { propsData: { fields: testFields, items: testItems } }) expect(wrapper).toBeDefined() expect(wrapper.element.tagName).toBe('TABLE') expect(wrapper.find('tbody').exists()).toBe(true) expect(wrapper.findAll('tbody > tr').exists()).toBe(true) expect(wrapper.findAll('tbody > tr').length).toBe(testItems.length) wrapper.destroy() }) it('should render named slot `bottom-row`', async () => { const wrapper = mount(BTable, { propsData: { fields: testFields, items: testItems }, slots: { 'bottom-row': `<td span="${testFields.length}">foobar</td>` } }) expect(wrapper).toBeDefined() expect(wrapper.element.tagName).toBe('TABLE') expect(wrapper.find('tbody').exists()).toBe(true) expect(wrapper.findAll('tbody > tr').exists()).toBe(true) expect(wrapper.findAll('tbody > tr').length).toBe(testItems.length + 1) expect( wrapper .findAll('tbody > tr') .at(testItems.length) .text() ).toBe('foobar') expect( wrapper .findAll('tbody > tr') .at(testItems.length) .classes() ).toContain('b-table-bottom-row') wrapper.destroy() }) it('should render scoped slot `bottom-row`', async () => { let fields = [] let columns const wrapper = mount(BTable, { propsData: { fields: testFields, items: testItems }, scopedSlots: { 'bottom-row': function(scope) { fields = scope.fields columns = scope.columns return this.$createElement('td', { attrs: { span: columns } }, 'foobar') } } }) expect(wrapper).toBeDefined() expect(wrapper.element.tagName).toBe('TABLE') expect(wrapper.find('tbody').exists()).toBe(true) expect(columns).toBe(3) expect(fields).toEqual(normalizeFields(testFields)) expect(wrapper.findAll('tbody > tr').exists()).toBe(true) expect(wrapper.findAll('tbody > tr').length).toBe(testItems.length + 1) expect( wrapper .findAll('tbody > tr') .at(testItems.length) .text() ).toBe('foobar') expect( wrapper .findAll('tbody > tr') .at(testItems.length) .classes() ).toContain('b-table-bottom-row') wrapper.destroy() }) })