mirror of
https://github.com/woodpecker-ci/woodpecker.git
synced 2025-01-07 16:15:27 +00:00
154 lines
5.3 KiB
TypeScript
154 lines
5.3 KiB
TypeScript
|
import { shallowMount } from '@vue/test-utils';
|
||
|
import { describe, expect, it } from 'vitest';
|
||
|
import { type Ref, watch } from 'vue';
|
||
|
|
||
|
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 },
|
||
|
);
|
||
|
});
|
||
|
}
|
||
|
|
||
|
// eslint-disable-next-line promise/prefer-await-to-callbacks
|
||
|
export const mountComposition = (cb: () => void) => {
|
||
|
const wrapper = shallowMount({
|
||
|
setup() {
|
||
|
// eslint-disable-next-line promise/prefer-await-to-callbacks
|
||
|
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);
|
||
|
|
||
|
usePaginationComposition.resetPage();
|
||
|
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);
|
||
|
});
|
||
|
});
|