budibase/packages/server/src/api/routes/tests/viewV2.spec.ts

202 lines
5.2 KiB
TypeScript
Raw Normal View History

2023-07-12 16:13:00 +02:00
import * as setup from "./utilities"
2023-07-18 15:47:37 +02:00
import { FieldType, SortOrder, SortType, Table, ViewV2 } from "@budibase/types"
2023-07-12 18:01:46 +02:00
import { generator, structures } from "@budibase/backend-core/tests"
2023-07-12 16:13:00 +02:00
function priceTable(): Table {
return {
name: "table",
type: "table",
schema: {
Price: {
type: FieldType.NUMBER,
name: "Price",
constraints: {},
},
Category: {
type: FieldType.STRING,
name: "Category",
constraints: {
type: "string",
},
},
},
}
}
2023-07-17 22:26:57 +02:00
describe("/v2/views", () => {
2023-07-12 16:13:00 +02:00
const config = setup.getConfig()
2023-07-18 15:03:57 +02:00
const viewFilters: Omit<ViewV2, "name" | "tableId"> = {
query: { allOr: false, equal: { field: "value" } },
sort: {
field: "fieldToSort",
2023-07-18 15:47:37 +02:00
order: SortOrder.DESCENDING,
2023-07-18 15:03:57 +02:00
type: SortType.STRING,
},
2023-07-18 15:47:37 +02:00
columns: ["name"],
2023-07-18 15:03:57 +02:00
}
2023-07-12 16:13:00 +02:00
afterAll(setup.afterAll)
beforeAll(async () => {
await config.init()
2023-07-18 12:56:24 +02:00
await config.createTable(priceTable())
2023-07-12 16:13:00 +02:00
})
2023-07-12 16:33:06 +02:00
describe("fetch", () => {
2023-07-18 09:58:43 +02:00
const views: ViewV2[] = []
2023-07-12 16:33:06 +02:00
beforeAll(async () => {
2023-07-18 10:14:13 +02:00
await config.createTable(priceTable())
2023-07-12 16:33:06 +02:00
for (let id = 0; id < 10; id++) {
2023-07-18 10:30:15 +02:00
views.push(await config.api.viewV2.create())
2023-07-12 16:33:06 +02:00
}
})
it("returns all views", async () => {
2023-07-19 12:38:01 +02:00
const res = await config.api.viewV2.fetch()
2023-07-12 16:33:06 +02:00
expect(res.body.views.length).toBe(10)
2023-07-12 16:49:50 +02:00
expect(res.body.views).toEqual(
expect.arrayContaining(views.map(v => expect.objectContaining(v)))
)
2023-07-12 16:33:06 +02:00
})
2023-07-12 17:02:54 +02:00
2023-07-13 11:36:26 +02:00
it("can filter by table id", async () => {
2023-07-18 14:34:23 +02:00
const newTable = await config.createTable(priceTable(), {
skipReassigning: true,
})
2023-07-13 11:36:26 +02:00
const newViews = []
2023-07-12 17:02:54 +02:00
for (let id = 0; id < 5; id++) {
2023-07-18 10:30:15 +02:00
newViews.push(await config.api.viewV2.create({ tableId: newTable._id }))
2023-07-12 17:02:54 +02:00
}
2023-07-18 10:14:13 +02:00
2023-07-19 12:38:01 +02:00
const res = await config.api.viewV2.fetch(newTable._id)
2023-07-12 17:02:54 +02:00
expect(res.body.views.length).toBe(5)
2023-07-13 11:36:26 +02:00
expect(res.body.views).toEqual(
expect.arrayContaining(newViews.map(v => expect.objectContaining(v)))
)
})
it("can not filter by multiple table ids", async () => {
2023-07-19 12:38:01 +02:00
const res = await config
.getRequest()!
2023-07-13 11:36:26 +02:00
.get(
2023-07-17 22:26:57 +02:00
`/api/v2/views?tableId=${structures.generator.guid()}&tableId=${structures.generator.guid()}`
2023-07-13 11:36:26 +02:00
)
.set(config.defaultHeaders())
.expect("Content-Type", /json/)
.expect(400)
expect(res.body.message).toBe("tableId type is not valid")
2023-07-12 17:02:54 +02:00
})
2023-07-18 14:34:23 +02:00
it("returns views with query info", async () => {
2023-07-18 15:03:57 +02:00
const newView = await config.api.viewV2.create({ ...viewFilters })
2023-07-18 14:34:23 +02:00
const res = await request
.get(`/api/v2/views?tableId=${config.table!._id}`)
.set(config.defaultHeaders())
.expect("Content-Type", /json/)
.expect(200)
expect(res.body.views.length).toBe(11)
expect(newView.query).toEqual({ allOr: false, equal: { field: "value" } })
expect(res.body.views).toEqual(
2023-07-18 15:03:57 +02:00
expect.arrayContaining([
expect.objectContaining({
...newView,
...viewFilters,
}),
])
2023-07-18 14:34:23 +02:00
)
})
2023-07-12 17:02:54 +02:00
})
2023-07-12 17:48:11 +02:00
describe("getView", () => {
2023-07-18 09:58:43 +02:00
let view: ViewV2
2023-07-12 17:48:11 +02:00
beforeAll(async () => {
2023-07-18 14:34:23 +02:00
view = await config.api.viewV2.create({
query: { allOr: false, notEqual: { field: "value" } },
})
2023-07-12 17:48:11 +02:00
})
2023-07-12 18:01:46 +02:00
it("can fetch the expected view", async () => {
2023-07-19 12:38:01 +02:00
const res = await config.api.viewV2.get(view._id!)
2023-07-12 17:48:11 +02:00
expect(res.status).toBe(200)
expect(res.body).toEqual({
2023-07-18 09:58:43 +02:00
data: {
...view,
_id: view._id,
_rev: view._rev,
createdAt: expect.any(String),
updatedAt: expect.any(String),
},
2023-07-12 17:48:11 +02:00
})
})
2023-07-12 18:01:46 +02:00
2023-07-13 11:36:26 +02:00
it("will return 404 if the unnexisting id is provided", async () => {
2023-07-19 12:38:01 +02:00
await config.api.viewV2.get(structures.generator.guid(), {
expectStatus: 404,
})
2023-07-12 18:01:46 +02:00
})
2023-07-12 17:48:11 +02:00
})
2023-07-12 16:13:00 +02:00
describe("create", () => {
it("persist the view when the view is successfully created", async () => {
2023-07-18 10:14:13 +02:00
const newView: ViewV2 = {
name: generator.name(),
tableId: config.table!._id!,
}
2023-07-19 12:38:01 +02:00
const res = await config.api.viewV2.create(newView)
2023-07-12 16:13:00 +02:00
2023-07-19 12:38:01 +02:00
expect(res).toEqual({
...newView,
_id: expect.any(String),
_rev: expect.any(String),
2023-07-12 16:13:00 +02:00
})
})
2023-07-18 14:34:23 +02:00
it("can persist views with queries", async () => {
const newView: ViewV2 = {
name: generator.name(),
tableId: config.table!._id!,
2023-07-18 15:03:57 +02:00
...viewFilters,
2023-07-18 14:34:23 +02:00
}
const res = await request
.post(`/api/v2/views`)
.send(newView)
.set(config.defaultHeaders())
.expect("Content-Type", /json/)
.expect(201)
expect(res.body).toEqual({
data: {
...newView,
2023-07-18 15:03:57 +02:00
...viewFilters,
2023-07-18 14:34:23 +02:00
_id: expect.any(String),
_rev: expect.any(String),
},
})
})
2023-07-12 16:13:00 +02:00
})
2023-07-12 18:09:13 +02:00
describe("delete", () => {
2023-07-18 09:58:43 +02:00
let view: ViewV2
2023-07-12 18:09:13 +02:00
beforeAll(async () => {
2023-07-18 10:14:13 +02:00
await config.createTable(priceTable())
2023-07-18 10:30:15 +02:00
view = await config.api.viewV2.create()
2023-07-12 18:09:13 +02:00
})
it("can delete an existing view", async () => {
2023-07-19 12:38:01 +02:00
await config.api.viewV2.get(view._id!, { expectStatus: 200 })
2023-07-12 18:09:13 +02:00
2023-07-19 12:38:01 +02:00
await config.api.viewV2.delete(view._id!)
2023-07-12 18:09:13 +02:00
2023-07-19 12:38:01 +02:00
await config.api.viewV2.get(view._id!, { expectStatus: 404 })
2023-07-12 18:09:13 +02:00
})
})
2023-07-12 16:13:00 +02:00
})