vuetify
Version:
Vue Material Component Framework
39 lines (34 loc) • 1.04 kB
text/typescript
import Roundable from '../'
import {
mount,
MountOptions,
Wrapper,
} from '@vue/test-utils'
describe('rippleable.ts', () => {
const Mock = Roundable.extend({
render (h) {
return h('div', {
class: this.roundableClasses,
})
},
})
type Instance = InstanceType<typeof Mock>
let mountFunction: (options?: MountOptions<Instance>) => Wrapper<Instance>
beforeEach(() => {
mountFunction = (options?: MountOptions<Instance>) => {
return mount(Mock, options)
}
})
it.each([
[undefined, {}],
[{ tile: true }, { 'rounded-0': true }],
[{ rounded: true, tile: true }, { 'rounded-0': true }],
[{ rounded: '0' }, { 'rounded-0': true }],
[{ rounded: true }, { rounded: true }],
[{ rounded: false }, {}],
[{ rounded: 'tr-xl br-lg' }, { 'rounded-tr-xl rounded-br-lg': true }],
])('should return correct rounded classes', (propsData, expected: any) => {
const wrapper = mountFunction({ propsData })
expect(wrapper.vm.roundedClasses).toEqual(expected)
})
})