import { mount } from '@vue/test-utils' import { sleep } from '@element-plus/test-utils' import Pagination from '../src/index' import { nextTick, ref, h } from 'vue' const TIME_OUT = 100 describe('Pagination.vue', () => { test('layout', () => { const wrapper = mount(Pagination, { props: { layout: 'prev, pager, next', }, }) expect(wrapper.find('button.btn-prev').exists()).toBe(true) expect(wrapper.find('ul.el-pager').exists()).toBe(true) expect(wrapper.find('button.btn-next').exists()).toBe(true) expect(wrapper.find('.el-pagination__jump').exists()).toBe(false) expect(wrapper.find('.el-pagination__rightwrapper').exists()).toBe(false) expect(wrapper.find('.el-pagination__total').exists()).toBe(false) }) test('change layout value', async () => { const layout = ref('prev, pager, next') const Comp = { setup() { return () => { return h(Pagination, { class: 'pagination-wrapper', layout: layout.value, }) } }, } const wrapper = mount(Comp) expect(wrapper.find('button.btn-prev').exists()).toBe(true) expect(wrapper.find('ul.el-pager').exists()).toBe(true) expect(wrapper.find('button.btn-next').exists()).toBe(true) expect(wrapper.find('.el-pagination__rightwrapper').exists()).toBe(false) layout.value = 'prev, pager, next, ->' await nextTick() expect(wrapper.find('button.btn-prev').exists()).toBe(true) expect(wrapper.find('ul.el-pager').exists()).toBe(true) expect(wrapper.find('button.btn-next').exists()).toBe(true) expect(wrapper.find('.el-pagination__rightwrapper').exists()).toBe(false) layout.value = 'prev, pager, next, ->, jumper' await nextTick() expect(wrapper.find('button.btn-prev').exists()).toBe(true) expect(wrapper.find('ul.el-pager').exists()).toBe(true) expect(wrapper.find('button.btn-next').exists()).toBe(true) expect(wrapper.find('.el-pagination__rightwrapper').exists()).toBe(true) expect(wrapper.find('.el-pagination__rightwrapper .el-pagination__jump').exists()).toBe(true) layout.value = 'prev, pager, next, ->, jumper, sizes' await nextTick() expect(wrapper.find('button.btn-prev').exists()).toBe(true) expect(wrapper.find('ul.el-pager').exists()).toBe(true) expect(wrapper.find('button.btn-next').exists()).toBe(true) expect(wrapper.find('.el-pagination__rightwrapper').exists()).toBe(true) expect(wrapper.find('.el-pagination__rightwrapper .el-pagination__jump').exists()).toBe(true) expect(wrapper.find('.el-pagination__rightwrapper .el-pagination__sizes').exists()).toBe(true) layout.value = 'prev, pager, next, ->, jumper, sizes, total' await nextTick() expect(wrapper.find('button.btn-prev').exists()).toBe(true) expect(wrapper.find('ul.el-pager').exists()).toBe(true) expect(wrapper.find('button.btn-next').exists()).toBe(true) expect(wrapper.find('.el-pagination__rightwrapper').exists()).toBe(true) expect(wrapper.find('.el-pagination__rightwrapper .el-pagination__jump').exists()).toBe(true) expect(wrapper.find('.el-pagination__rightwrapper .el-pagination__sizes').exists()).toBe(true) expect(wrapper.find('.el-pagination__rightwrapper .el-pagination__total').exists()).toBe(true) }) test('slot', () => { const TestComponent = { template: ` slot test `, components: { 'el-pagination': Pagination, }, } const wrapper = mount(TestComponent) expect(wrapper.find('.slot-test').exists()).toBe(true) }) test('small', () => { const wrapper = mount(Pagination, { props: { small: true, }, }) expect(wrapper.vm.$el.classList.contains('el-pagination--small')).toBe(true) }) test('pageSize', () => { const wrapper = mount(Pagination, { props: { pageSize: 25, total: 100, }, }) expect(wrapper.findAll('li.number').length).toBe(4) }) test('pageSize: NaN', () => { const wrapper = mount(Pagination, { props: { pageSize: NaN, total: 100, }, }) expect(wrapper.findAll('li.number').length).toBe(7) }) test('pageCount', () => { const wrapper = mount(Pagination, { props: { pageSize: 25, pagerCount: 5, pageCount: 50, }, }) expect(wrapper.findAll('li.number').length).toBe(5) }) test('pagerCount', () => { const wrapper = mount(Pagination, { props: { pageSize: 25, total: 1000, pagerCount: 21, }, }) expect(wrapper.findAll('li.number').length).toBe(21) }) test('will work without total & page-count', async () => { const wrapper = mount(Pagination, { props: { pageSize: 25, currentPage: 2, }, }) wrapper.find('.btn-prev').trigger('click') await sleep(TIME_OUT) expect(wrapper.vm.internalCurrentPage).toEqual(1) wrapper.find('.btn-prev').trigger('click') expect(wrapper.vm.internalCurrentPage).toEqual(1) }) test('currentPage', () => { const wrapper = mount(Pagination, { props: { pageSize: 20, total: 200, currentPage: 3, }, }) expect(wrapper.find('li.number.active').text()).toEqual('3') }) test('currentPage: NaN', () => { const wrapper = mount(Pagination, { props: { pageSize: 20, total: 200, currentPage: NaN, }, }) expect(wrapper.find('li.number.active').text()).toEqual('1') expect(wrapper.vm.$el.querySelectorAll('li.number').length).toBe(7) }) test('layout is empty', () => { const wrapper = mount(Pagination, { props: { layout: '', }, }) expect(wrapper.vm.$el.textContent).toEqual('') }) }) describe('click pager', () => { test('click ul', () => { const wrapper = mount(Pagination, { props: { total: 1000, }, }) wrapper.find('.el-pager').trigger('click') expect(wrapper.vm.internalCurrentPage).toEqual(1) }) test('click li', () => { const wrapper = mount(Pagination, { props: { total: 1000, }, }) wrapper.findAll('.el-pager li.number')[1].trigger('click') expect(wrapper.vm.internalCurrentPage).toEqual(2) }) test('click next icon-more', () => { const wrapper = mount(Pagination, { props: { total: 1000, }, }) wrapper.find('.btn-quicknext.more').trigger('click') expect(wrapper.vm.internalCurrentPage).toEqual(6) }) test('click prev icon-more', async () => { const wrapper = mount(Pagination, { props: { total: 1000, }, }) wrapper.find('.btn-quicknext.more').trigger('click') await sleep(TIME_OUT) expect(wrapper.find('.btn-quickprev.more').exists()).toBe(true) wrapper.find('.btn-quickprev.more').trigger('click') expect(wrapper.vm.internalCurrentPage).toEqual(1) }) test('click last page', async () => { const wrapper = mount(Pagination, { props: { total: 1000, }, }) const nodes = wrapper.findAll('li.number') nodes[nodes.length - 1].trigger('click') await sleep(TIME_OUT) expect(wrapper.find('.btn-quickprev.more').exists()).toBe(true) expect(wrapper.find('.btn-quicknext.more').exists()).toBe(false) }) test('should emit change size evt and update pageSize', async () => { const onSizeChange = jest.fn() const wrapper = mount({ components: { 'el-pagination': Pagination, }, template: ` `, methods: { onSizeChange, }, data(){ return { pageSize: 200, } }, }) const items = document.querySelector('.select-dropdown-klass').querySelectorAll('.el-select-dropdown__item:not(.selected)'); (items[0] as HTMLOptionElement)?.click() expect(onSizeChange).toHaveBeenCalled() expect(wrapper.vm.pageSize).toBe(100) expect(wrapper.findComponent(Pagination).emitted()).toHaveProperty('size-change') }) test('should handle total size change', async () => { const onCurrentChange = jest.fn() const wrapper = mount({ components: { [Pagination.name]: Pagination, }, template: ` }, `, methods: { onCurrentChange, }, data() { return { currentPage: 3, total: 1000, pageSize: 100, } }, }) await nextTick() expect(wrapper.vm.currentPage).toBe(3) wrapper.vm.total = 100 await nextTick() expect(wrapper.vm.currentPage).toBe(1) expect(onCurrentChange).toHaveBeenCalledWith(1) }) }) test('repeat click next & change current page', async () => { const onCurrentChange = jest.fn() const wrapper = mount({ components: { [Pagination.name]: Pagination, }, template: ` }, `, methods: { onCurrentChange, }, data() { return { currentPage: 1, total: 400, pageSize: 100, } }, }) await nextTick() expect(wrapper.vm.currentPage).toBe(1) wrapper.find('.btn-next').trigger('click') await nextTick() expect(wrapper.vm.currentPage).toBe(2) wrapper.vm.currentPage = 1 await nextTick() expect(wrapper.vm.currentPage).toBe(1) wrapper.find('.btn-next').trigger('click') await nextTick() expect(wrapper.vm.currentPage).toBe(2) }) test('repeat click prev & change current page', async () => { const onCurrentChange = jest.fn() const wrapper = mount({ components: { [Pagination.name]: Pagination, }, template: ` }, `, methods: { onCurrentChange, }, data() { return { currentPage: 2, total: 400, pageSize: 100, } }, }) await nextTick() expect(wrapper.vm.currentPage).toBe(2) wrapper.find('.btn-prev').trigger('click') await nextTick() expect(wrapper.vm.currentPage).toBe(1) wrapper.vm.currentPage = 2 await nextTick() expect(wrapper.vm.currentPage).toBe(2) wrapper.find('.btn-prev').trigger('click') await nextTick() expect(wrapper.vm.currentPage).toBe(1) })