element-plus/packages/components/backtop/__tests__/backtop.spec.ts

41 lines
1.1 KiB
TypeScript
Raw Normal View History

import { nextTick } from 'vue'
2020-08-04 10:54:43 +08:00
import { mount } from '@vue/test-utils'
import Backtop from '../src/backtop.vue'
2020-08-04 10:54:43 +08:00
const _mount = (template: string) =>
mount(
{
components: {
'el-backtop': Backtop,
},
template,
},
{ attachTo: document.body }
)
2020-08-04 10:54:43 +08:00
describe('Backtop.vue', () => {
2020-08-06 23:35:23 +08:00
test('render', async () => {
2020-08-04 10:54:43 +08:00
const wrapper = _mount(`
2020-08-06 23:35:23 +08:00
<div class="target" style="height: 100px; overflow: auto">
<div style="height: 10000px; width: 100%">
<el-backtop target=".target" :visibilityHeight="2000" :right="100" :bottom="200" />
</div>
</div>
2020-08-04 10:54:43 +08:00
`)
await nextTick()
2020-08-04 10:54:43 +08:00
expect(wrapper.find('.el-backtop').exists()).toBe(false)
wrapper.element.scrollTop = 2000
await wrapper.trigger('scroll')
expect(wrapper.find('.el-backtop').exists()).toBe(true)
2020-08-06 23:35:23 +08:00
expect(wrapper.find('.el-backtop').attributes('style')).toBe(
'right: 100px; bottom: 200px;'
)
2020-08-04 10:54:43 +08:00
expect(wrapper.find('.el-icon-caret-top').exists()).toBe(true)
2020-08-06 23:35:23 +08:00
2020-08-04 10:54:43 +08:00
await wrapper.trigger('click')
expect(wrapper.emitted()).toBeDefined()
})
})