2024-04-29 19:33:45 +00:00
|
|
|
import { shallowMount } from '@vue/test-utils';
|
|
|
|
import { describe, expect, it } from 'vitest';
|
2024-06-06 13:16:59 +00:00
|
|
|
import { watch, type Ref } from 'vue';
|
2024-04-29 19:33:45 +00:00
|
|
|
|
|
|
|
import { usePagination } from './usePaginate';
|
|
|
|
|
|
|
|
async function waitForState<T>(ref: Ref<T>, expected: T): Promise<void> {
|
|
|
|
await new Promise<void>((resolve) => {
|
|
|
|
watch(
|
|
|
|
ref,
|
|
|
|
(value) => {
|
|
|
|
if (value === expected) {
|
|
|
|
resolve();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{ immediate: true },
|
|
|
|
);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2024-06-06 13:16:59 +00:00
|
|
|
// TODO enable again with eslint-plugin-promise eslint-disable-next-line promise/prefer-await-to-callbacks
|
2024-04-29 19:33:45 +00:00
|
|
|
export const mountComposition = (cb: () => void) => {
|
|
|
|
const wrapper = shallowMount({
|
|
|
|
setup() {
|
2024-06-06 13:16:59 +00:00
|
|
|
// TODO enable again with eslint-plugin-promise eslint-disable-next-line promise/prefer-await-to-callbacks
|
2024-04-29 19:33:45 +00:00
|
|
|
cb();
|
|
|
|
return {};
|
|
|
|
},
|
|
|
|
template: '<div />',
|
|
|
|
});
|
|
|
|
|
|
|
|
return wrapper;
|
|
|
|
};
|
|
|
|
|
|
|
|
describe('usePaginate', () => {
|
|
|
|
const repoSecrets = [
|
|
|
|
[{ name: 'repo1' }, { name: 'repo2' }, { name: 'repo3' }],
|
|
|
|
[{ name: 'repo4' }, { name: 'repo5' }, { name: 'repo6' }],
|
|
|
|
];
|
|
|
|
const orgSecrets = [
|
|
|
|
[{ name: 'org1' }, { name: 'org2' }, { name: 'org3' }],
|
|
|
|
[{ name: 'org4' }, { name: 'org5' }, { name: 'org6' }],
|
|
|
|
];
|
|
|
|
|
|
|
|
it('should get first page', async () => {
|
|
|
|
let usePaginationComposition = null as unknown as ReturnType<typeof usePagination>;
|
|
|
|
mountComposition(() => {
|
|
|
|
usePaginationComposition = usePagination<{ name: string }>(
|
|
|
|
async (page) => repoSecrets[page - 1],
|
|
|
|
() => true,
|
|
|
|
);
|
|
|
|
});
|
|
|
|
await waitForState(usePaginationComposition.loading, true);
|
|
|
|
await waitForState(usePaginationComposition.loading, false);
|
|
|
|
|
|
|
|
expect(usePaginationComposition.data.value.length).toBe(3);
|
|
|
|
expect(usePaginationComposition.data.value[0]).toStrictEqual(repoSecrets[0][0]);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should get first & second page', async () => {
|
|
|
|
let usePaginationComposition = null as unknown as ReturnType<typeof usePagination>;
|
|
|
|
mountComposition(() => {
|
|
|
|
usePaginationComposition = usePagination<{ name: string }>(
|
|
|
|
async (page) => repoSecrets[page - 1],
|
|
|
|
() => true,
|
|
|
|
);
|
|
|
|
});
|
|
|
|
await waitForState(usePaginationComposition.loading, true);
|
|
|
|
await waitForState(usePaginationComposition.loading, false);
|
|
|
|
|
|
|
|
usePaginationComposition.nextPage();
|
|
|
|
await waitForState(usePaginationComposition.loading, false);
|
|
|
|
|
|
|
|
expect(usePaginationComposition.data.value.length).toBe(6);
|
|
|
|
expect(usePaginationComposition.data.value.at(-1)).toStrictEqual(repoSecrets[1][2]);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should get first page for each category', async () => {
|
|
|
|
let usePaginationComposition = null as unknown as ReturnType<typeof usePagination>;
|
|
|
|
mountComposition(() => {
|
|
|
|
usePaginationComposition = usePagination<{ name: string }>(
|
|
|
|
async (page, level) => {
|
|
|
|
if (level === 'repo') {
|
|
|
|
return repoSecrets[page - 1];
|
|
|
|
}
|
|
|
|
return orgSecrets[page - 1];
|
|
|
|
},
|
|
|
|
() => true,
|
|
|
|
{ each: ['repo', 'org'] },
|
|
|
|
);
|
|
|
|
});
|
|
|
|
await waitForState(usePaginationComposition.loading, true);
|
|
|
|
await waitForState(usePaginationComposition.loading, false);
|
|
|
|
|
|
|
|
usePaginationComposition.nextPage();
|
|
|
|
await waitForState(usePaginationComposition.loading, false);
|
|
|
|
|
|
|
|
usePaginationComposition.nextPage();
|
|
|
|
await waitForState(usePaginationComposition.loading, false);
|
|
|
|
|
|
|
|
usePaginationComposition.nextPage();
|
|
|
|
await waitForState(usePaginationComposition.loading, false);
|
|
|
|
|
|
|
|
expect(usePaginationComposition.data.value.length).toBe(9);
|
|
|
|
expect(usePaginationComposition.data.value.at(-1)).toStrictEqual(orgSecrets[0][2]);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should reset page and get first page again', async () => {
|
|
|
|
let usePaginationComposition = null as unknown as ReturnType<typeof usePagination>;
|
|
|
|
mountComposition(() => {
|
|
|
|
usePaginationComposition = usePagination<{ name: string }>(
|
|
|
|
async (page) => repoSecrets[page - 1],
|
|
|
|
() => true,
|
|
|
|
);
|
|
|
|
});
|
|
|
|
await waitForState(usePaginationComposition.loading, true);
|
|
|
|
await waitForState(usePaginationComposition.loading, false);
|
|
|
|
|
|
|
|
usePaginationComposition.nextPage();
|
|
|
|
await waitForState(usePaginationComposition.loading, false);
|
|
|
|
|
2024-06-06 13:16:59 +00:00
|
|
|
void usePaginationComposition.resetPage();
|
2024-04-29 19:33:45 +00:00
|
|
|
await waitForState(usePaginationComposition.loading, false);
|
|
|
|
|
|
|
|
expect(usePaginationComposition.data.value.length).toBe(3);
|
|
|
|
expect(usePaginationComposition.data.value[0]).toStrictEqual(repoSecrets[0][0]);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should not hasMore when no data is left', async () => {
|
|
|
|
let usePaginationComposition = null as unknown as ReturnType<typeof usePagination>;
|
|
|
|
mountComposition(() => {
|
|
|
|
usePaginationComposition = usePagination<{ name: string }>(
|
|
|
|
async (page) => repoSecrets[page - 1],
|
|
|
|
() => true,
|
|
|
|
);
|
|
|
|
});
|
|
|
|
await waitForState(usePaginationComposition.loading, true);
|
|
|
|
await waitForState(usePaginationComposition.loading, false);
|
|
|
|
|
|
|
|
expect(usePaginationComposition.hasMore.value).toBe(true);
|
|
|
|
expect(usePaginationComposition.data.value.length).toBe(3);
|
|
|
|
|
|
|
|
usePaginationComposition.nextPage();
|
|
|
|
await waitForState(usePaginationComposition.loading, false);
|
|
|
|
expect(usePaginationComposition.hasMore.value).toBe(true);
|
|
|
|
expect(usePaginationComposition.data.value.length).toBe(6);
|
|
|
|
|
|
|
|
usePaginationComposition.nextPage();
|
|
|
|
await waitForState(usePaginationComposition.loading, false);
|
|
|
|
expect(usePaginationComposition.hasMore.value).toBe(false);
|
|
|
|
expect(usePaginationComposition.data.value.length).toBe(6);
|
|
|
|
});
|
|
|
|
});
|