2023-01-03 13:17:22 +00:00
|
|
|
import { vi, describe, expect, it, beforeAll, afterEach } from 'vitest';
|
|
|
|
import { createWrapper, axios } from 'app/test/vitest/helper';
|
2023-04-11 12:53:08 +00:00
|
|
|
import VnPaginate from 'src/components/ui/VnPaginate.vue';
|
2022-12-20 11:30:25 +00:00
|
|
|
|
2024-03-18 14:02:50 +00:00
|
|
|
describe('VnPaginate', () => {
|
2022-12-20 11:30:25 +00:00
|
|
|
const expectedUrl = '/api/customers';
|
2024-12-11 14:04:31 +00:00
|
|
|
const defaultData = [
|
|
|
|
{ id: 1, name: 'Tony Stark' },
|
|
|
|
{ id: 2, name: 'Jessica Jones' },
|
|
|
|
{ id: 3, name: 'Bruce Wayne' },
|
|
|
|
];
|
2022-12-20 11:30:25 +00:00
|
|
|
let vm;
|
|
|
|
beforeAll(() => {
|
|
|
|
const options = {
|
|
|
|
attrs: {
|
|
|
|
url: expectedUrl,
|
2023-02-24 12:21:37 +00:00
|
|
|
dataKey: 'CustomerList',
|
|
|
|
order: 'id DESC',
|
|
|
|
limit: 3,
|
2022-12-22 12:46:43 +00:00
|
|
|
},
|
2022-12-20 11:30:25 +00:00
|
|
|
};
|
2023-04-11 12:53:08 +00:00
|
|
|
vm = createWrapper(VnPaginate, options).vm;
|
2022-12-20 11:30:25 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
afterEach(() => {
|
2023-02-24 12:21:37 +00:00
|
|
|
vm.store.data = [];
|
2023-03-02 06:59:15 +00:00
|
|
|
vm.store.skip = 0;
|
2022-12-20 11:30:25 +00:00
|
|
|
vm.pagination.page = 1;
|
|
|
|
vm.hasMoreData = true;
|
2022-12-22 12:46:43 +00:00
|
|
|
});
|
2022-12-20 11:30:25 +00:00
|
|
|
|
|
|
|
describe('paginate()', () => {
|
|
|
|
it('should call to the paginate() method and set the data on the rows property', async () => {
|
2023-02-24 12:21:37 +00:00
|
|
|
vi.spyOn(vm.arrayData, 'loadMore');
|
2024-12-11 14:04:31 +00:00
|
|
|
vm.store.data = defaultData;
|
2022-12-20 11:30:25 +00:00
|
|
|
|
|
|
|
await vm.paginate();
|
|
|
|
|
2023-02-24 12:21:37 +00:00
|
|
|
expect(vm.arrayData.loadMore).toHaveBeenCalledWith();
|
|
|
|
expect(vm.store.data.length).toEqual(3);
|
2022-12-20 11:30:25 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should call to the paginate() method and then call it again to paginate', async () => {
|
2023-02-24 12:21:37 +00:00
|
|
|
vi.spyOn(axios, 'get').mockResolvedValue({
|
2024-12-11 14:04:31 +00:00
|
|
|
data: defaultData,
|
2023-02-24 12:21:37 +00:00
|
|
|
});
|
2024-04-22 14:35:34 +00:00
|
|
|
vm.store.hasMoreData = true;
|
2024-03-18 14:02:50 +00:00
|
|
|
await vm.$nextTick();
|
|
|
|
|
2024-12-11 14:04:31 +00:00
|
|
|
vm.store.data = defaultData;
|
2022-12-20 11:30:25 +00:00
|
|
|
|
|
|
|
await vm.paginate();
|
|
|
|
|
2024-04-22 14:35:34 +00:00
|
|
|
expect(vm.store.skip).toEqual(3);
|
|
|
|
expect(vm.store.data.length).toEqual(6);
|
2022-12-20 11:30:25 +00:00
|
|
|
|
2024-12-11 14:04:31 +00:00
|
|
|
vi.spyOn(axios, 'get').mockResolvedValue({
|
|
|
|
data: [
|
|
|
|
{ id: 4, name: 'Peter Parker' },
|
|
|
|
{ id: 5, name: 'Clark Kent' },
|
|
|
|
{ id: 6, name: 'Barry Allen' },
|
|
|
|
],
|
|
|
|
});
|
2022-12-20 11:30:25 +00:00
|
|
|
await vm.paginate();
|
|
|
|
|
2024-04-22 14:35:34 +00:00
|
|
|
expect(vm.store.skip).toEqual(6);
|
|
|
|
expect(vm.store.data.length).toEqual(9);
|
2022-12-20 11:30:25 +00:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('onLoad()', () => {
|
|
|
|
it('should call to the done() callback and not increment the pagination', async () => {
|
|
|
|
const index = 1;
|
2023-01-03 13:17:22 +00:00
|
|
|
const done = vi.fn();
|
2022-12-20 11:30:25 +00:00
|
|
|
|
|
|
|
await vm.onLoad(index, done);
|
|
|
|
|
|
|
|
expect(vm.pagination.page).toEqual(1);
|
|
|
|
expect(done).toHaveBeenCalledWith(false);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should increment the pagination and then call to the done() callback', async () => {
|
|
|
|
expect(vm.pagination.page).toEqual(1);
|
|
|
|
|
|
|
|
const index = 1;
|
2023-01-03 13:17:22 +00:00
|
|
|
const done = vi.fn();
|
2024-12-11 14:04:31 +00:00
|
|
|
vm.store.data = defaultData;
|
2022-12-20 11:30:25 +00:00
|
|
|
|
|
|
|
await vm.onLoad(index, done);
|
|
|
|
|
|
|
|
expect(vm.pagination.page).toEqual(2);
|
|
|
|
expect(done).toHaveBeenCalledWith(false);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should call to the done() callback with true as argument to finish pagination', async () => {
|
2023-01-03 13:17:22 +00:00
|
|
|
vi.spyOn(axios, 'get').mockResolvedValue({
|
2022-12-20 11:30:25 +00:00
|
|
|
data: [
|
|
|
|
{ id: 1, name: 'Tony Stark' },
|
2022-12-22 12:46:43 +00:00
|
|
|
{ id: 2, name: 'Jessica Jones' },
|
|
|
|
],
|
2022-12-20 11:30:25 +00:00
|
|
|
});
|
|
|
|
|
2024-12-11 14:04:31 +00:00
|
|
|
vm.store.data = defaultData;
|
2022-12-20 11:30:25 +00:00
|
|
|
|
|
|
|
expect(vm.pagination.page).toEqual(1);
|
|
|
|
|
|
|
|
const index = 1;
|
2023-01-03 13:17:22 +00:00
|
|
|
const done = vi.fn();
|
2022-12-20 11:30:25 +00:00
|
|
|
|
|
|
|
vm.hasMoreData = false;
|
|
|
|
|
|
|
|
await vm.onLoad(index, done);
|
|
|
|
|
|
|
|
expect(vm.pagination.page).toEqual(2);
|
2024-01-16 11:15:08 +00:00
|
|
|
expect(done).toHaveBeenCalledWith(false);
|
2022-12-20 11:30:25 +00:00
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|