Handle and test pagination
This commit is contained in:
parent
497943930e
commit
39d099b443
|
@ -33,13 +33,17 @@ export async function searchView(
|
||||||
|
|
||||||
ctx.status = 200
|
ctx.status = 200
|
||||||
|
|
||||||
|
const { body } = ctx.request
|
||||||
|
|
||||||
const searchOptions: RequiredKeys<SearchViewRowRequest> &
|
const searchOptions: RequiredKeys<SearchViewRowRequest> &
|
||||||
RequiredKeys<Pick<SearchParams, "tableId" | "query" | "fields">> = {
|
RequiredKeys<Pick<SearchParams, "tableId" | "query" | "fields">> = {
|
||||||
tableId: view.tableId,
|
tableId: view.tableId,
|
||||||
query: view.query || {},
|
query: view.query || {},
|
||||||
fields: viewFields,
|
fields: viewFields,
|
||||||
...getSortOptions(ctx.request.body, view),
|
...getSortOptions(body, view),
|
||||||
limit: ctx.request.body.limit,
|
limit: body.limit,
|
||||||
|
bookmark: body.bookmark,
|
||||||
|
paginate: body.paginate,
|
||||||
}
|
}
|
||||||
|
|
||||||
const result = await quotas.addQuery(() => sdk.rows.search(searchOptions), {
|
const result = await quotas.addQuery(() => sdk.rows.search(searchOptions), {
|
||||||
|
|
|
@ -1279,6 +1279,63 @@ describe("/rows", () => {
|
||||||
|
|
||||||
expect(response.body.rows).toHaveLength(limit)
|
expect(response.body.rows).toHaveLength(limit)
|
||||||
})
|
})
|
||||||
|
|
||||||
|
it("can handle pagination", async () => {
|
||||||
|
const table = await config.createTable(userTable())
|
||||||
|
const rows = []
|
||||||
|
for (let i = 0; i < 10; i++) {
|
||||||
|
rows.push(await config.createRow({ tableId: table._id }))
|
||||||
|
}
|
||||||
|
// rows.sort((a, b) => (a._id! > b._id! ? 1 : -1))
|
||||||
|
|
||||||
|
const createViewResponse = await config.api.viewV2.create()
|
||||||
|
const allRows = (await config.api.viewV2.search(createViewResponse.id))
|
||||||
|
.body.rows
|
||||||
|
|
||||||
|
const firstPageResponse = await config.api.viewV2.search(
|
||||||
|
createViewResponse.id,
|
||||||
|
{
|
||||||
|
paginate: true,
|
||||||
|
limit: 4,
|
||||||
|
}
|
||||||
|
)
|
||||||
|
expect(firstPageResponse.body).toEqual({
|
||||||
|
rows: expect.arrayContaining(allRows.slice(0, 4)),
|
||||||
|
totalRows: 10,
|
||||||
|
hasNextPage: true,
|
||||||
|
bookmark: expect.any(String),
|
||||||
|
})
|
||||||
|
|
||||||
|
const secondPageResponse = await config.api.viewV2.search(
|
||||||
|
createViewResponse.id,
|
||||||
|
{
|
||||||
|
paginate: true,
|
||||||
|
limit: 4,
|
||||||
|
bookmark: firstPageResponse.body.bookmark,
|
||||||
|
}
|
||||||
|
)
|
||||||
|
expect(secondPageResponse.body).toEqual({
|
||||||
|
rows: expect.arrayContaining(allRows.slice(4, 8)),
|
||||||
|
totalRows: 10,
|
||||||
|
hasNextPage: true,
|
||||||
|
bookmark: expect.any(String),
|
||||||
|
})
|
||||||
|
|
||||||
|
const lastPageResponse = await config.api.viewV2.search(
|
||||||
|
createViewResponse.id,
|
||||||
|
{
|
||||||
|
paginate: true,
|
||||||
|
limit: 4,
|
||||||
|
bookmark: secondPageResponse.body.bookmark,
|
||||||
|
}
|
||||||
|
)
|
||||||
|
expect(lastPageResponse.body).toEqual({
|
||||||
|
rows: expect.arrayContaining(allRows.slice(8)),
|
||||||
|
totalRows: 10,
|
||||||
|
hasNextPage: false,
|
||||||
|
bookmark: expect.any(String),
|
||||||
|
})
|
||||||
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
|
@ -12,7 +12,10 @@ export interface PatchRowResponse extends Row {}
|
||||||
export interface SearchRowRequest extends Omit<SearchParams, "tableId"> {}
|
export interface SearchRowRequest extends Omit<SearchParams, "tableId"> {}
|
||||||
|
|
||||||
export interface SearchViewRowRequest
|
export interface SearchViewRowRequest
|
||||||
extends Pick<SearchRowRequest, "sort" | "sortOrder" | "sortType" | "limit"> {}
|
extends Pick<
|
||||||
|
SearchRowRequest,
|
||||||
|
"sort" | "sortOrder" | "sortType" | "limit" | "bookmark" | "paginate"
|
||||||
|
> {}
|
||||||
|
|
||||||
export interface SearchRowResponse {
|
export interface SearchRowResponse {
|
||||||
rows: any[]
|
rows: any[]
|
||||||
|
|
Loading…
Reference in New Issue