From 2412056292c0fdf1714397f2c5a7c0dd63c1080b Mon Sep 17 00:00:00 2001 From: Adria Navarro Date: Tue, 25 Jul 2023 15:34:25 +0200 Subject: [PATCH] Update basic test --- .../src/api/routes/tests/viewV2.spec.ts | 23 ++++++++++++++++ .../server/src/tests/utilities/api/viewV2.ts | 27 +++++++++++++++++-- 2 files changed, 48 insertions(+), 2 deletions(-) diff --git a/packages/server/src/api/routes/tests/viewV2.spec.ts b/packages/server/src/api/routes/tests/viewV2.spec.ts index 480580eb86..bf09026ec6 100644 --- a/packages/server/src/api/routes/tests/viewV2.spec.ts +++ b/packages/server/src/api/routes/tests/viewV2.spec.ts @@ -86,6 +86,29 @@ describe("/v2/views", () => { }) }) + describe("update", () => { + let view: ViewV2 + + beforeAll(async () => { + await config.createTable(priceTable()) + view = await config.api.viewV2.create({ name: "View A" }) + }) + + it("can update an existing view name", async () => { + const tableId = config.table!._id! + await config.api.viewV2.update({ ...view, name: "View B" }) + + expect(await config.api.table.get(tableId)).toEqual({ + ...config.table, + views: { + "View B": { ...view, name: "View B", schema: expect.anything() }, + }, + _rev: expect.any(String), + updatedAt: expect.any(String), + }) + }) + }) + describe("delete", () => { let view: ViewV2 diff --git a/packages/server/src/tests/utilities/api/viewV2.ts b/packages/server/src/tests/utilities/api/viewV2.ts index 15111ad977..445a806428 100644 --- a/packages/server/src/tests/utilities/api/viewV2.ts +++ b/packages/server/src/tests/utilities/api/viewV2.ts @@ -1,4 +1,4 @@ -import { SortOrder, SortType, ViewV2 } from "@budibase/types" +import { CreateViewRequest, SortOrder, SortType, ViewV2 } from "@budibase/types" import TestConfiguration from "../TestConfiguration" import { TestAPI } from "./base" import { generator } from "@budibase/backend-core/tests" @@ -9,7 +9,7 @@ export class ViewV2API extends TestAPI { } create = async ( - viewData?: Partial, + viewData?: Partial, { expectStatus } = { expectStatus: 201 } ): Promise => { let tableId = viewData?.tableId @@ -31,6 +31,29 @@ export class ViewV2API extends TestAPI { return result.body.data as ViewV2 } + update = async ( + viewData?: Partial, + { expectStatus } = { expectStatus: 200 } + ): Promise => { + let tableId = viewData?.tableId + if (!tableId && !this.config.table) { + throw "Test requires table to be configured." + } + tableId = this.config.table!._id! + const view = { + tableId, + name: generator.guid(), + ...viewData, + } + const result = await this.request + .put(`/api/v2/views`) + .send(view) + .set(this.config.defaultHeaders()) + .expect("Content-Type", /json/) + .expect(expectStatus) + return result.body.data as ViewV2 + } + delete = async (viewId: string, { expectStatus } = { expectStatus: 204 }) => { return this.request .delete(`/api/v2/views/${viewId}`)