import { mount } from '@vue/test-utils'
import { asyncExpect } from '@/tests/utils'
import Spin from '..'
describe('Spin', () => {
it('should only affect the spin element when set style to a nested xx', () => {
const wrapper = mount({
render () {
return (
content
)
},
})
expect(wrapper.html()).toMatchSnapshot()
// expect(wrapper.findAll('.ant-spin-nested-loading').at(0).prop('style')).toBe(null)
// expect(wrapper.findAll('.ant-spin').at(0).prop('style').background).toBe('red')
})
it('should render custom indicator when it\'s set', () => {
// const customIndicator =
const wrapper = mount(
{
render () {
return (
)
},
})
expect(wrapper.html()).toMatchSnapshot()
})
it('should render with delay when it\'s mounted with spinning=true and delay', async () => {
const props = {
propsData: {
delay: 500,
spinning: true,
},
sync: false,
}
const wrapper = mount(Spin, props)
await asyncExpect(() => {
expect(wrapper.find('.ant-spin').classes().includes('ant-spin-spinning')).toEqual(false)
})
})
it('should be controlled by spinning', async () => {
const props = {
propsData: {
spinning: false,
},
sync: false,
}
const wrapper = mount(Spin, props)
await asyncExpect(() => {
expect(wrapper.vm.sSpinning).toBe(false)
wrapper.setProps({ spinning: true })
})
await asyncExpect(() => {
expect(wrapper.vm.sSpinning).toBe(true)
})
})
})