Review updates

This commit is contained in:
Dean 2023-07-24 09:08:10 +01:00
parent ca6737b77b
commit 3b36970c58
2 changed files with 53 additions and 14 deletions

View File

@ -2,7 +2,7 @@ import { quotas } from "@budibase/pro"
import * as internal from "./internal" import * as internal from "./internal"
import * as external from "./external" import * as external from "./external"
import { isExternalTable } from "../../../integrations/utils" import { isExternalTable } from "../../../integrations/utils"
import { Ctx } from "@budibase/types" import { Ctx, UserCtx, DeleteRowRequest, Row } from "@budibase/types"
import * as utils from "./utils" import * as utils from "./utils"
import { gridSocket } from "../../../websockets" import { gridSocket } from "../../../websockets"
import { addRev } from "../public/utils" import { addRev } from "../public/utils"
@ -100,25 +100,24 @@ export async function find(ctx: any) {
}) })
} }
export async function destroy(ctx: any) { export async function destroy(ctx: UserCtx<DeleteRowRequest>) {
const appId = ctx.appId const appId = ctx.appId
const inputs = ctx.request.body const inputs: DeleteRowRequest = ctx.request.body
const tableId = utils.getTableId(ctx) const tableId = utils.getTableId(ctx)
let response, row let response, row
if (inputs.rows) { if ("rows" in inputs && Array.isArray(inputs?.rows)) {
const targetRows = inputs.rows.map( const targetRows = inputs.rows.map(row => {
(row: { [key: string]: string | string }) => { let processedRow: Row = typeof row == "string" ? { _id: row } : row
let processedRow = typeof row == "string" ? { _id: row } : row return !processedRow._rev
return !processedRow._rev ? addRev(fixRow(processedRow, ctx.params), tableId)
? addRev(fixRow(processedRow, ctx.params), tableId) : fixRow(processedRow, ctx.params)
: fixRow(processedRow, ctx.params) })
}
)
const rowDeletes = await Promise.all(targetRows) const rowDeletes: Row[] = await Promise.all(targetRows)
if (rowDeletes) { if (rowDeletes) {
ctx.request.body.rows = rowDeletes inputs.rows = rowDeletes
} }
let { rows } = await quotas.addQuery<any>( let { rows } = await quotas.addQuery<any>(

View File

@ -517,6 +517,46 @@ describe("/rows", () => {
await assertRowUsage(rowUsage - 2) await assertRowUsage(rowUsage - 2)
await assertQueryUsage(queryUsage + 1) await assertQueryUsage(queryUsage + 1)
}) })
it("should be able to delete a variety of row set types", async () => {
const row1 = await config.createRow()
const row2 = await config.createRow()
const row3 = await config.createRow()
const rowUsage = await getRowUsage()
const queryUsage = await getQueryUsage()
const res = await request
.delete(`/api/${table._id}/rows`)
.send({
rows: [row1, row2._id, { _id: row3._id }],
})
.set(config.defaultHeaders())
.expect("Content-Type", /json/)
.expect(200)
expect(res.body.length).toEqual(3)
await loadRow(row1._id!, table._id!, 404)
await assertRowUsage(rowUsage - 3)
await assertQueryUsage(queryUsage + 1)
})
it("should accept a valid row object and delete the row", async () => {
const row1 = await config.createRow()
const rowUsage = await getRowUsage()
const queryUsage = await getQueryUsage()
const res = await request
.delete(`/api/${table._id}/rows`)
.send(row1)
.set(config.defaultHeaders())
.expect("Content-Type", /json/)
.expect(200)
expect(res.body.id).toEqual(row1._id)
await loadRow(row1._id!, table._id!, 404)
await assertRowUsage(rowUsage - 1)
await assertQueryUsage(queryUsage + 1)
})
}) })
describe("fetchView", () => { describe("fetchView", () => {