bootstrap-vue-3
Version:
Early (but lovely) implementation of Vue 3, Bootstrap 5 and Typescript
114 lines (92 loc) • 3.61 kB
text/typescript
import {enableAutoUnmount, mount} from '@vue/test-utils'
import BListGroup from './BListGroup.vue'
import {afterEach, describe, expect, it} from 'vitest'
describe('list-group', () => {
enableAutoUnmount(afterEach)
it('default should have tag div', () => {
const wrapper = mount(BListGroup)
expect(wrapper.element.tagName).toBe('DIV')
})
it('default should contain only single class of list-group', () => {
const wrapper = mount(BListGroup)
expect(wrapper.classes().length).toBe(1)
expect(wrapper.classes()).toContain('list-group')
expect(wrapper.classes()).not.toContain('list-group-flush')
expect(wrapper.classes()).not.toContain('list-group-horizontal')
})
it('should have tag ul then prop tag=ul', () => {
const wrapper = mount(BListGroup, {
props: {tag: 'ul'},
})
expect(wrapper.element.tagName).toBe('UL')
})
it('should have tag ol then prop numbered=true', () => {
const wrapper = mount(BListGroup, {
props: {tag: 'div', numbered: true},
})
expect(wrapper.element.tagName).toBe('OL')
})
it('should have class list-group-flush when prop flush=true', () => {
const wrapper = mount(BListGroup, {
props: {flush: true},
})
expect(wrapper.classes().length).toBe(2)
expect(wrapper.classes()).toContain('list-group')
expect(wrapper.classes()).toContain('list-group-flush')
expect(wrapper.classes()).not.toContain('list-group-horizontal')
})
it('should have class list-group-horizontal when prop horizontal=true', () => {
const wrapper = mount(BListGroup, {
props: {horizontal: true},
})
expect(wrapper.classes().length).toBe(2)
expect(wrapper.classes()).not.toContain('list-group-flush')
expect(wrapper.classes()).toContain('list-group')
expect(wrapper.classes()).toContain('list-group-horizontal')
})
it('should have class list-group-horizontal-md when prop horizontal=md', () => {
const wrapper = mount(BListGroup, {
props: {horizontal: 'md'},
})
expect(wrapper.classes().length).toBe(2)
expect(wrapper.classes()).not.toContain('list-group-flush')
expect(wrapper.classes()).not.toContain('list-group-horizontal')
expect(wrapper.classes()).toContain('list-group')
expect(wrapper.classes()).toContain('list-group-horizontal-md')
})
it('should not have class list-group-horizontal when prop horizontal=true and flush=true', () => {
const wrapper = mount(BListGroup, {
props: {
horizontal: true,
flush: true,
},
})
expect(wrapper.classes().length).toBe(2)
expect(wrapper.classes()).not.toContain('list-group-horizontal')
expect(wrapper.classes()).toContain('list-group')
expect(wrapper.classes()).toContain('list-group-flush')
})
it('should not have class list-group-horizontal-lg when prop horizontal=lg and flush=true', () => {
const wrapper = mount(BListGroup, {
props: {
horizontal: 'lg',
flush: true,
},
})
expect(wrapper.classes().length).toBe(2)
expect(wrapper.classes()).not.toContain('list-group-horizontal-lg')
expect(wrapper.classes()).not.toContain('list-group-horizontal')
expect(wrapper.classes()).toContain('list-group')
expect(wrapper.classes()).toContain('list-group-flush')
})
it('should accept custom classes', () => {
const wrapper = mount(BListGroup, {
attrs: {
class: 'foobar',
},
})
expect(wrapper.classes().length).toBe(2)
expect(wrapper.classes()).toContain('list-group')
expect(wrapper.classes()).toContain('foobar')
})
})