Add "get" tests

This commit is contained in:
Adria Navarro 2023-01-19 11:44:48 +00:00
parent df418daf40
commit 39f3cc57eb
1 changed files with 85 additions and 73 deletions

View File

@ -229,12 +229,12 @@ describe("row api - postgres", () => {
})
describe("search for rows", () => {
const search = (tableId: string | undefined, body?: object) =>
makeRequest("post", `/tables/${postgresTable._id}/rows/search`, body)
describe("empty search", () => {
test("Given than a table has no rows, search without query returns empty", async () => {
const res = await makeRequest(
"post",
`/tables/${postgresTable._id}/rows/search`
)
const res = await search(postgresTable._id)
expect(res.status).toBe(200)
@ -245,10 +245,7 @@ describe("row api - postgres", () => {
const rowsCount = 6
const rows = await populateRows(rowsCount)
const res = await makeRequest(
"post",
`/tables/${postgresTable._id}/rows/search`
)
const res = await search(postgresTable._id)
expect(res.status).toBe(200)
@ -266,10 +263,7 @@ describe("row api - postgres", () => {
await populateRows(rowsCount)
await populateRows(2, (await config.createTable())._id)
const res = await makeRequest(
"post",
`/tables/${postgresTable._id}/rows/search`
)
const res = await search(postgresTable._id)
expect(res.status).toBe(200)
@ -298,17 +292,13 @@ describe("row api - postgres", () => {
}
await populateRows(1)
const res = await makeRequest(
"post",
`/tables/${postgresTable._id}/rows/search`,
{
const res = await search(postgresTable._id, {
query: {
string: {
name,
},
},
}
)
})
expect(res.status).toBe(200)
@ -321,13 +311,9 @@ describe("row api - postgres", () => {
test("Querying respects the limit fields", async () => {
await populateRows(6)
const res = await makeRequest(
"post",
`/tables/${postgresTable._id}/rows/search`,
{
const res = await search(postgresTable._id, {
limit: 2,
}
)
})
expect(res.status).toBe(200)
@ -361,17 +347,13 @@ describe("row api - postgres", () => {
})
test("Querying respects the sort order when sorting ascending by a string value", async () => {
const res = await makeRequest(
"post",
`/tables/${postgresTable._id}/rows/search`,
{
const res = await search(postgresTable._id, {
sort: {
order: "ascending",
column: "name",
type: "string",
},
}
)
})
expect(res.status).toBe(200)
expect(res.body.data).toEqual([
@ -383,17 +365,13 @@ describe("row api - postgres", () => {
})
test("Querying respects the sort order when sorting descending by a string value", async () => {
const res = await makeRequest(
"post",
`/tables/${postgresTable._id}/rows/search`,
{
const res = await search(postgresTable._id, {
sort: {
order: "descending",
column: "name",
type: "string",
},
}
)
})
expect(res.status).toBe(200)
expect(res.body.data).toEqual([
@ -405,17 +383,13 @@ describe("row api - postgres", () => {
})
test("Querying respects the sort order when sorting ascending by a numeric value", async () => {
const res = await makeRequest(
"post",
`/tables/${postgresTable._id}/rows/search`,
{
const res = await search(postgresTable._id, {
sort: {
order: "ascending",
column: "value",
type: "number",
},
}
)
})
expect(res.status).toBe(200)
expect(res.body.data).toEqual([
@ -427,17 +401,13 @@ describe("row api - postgres", () => {
})
test("Querying respects the sort order when sorting descending by a numeric value", async () => {
const res = await makeRequest(
"post",
`/tables/${postgresTable._id}/rows/search`,
{
const res = await search(postgresTable._id, {
sort: {
order: "descending",
column: "value",
type: "number",
},
}
)
})
expect(res.status).toBe(200)
expect(res.body.data).toEqual([
@ -449,4 +419,46 @@ describe("row api - postgres", () => {
})
})
})
describe("get all rows", () => {
const getAll = (tableId: string | undefined) =>
makeRequest("get", `/tables/${postgresTable._id}/rows`)
test("Given than a table has no rows, get returns empty", async () => {
const res = await getAll(postgresTable._id)
expect(res.status).toBe(200)
expect(res.body.data).toHaveLength(0)
})
test("Given than a table has multiple rows, get returns all of them", async () => {
const rowsCount = 6
const rows = await populateRows(rowsCount)
const res = await getAll(postgresTable._id)
expect(res.status).toBe(200)
expect(res.body.data).toHaveLength(rowsCount)
expect(res.body.data).toEqual(
expect.arrayContaining(
rows.map(r => expect.objectContaining(r.rowData))
)
)
})
test("Given than multiple tables have multiple rows, get returns the requested ones", async () => {
await populateRows(2, (await config.createTable())._id)
const rowsCount = 6
await populateRows(rowsCount)
await populateRows(2, (await config.createTable())._id)
const res = await getAll(postgresTable._id)
expect(res.status).toBe(200)
expect(res.body.data).toHaveLength(rowsCount)
})
})
})