Improve internal API classes

This commit is contained in:
Pedro Silva 2023-05-10 16:53:20 +01:00
parent 62238611bf
commit fc61623e32
11 changed files with 110 additions and 208 deletions

View File

@ -7,78 +7,64 @@ import {
MessageResponse, MessageResponse,
} from "../../../types" } from "../../../types"
import BudibaseInternalAPIClient from "../BudibaseInternalAPIClient" import BudibaseInternalAPIClient from "../BudibaseInternalAPIClient"
import BaseAPI from "./BaseAPI"
export default class AppAPI { export default class AppAPI extends BaseAPI {
client: BudibaseInternalAPIClient
constructor(client: BudibaseInternalAPIClient) { constructor(client: BudibaseInternalAPIClient) {
this.client = client super(client)
} }
// TODO Fix the fetch apps to receive an optional number of apps and compare if the received app is more or less. // TODO Fix the fetch apps to receive an optional number of apps and compare if the received app is more or less.
// each possible scenario should have its own method. // each possible scenario should have its own method.
async fetchEmptyAppList(): Promise<[Response, App[]]> { async fetchEmptyAppList(): Promise<[Response, App[]]> {
const [response, json] = await this.client.get(`/applications?status=all`) const [response, json] = await this.get(`/applications?status=all`)
expect(response).toHaveStatusCode(200)
expect(json.length).toBeGreaterThanOrEqual(0) expect(json.length).toBeGreaterThanOrEqual(0)
return [response, json] return [response, json]
} }
async fetchAllApplications(): Promise<[Response, App[]]> { async fetchAllApplications(): Promise<[Response, App[]]> {
const [response, json] = await this.client.get(`/applications?status=all`) const [response, json] = await this.get(`/applications?status=all`)
expect(response).toHaveStatusCode(200)
expect(json.length).toBeGreaterThanOrEqual(1) expect(json.length).toBeGreaterThanOrEqual(1)
return [response, json] return [response, json]
} }
async canRender(): Promise<[Response, boolean]> { async canRender(): Promise<[Response, boolean]> {
const [response, json] = await this.client.get("/routing/client") const [response, json] = await this.get("/routing/client")
expect(response).toHaveStatusCode(200)
const publishedAppRenders = Object.keys(json.routes).length > 0 const publishedAppRenders = Object.keys(json.routes).length > 0
expect(publishedAppRenders).toBe(true) expect(publishedAppRenders).toBe(true)
return [response, publishedAppRenders] return [response, publishedAppRenders]
} }
async getAppPackage(appId: string): Promise<[Response, AppPackageResponse]> { async getAppPackage(appId: string): Promise<[Response, AppPackageResponse]> {
const [response, json] = await this.client.get( const [response, json] = await this.get(`/applications/${appId}/appPackage`)
`/applications/${appId}/appPackage`
)
expect(response).toHaveStatusCode(200)
expect(json.application.appId).toEqual(appId) expect(json.application.appId).toEqual(appId)
return [response, json] return [response, json]
} }
async publish(appId: string | undefined): Promise<[Response, DeployConfig]> { async publish(appId: string | undefined): Promise<[Response, DeployConfig]> {
const [response, json] = await this.client.post( const [response, json] = await this.post(`/applications/${appId}/publish`)
`/applications/${appId}/publish`
)
expect(response).toHaveStatusCode(200)
return [response, json] return [response, json]
} }
async create(body: any): Promise<App> { async create(body: any): Promise<App> {
const [response, json] = await this.client.post(`/applications`, { body }) const [response, json] = await this.post(`/applications`, body)
expect(response).toHaveStatusCode(200)
expect(json._id).toBeDefined() expect(json._id).toBeDefined()
return json return json
} }
async read(id: string): Promise<[Response, App]> { async read(id: string): Promise<[Response, App]> {
const [response, json] = await this.client.get(`/applications/${id}`) const [response, json] = await this.get(`/applications/${id}`)
return [response, json.data] return [response, json.data]
} }
async sync(appId: string): Promise<[Response, MessageResponse]> { async sync(appId: string): Promise<[Response, MessageResponse]> {
const [response, json] = await this.client.post( const [response, json] = await this.post(`/applications/${appId}/sync`)
`/applications/${appId}/sync`
)
expect(response).toHaveStatusCode(200)
return [response, json] return [response, json]
} }
// TODO // TODO
async updateClient(appId: string, body: any): Promise<[Response, App]> { async updateClient(appId: string, body: any): Promise<[Response, App]> {
const [response, json] = await this.client.put( const [response, json] = await this.put(
`/applications/${appId}/client/update`, `/applications/${appId}/client/update`,
{ body } { body }
) )
@ -86,8 +72,7 @@ export default class AppAPI {
} }
async revertPublished(appId: string): Promise<[Response, MessageResponse]> { async revertPublished(appId: string): Promise<[Response, MessageResponse]> {
const [response, json] = await this.client.post(`/dev/${appId}/revert`) const [response, json] = await this.post(`/dev/${appId}/revert`)
expect(response).toHaveStatusCode(200)
expect(json).toEqual({ expect(json).toEqual({
message: "Reverted changes successfully.", message: "Reverted changes successfully.",
}) })
@ -95,8 +80,11 @@ export default class AppAPI {
} }
async revertUnpublished(appId: string): Promise<[Response, MessageResponse]> { async revertUnpublished(appId: string): Promise<[Response, MessageResponse]> {
const [response, json] = await this.client.post(`/dev/${appId}/revert`) const [response, json] = await this.post(
expect(response).toHaveStatusCode(400) `/dev/${appId}/revert`,
undefined,
400
)
expect(json).toEqual({ expect(json).toEqual({
message: "App has not yet been deployed", message: "App has not yet been deployed",
status: 400, status: 400,
@ -105,8 +93,7 @@ export default class AppAPI {
} }
async delete(appId: string): Promise<Response> { async delete(appId: string): Promise<Response> {
const [response, _] = await this.client.del(`/applications/${appId}`) const [response, _] = await this.del(`/applications/${appId}`)
expect(response).toHaveStatusCode(200)
return response return response
} }
@ -115,22 +102,18 @@ export default class AppAPI {
oldName: string, oldName: string,
body: any body: any
): Promise<[Response, App]> { ): Promise<[Response, App]> {
const [response, json] = await this.client.put(`/applications/${appId}`, { const [response, json] = await this.put(`/applications/${appId}`, body)
body,
})
expect(response).toHaveStatusCode(200)
expect(json.name).not.toEqual(oldName) expect(json.name).not.toEqual(oldName)
return [response, json] return [response, json]
} }
async addScreentoApp(body: any): Promise<[Response, App]> { async addScreentoApp(body: any): Promise<[Response, App]> {
const [response, json] = await this.client.post(`/screens`, { body }) const [response, json] = await this.post(`/screens`, body)
return [response, json] return [response, json]
} }
async getRoutes(screenExists?: boolean): Promise<[Response, RouteConfig]> { async getRoutes(screenExists?: boolean): Promise<[Response, RouteConfig]> {
const [response, json] = await this.client.get(`/routing`) const [response, json] = await this.get(`/routing`)
expect(response).toHaveStatusCode(200)
if (screenExists) { if (screenExists) {
expect(json.routes["/test"]).toBeTruthy() expect(json.routes["/test"]).toBeTruthy()
} else { } else {
@ -141,16 +124,16 @@ export default class AppAPI {
} }
async unpublish(appId: string): Promise<[Response]> { async unpublish(appId: string): Promise<[Response]> {
const [response, json] = await this.client.post( const [response, json] = await this.post(
`/applications/${appId}/unpublish` `/applications/${appId}/unpublish`,
undefined,
204
) )
expect(response).toHaveStatusCode(204)
return [response] return [response]
} }
async unlock(appId: string): Promise<[Response, MessageResponse]> { async unlock(appId: string): Promise<[Response, MessageResponse]> {
const [response, json] = await this.client.del(`/dev/${appId}/lock`) const [response, json] = await this.del(`/dev/${appId}/lock`)
expect(response).toHaveStatusCode(200)
expect(json.message).toEqual("Lock released successfully.") expect(json.message).toEqual("Lock released successfully.")
return [response, json] return [response, json]
} }
@ -162,10 +145,7 @@ export default class AppAPI {
color: "var(--spectrum-global-color-red-400)", color: "var(--spectrum-global-color-red-400)",
}, },
} }
const [response, json] = await this.client.put(`/applications/${appId}`, { const [response, json] = await this.put(`/applications/${appId}`, body)
body,
})
expect(response).toHaveStatusCode(200)
expect(json.icon.name).toEqual(body.icon.name) expect(json.icon.name).toEqual(body.icon.name)
expect(json.icon.color).toEqual(body.icon.color) expect(json.icon.color).toEqual(body.icon.color)
return [response, json] return [response, json]

View File

@ -5,41 +5,34 @@ import {
UpdateDatasourceResponse, UpdateDatasourceResponse,
} from "@budibase/types" } from "@budibase/types"
import BudibaseInternalAPIClient from "../BudibaseInternalAPIClient" import BudibaseInternalAPIClient from "../BudibaseInternalAPIClient"
import BaseAPI from "./BaseAPI"
export default class DatasourcesAPI { export default class DatasourcesAPI extends BaseAPI {
client: BudibaseInternalAPIClient
constructor(client: BudibaseInternalAPIClient) { constructor(client: BudibaseInternalAPIClient) {
this.client = client super(client)
} }
async getIntegrations(): Promise<[Response, any]> { async getIntegrations(): Promise<[Response, any]> {
const [response, json] = await this.client.get(`/integrations`) const [response, json] = await this.get(`/integrations`)
expect(response).toHaveStatusCode(200)
const integrationsCount = Object.keys(json).length const integrationsCount = Object.keys(json).length
expect(integrationsCount).toBe(16) expect(integrationsCount).toBe(16)
return [response, json] return [response, json]
} }
async getAll(): Promise<[Response, Datasource[]]> { async getAll(): Promise<[Response, Datasource[]]> {
const [response, json] = await this.client.get(`/datasources`) const [response, json] = await this.get(`/datasources`)
expect(response).toHaveStatusCode(200)
expect(json.length).toBeGreaterThan(0) expect(json.length).toBeGreaterThan(0)
return [response, json] return [response, json]
} }
async getTable(dataSourceId: string): Promise<[Response, Datasource]> { async getTable(dataSourceId: string): Promise<[Response, Datasource]> {
const [response, json] = await this.client.get( const [response, json] = await this.get(`/datasources/${dataSourceId}`)
`/datasources/${dataSourceId}`
)
expect(response).toHaveStatusCode(200)
expect(json._id).toEqual(dataSourceId) expect(json._id).toEqual(dataSourceId)
return [response, json] return [response, json]
} }
async add(body: any): Promise<[Response, CreateDatasourceResponse]> { async add(body: any): Promise<[Response, CreateDatasourceResponse]> {
const [response, json] = await this.client.post(`/datasources`, { body }) const [response, json] = await this.post(`/datasources`, body)
expect(response).toHaveStatusCode(200)
expect(json.datasource._id).toBeDefined() expect(json.datasource._id).toBeDefined()
expect(json.datasource._rev).toBeDefined() expect(json.datasource._rev).toBeDefined()
@ -47,10 +40,7 @@ export default class DatasourcesAPI {
} }
async update(body: any): Promise<[Response, UpdateDatasourceResponse]> { async update(body: any): Promise<[Response, UpdateDatasourceResponse]> {
const [response, json] = await this.client.put(`/datasources/${body._id}`, { const [response, json] = await this.put(`/datasources/${body._id}`, body)
body,
})
expect(response).toHaveStatusCode(200)
expect(json.datasource._id).toBeDefined() expect(json.datasource._id).toBeDefined()
expect(json.datasource._rev).toBeDefined() expect(json.datasource._rev).toBeDefined()
@ -58,38 +48,32 @@ export default class DatasourcesAPI {
} }
async previewQuery(body: any): Promise<[Response, any]> { async previewQuery(body: any): Promise<[Response, any]> {
const [response, json] = await this.client.post(`/queries/preview`, { const [response, json] = await this.post(`/queries/preview`, body)
body,
})
expect(response).toHaveStatusCode(200)
return [response, json] return [response, json]
} }
async saveQuery(body: any): Promise<[Response, any]> { async saveQuery(body: any): Promise<[Response, any]> {
const [response, json] = await this.client.post(`/queries`, { const [response, json] = await this.post(`/queries`, body)
body,
})
expect(response).toHaveStatusCode(200)
return [response, json] return [response, json]
} }
async getQuery(queryId: string): Promise<[Response, any]> { async getQuery(queryId: string): Promise<[Response, any]> {
const [response, json] = await this.client.get(`/queries/${queryId}`) const [response, json] = await this.get(`/queries/${queryId}`)
expect(response).toHaveStatusCode(200)
return [response, json] return [response, json]
} }
async getQueryPermissions(queryId: string): Promise<[Response, any]> { async getQueryPermissions(queryId: string): Promise<[Response, any]> {
const [response, json] = await this.client.get(`/permissions/${queryId}`) const [response, json] = await this.get(`/permissions/${queryId}`)
expect(response).toHaveStatusCode(200)
return [response, json] return [response, json]
} }
async delete(dataSourceId: string, revId: string): Promise<Response> { async delete(dataSourceId: string, revId: string): Promise<Response> {
const [response, json] = await this.client.del( const [response, json] = await this.del(
`/datasources/${dataSourceId}/${revId}` `/datasources/${dataSourceId}/${revId}`
) )
expect(response).toHaveStatusCode(200)
return response return response
} }
} }

View File

@ -1,16 +1,14 @@
import { Response } from "node-fetch" import { Response } from "node-fetch"
import BudibaseInternalAPIClient from "../BudibaseInternalAPIClient" import BudibaseInternalAPIClient from "../BudibaseInternalAPIClient"
import BaseAPI from "./BaseAPI"
export default class IntegrationsAPI { export default class IntegrationsAPI extends BaseAPI {
client: BudibaseInternalAPIClient
constructor(client: BudibaseInternalAPIClient) { constructor(client: BudibaseInternalAPIClient) {
this.client = client super(client)
} }
async getAll(): Promise<[Response, any]> { async getAll(): Promise<[Response, any]> {
const [response, json] = await this.client.get(`/integrations`) const [response, json] = await this.get(`/integrations`)
expect(response).toHaveStatusCode(200)
const integrationsCount = Object.keys(json).length const integrationsCount = Object.keys(json).length
expect(integrationsCount).toBeGreaterThan(0) expect(integrationsCount).toBeGreaterThan(0)
return [response, json] return [response, json]

View File

@ -1,16 +1,14 @@
import { Response } from "node-fetch" import { Response } from "node-fetch"
import BudibaseInternalAPIClient from "../BudibaseInternalAPIClient" import BudibaseInternalAPIClient from "../BudibaseInternalAPIClient"
import BaseAPI from "./BaseAPI"
export default class PermissionsAPI { export default class PermissionsAPI extends BaseAPI {
client: BudibaseInternalAPIClient
constructor(client: BudibaseInternalAPIClient) { constructor(client: BudibaseInternalAPIClient) {
this.client = client super(client)
} }
async getAll(id: string): Promise<[Response, any]> { async getAll(id: string): Promise<[Response, any]> {
const [response, json] = await this.client.get(`/permissions/${id}`) const [response, json] = await this.get(`/permissions/${id}`)
expect(response).toHaveStatusCode(200)
return [response, json] return [response, json]
} }
} }

View File

@ -1,33 +1,25 @@
import { Response } from "node-fetch" import { Response } from "node-fetch"
import BudibaseInternalAPIClient from "../BudibaseInternalAPIClient" import BudibaseInternalAPIClient from "../BudibaseInternalAPIClient"
import { PreviewQueryRequest, Query } from "@budibase/types" import { PreviewQueryRequest, Query } from "@budibase/types"
import BaseAPI from "./BaseAPI"
export default class DatasourcesAPI { export default class DatasourcesAPI extends BaseAPI {
client: BudibaseInternalAPIClient
constructor(client: BudibaseInternalAPIClient) { constructor(client: BudibaseInternalAPIClient) {
this.client = client super(client)
} }
async preview(body: PreviewQueryRequest): Promise<[Response, any]> { async preview(body: PreviewQueryRequest): Promise<[Response, any]> {
const [response, json] = await this.client.post(`/queries/preview`, { const [response, json] = await this.post(`/queries/preview`, body)
body,
})
expect(response).toHaveStatusCode(200)
return [response, json] return [response, json]
} }
async save(body: Query): Promise<[Response, any]> { async save(body: Query): Promise<[Response, any]> {
const [response, json] = await this.client.post(`/queries`, { const [response, json] = await this.post(`/queries`, body)
body,
})
expect(response).toHaveStatusCode(200)
return [response, json] return [response, json]
} }
async get(queryId: string): Promise<[Response, any]> { async get(queryId: string): Promise<[Response, any]> {
const [response, json] = await this.client.get(`/queries/${queryId}`) const [response, json] = await this.get(`/queries/${queryId}`)
expect(response).toHaveStatusCode(200)
return [response, json] return [response, json]
} }
} }

View File

@ -1,23 +1,20 @@
import { Response } from "node-fetch" import { Response } from "node-fetch"
import { Role, UserRoles } from "@budibase/types" import { Role, UserRoles } from "@budibase/types"
import BudibaseInternalAPIClient from "../BudibaseInternalAPIClient" import BudibaseInternalAPIClient from "../BudibaseInternalAPIClient"
import BaseAPI from "./BaseAPI"
export default class RoleAPI { export default class RoleAPI extends BaseAPI {
client: BudibaseInternalAPIClient
constructor(client: BudibaseInternalAPIClient) { constructor(client: BudibaseInternalAPIClient) {
this.client = client super(client)
} }
async getRoles(): Promise<[Response, Role[]]> { async getRoles(): Promise<[Response, Role[]]> {
const [response, json] = await this.client.get(`/roles`) const [response, json] = await this.get(`/roles`)
expect(response).toHaveStatusCode(200)
return [response, json] return [response, json]
} }
async createRole(body: Partial<UserRoles>): Promise<[Response, UserRoles]> { async createRole(body: Partial<UserRoles>): Promise<[Response, UserRoles]> {
const [response, json] = await this.client.post(`/roles`, { body }) const [response, json] = await this.post(`/roles`, body)
expect(response).toHaveStatusCode(200)
return [response, json] return [response, json]
} }
} }

View File

@ -1,29 +1,25 @@
import { Response } from "node-fetch" import { Response } from "node-fetch"
import { Row } from "@budibase/types" import { Row } from "@budibase/types"
import BudibaseInternalAPIClient from "../BudibaseInternalAPIClient" import BudibaseInternalAPIClient from "../BudibaseInternalAPIClient"
import BaseAPI from "./BaseAPI"
export default class RowAPI { export default class RowAPI extends BaseAPI {
rowAdded: boolean rowAdded: boolean
client: BudibaseInternalAPIClient
constructor(client: BudibaseInternalAPIClient) { constructor(client: BudibaseInternalAPIClient) {
this.client = client super(client)
this.rowAdded = false this.rowAdded = false
} }
async getAll(tableId: string): Promise<[Response, Row[]]> { async getAll(tableId: string): Promise<[Response, Row[]]> {
const [response, json] = await this.client.get(`/${tableId}/rows`) const [response, json] = await this.get(`/${tableId}/rows`)
if (this.rowAdded) { if (this.rowAdded) {
expect(response).toHaveStatusCode(200)
expect(json.length).toBeGreaterThanOrEqual(1) expect(json.length).toBeGreaterThanOrEqual(1)
} }
return [response, json] return [response, json]
} }
async add(tableId: string, body: any): Promise<[Response, Row]> { async add(tableId: string, body: any): Promise<[Response, Row]> {
const [response, json] = await this.client.post(`/${tableId}/rows`, { const [response, json] = await this.post(`/${tableId}/rows`, body)
body,
})
expect(response).toHaveStatusCode(200)
expect(json._id).toBeDefined() expect(json._id).toBeDefined()
expect(json._rev).toBeDefined() expect(json._rev).toBeDefined()
expect(json.tableId).toEqual(tableId) expect(json.tableId).toEqual(tableId)
@ -32,10 +28,7 @@ export default class RowAPI {
} }
async delete(tableId: string, body: any): Promise<[Response, Row[]]> { async delete(tableId: string, body: any): Promise<[Response, Row[]]> {
const [response, json] = await this.client.del(`/${tableId}/rows/`, { const [response, json] = await this.del(`/${tableId}/rows/`, body)
body,
})
expect(response).toHaveStatusCode(200)
return [response, json] return [response, json]
} }
@ -43,10 +36,7 @@ export default class RowAPI {
tableId: string, tableId: string,
body: any body: any
): Promise<[Response, Row[]]> { ): Promise<[Response, Row[]]> {
const [response, json] = await this.client.post(`/${tableId}/search`, { const [response, json] = await this.post(`/${tableId}/search`, body)
body,
})
expect(response).toHaveStatusCode(200)
expect(json.hasNextPage).toEqual(false) expect(json.hasNextPage).toEqual(false)
return [response, json.rows] return [response, json.rows]
} }
@ -55,10 +45,7 @@ export default class RowAPI {
tableId: string, tableId: string,
body: any body: any
): Promise<[Response, Row[]]> { ): Promise<[Response, Row[]]> {
const [response, json] = await this.client.post(`/${tableId}/search`, { const [response, json] = await this.post(`/${tableId}/search`, body)
body,
})
expect(response).toHaveStatusCode(200)
expect(json.hasNextPage).toEqual(true) expect(json.hasNextPage).toEqual(true)
expect(json.rows.length).toEqual(10) expect(json.rows.length).toEqual(10)
return [response, json.rows] return [response, json.rows]

View File

@ -1,27 +1,22 @@
import { Screen } from "@budibase/types" import { Screen } from "@budibase/types"
import { Response } from "node-fetch" import { Response } from "node-fetch"
import BudibaseInternalAPIClient from "../BudibaseInternalAPIClient" import BudibaseInternalAPIClient from "../BudibaseInternalAPIClient"
import BaseAPI from "./BaseAPI"
export default class ScreenAPI { export default class ScreenAPI extends BaseAPI {
client: BudibaseInternalAPIClient
constructor(client: BudibaseInternalAPIClient) { constructor(client: BudibaseInternalAPIClient) {
this.client = client super(client)
} }
async create(body: any): Promise<[Response, Screen]> { async create(body: any): Promise<[Response, Screen]> {
const [response, json] = await this.client.post(`/screens`, { body }) const [response, json] = await this.post(`/screens`, body)
expect(response).toHaveStatusCode(200)
expect(json._id).toBeDefined() expect(json._id).toBeDefined()
expect(json.routing.roleId).toBe(body.routing.roleId) expect(json.routing.roleId).toBe(body.routing.roleId)
return [response, json] return [response, json]
} }
async delete(screenId: string, rev: string): Promise<[Response, Screen]> { async delete(screenId: string, rev: string): Promise<[Response, Screen]> {
const [response, json] = await this.client.del( const [response, json] = await this.del(`/screens/${screenId}/${rev}`)
`/screens/${screenId}/${rev}`
)
expect(response).toHaveStatusCode(200)
return [response, json] return [response, json]
} }
} }

View File

@ -2,31 +2,27 @@ import { Response } from "node-fetch"
import { User } from "@budibase/types" import { User } from "@budibase/types"
import BudibaseInternalAPIClient from "../BudibaseInternalAPIClient" import BudibaseInternalAPIClient from "../BudibaseInternalAPIClient"
import { ApiKeyResponse } from "../../../types" import { ApiKeyResponse } from "../../../types"
import BaseAPI from "./BaseAPI"
export default class SelfAPI { export default class SelfAPI extends BaseAPI {
client: BudibaseInternalAPIClient
constructor(client: BudibaseInternalAPIClient) { constructor(client: BudibaseInternalAPIClient) {
this.client = client super(client)
} }
async getSelf(): Promise<[Response, Partial<User>]> { async getSelf(): Promise<[Response, Partial<User>]> {
const [response, json] = await this.client.get(`/global/self`) const [response, json] = await this.get(`/global/self`)
expect(response).toHaveStatusCode(200)
return [response, json] return [response, json]
} }
async changeSelfPassword(body: Partial<User>): Promise<[Response, User]> { async changeSelfPassword(body: Partial<User>): Promise<[Response, User]> {
const [response, json] = await this.client.post(`/global/self`, { body }) const [response, json] = await this.post(`/global/self`, body)
expect(response).toHaveStatusCode(200)
expect(json._id).toEqual(body._id) expect(json._id).toEqual(body._id)
expect(json._rev).not.toEqual(body._rev) expect(json._rev).not.toEqual(body._rev)
return [response, json] return [response, json]
} }
async getApiKey(): Promise<ApiKeyResponse> { async getApiKey(): Promise<ApiKeyResponse> {
const [response, json] = await this.client.get(`/global/self/api_key`) const [response, json] = await this.get(`/global/self/api_key`)
expect(response).toHaveStatusCode(200)
expect(json).toHaveProperty("apiKey") expect(json).toHaveProperty("apiKey")
return json return json
} }

View File

@ -2,31 +2,27 @@ import { Response } from "node-fetch"
import { Table } from "@budibase/types" import { Table } from "@budibase/types"
import BudibaseInternalAPIClient from "../BudibaseInternalAPIClient" import BudibaseInternalAPIClient from "../BudibaseInternalAPIClient"
import { MessageResponse } from "../../../types" import { MessageResponse } from "../../../types"
import BaseAPI from "./BaseAPI"
export default class TableAPI { export default class TableAPI extends BaseAPI {
client: BudibaseInternalAPIClient
constructor(client: BudibaseInternalAPIClient) { constructor(client: BudibaseInternalAPIClient) {
this.client = client super(client)
} }
async getAll(expectedNumber: Number): Promise<[Response, Table[]]> { async getAll(expectedNumber: Number): Promise<[Response, Table[]]> {
const [response, json] = await this.client.get(`/tables`) const [response, json] = await this.get(`/tables`)
expect(response).toHaveStatusCode(200)
expect(json.length).toBe(expectedNumber) expect(json.length).toBe(expectedNumber)
return [response, json] return [response, json]
} }
async getTableById(id: string): Promise<[Response, Table]> { async getTableById(id: string): Promise<[Response, Table]> {
const [response, json] = await this.client.get(`/tables/${id}`) const [response, json] = await this.get(`/tables/${id}`)
expect(response).toHaveStatusCode(200)
expect(json._id).toEqual(id) expect(json._id).toEqual(id)
return [response, json] return [response, json]
} }
async save(body: any, columnAdded?: boolean): Promise<[Response, Table]> { async save(body: any, columnAdded?: boolean): Promise<[Response, Table]> {
const [response, json] = await this.client.post(`/tables`, { body }) const [response, json] = await this.post(`/tables`, body)
expect(response).toHaveStatusCode(200)
expect(json._id).toBeDefined() expect(json._id).toBeDefined()
expect(json._rev).toBeDefined() expect(json._rev).toBeDefined()
if (columnAdded) { if (columnAdded) {
@ -37,9 +33,7 @@ export default class TableAPI {
} }
async forbiddenSave(body: any): Promise<[Response, Table]> { async forbiddenSave(body: any): Promise<[Response, Table]> {
const [response, json] = await this.client.post(`/tables`, { body }) const [response, json] = await this.post(`/tables`, body, 403)
expect(response).toHaveStatusCode(403)
return [response, json] return [response, json]
} }
@ -47,8 +41,7 @@ export default class TableAPI {
id: string, id: string,
revId: string revId: string
): Promise<[Response, MessageResponse]> { ): Promise<[Response, MessageResponse]> {
const [response, json] = await this.client.del(`/tables/${id}/${revId}`) const [response, json] = await this.del(`/tables/${id}/${revId}`)
expect(response).toHaveStatusCode(200)
expect(json.message).toEqual(`Table ${id} deleted.`) expect(json.message).toEqual(`Table ${id} deleted.`)
return [response, json] return [response, json]
} }

View File

@ -2,30 +2,29 @@ import { Response } from "node-fetch"
import { Role, User, UserDeletedEvent, UserRoles } from "@budibase/types" import { Role, User, UserDeletedEvent, UserRoles } from "@budibase/types"
import BudibaseInternalAPIClient from "../BudibaseInternalAPIClient" import BudibaseInternalAPIClient from "../BudibaseInternalAPIClient"
import { MessageResponse } from "../../../types" import { MessageResponse } from "../../../types"
import BaseAPI from "./BaseAPI"
export default class UserAPI { export default class UserAPI extends BaseAPI {
client: BudibaseInternalAPIClient
constructor(client: BudibaseInternalAPIClient) { constructor(client: BudibaseInternalAPIClient) {
this.client = client super(client)
} }
async search(): Promise<[Response, Partial<User>[]]> { async search(): Promise<[Response, Partial<User>[]]> {
const [response, json] = await this.client.post(`/global/users/search`, {}) const [response, json] = await this.post(`/global/users/search`, {})
expect(response).toHaveStatusCode(200)
expect(json.data.length).toBeGreaterThan(0) expect(json.data.length).toBeGreaterThan(0)
return [response, json] return [response, json]
} }
async getSelf(): Promise<[Response, Partial<User>]> { async getSelf(): Promise<[Response, Partial<User>]> {
const [response, json] = await this.client.get(`/global/self`) const [response, json] = await this.get(`/global/self`)
expect(response).toHaveStatusCode(200)
return [response, json] return [response, json]
} }
async getAll(): Promise<[Response, Partial<User>[]]> { async getAll(): Promise<[Response, Partial<User>[]]> {
const [response, json] = await this.client.get(`/global/users`) const [response, json] = await this.get(`/global/users`)
expect(response).toHaveStatusCode(200)
expect(json.length).toBeGreaterThan(0) expect(json.length).toBeGreaterThan(0)
return [response, json] return [response, json]
} }
@ -38,10 +37,8 @@ export default class UserAPI {
groups: [], groups: [],
}, },
} }
const [response, json] = await this.client.post(`/global/users/bulk`, { const [response, json] = await this.post(`/global/users/bulk`, body)
body,
})
expect(response).toHaveStatusCode(200)
expect(json.created.unsuccessful.length).toEqual(0) expect(json.created.unsuccessful.length).toEqual(0)
expect(json.created.successful.length).toEqual(body.create.users.length) expect(json.created.successful.length).toEqual(body.create.users.length)
return [response, json] return [response, json]
@ -53,73 +50,58 @@ export default class UserAPI {
userIds: [userId], userIds: [userId],
}, },
} }
const [response, json] = await this.client.post(`/global/users/bulk`, { const [response, json] = await this.post(`/global/users/bulk`, body)
body,
})
expect(response).toHaveStatusCode(200)
expect(json.deleted.successful.length).toEqual(1) expect(json.deleted.successful.length).toEqual(1)
expect(json.deleted.unsuccessful.length).toEqual(0) expect(json.deleted.unsuccessful.length).toEqual(0)
expect(json.deleted.successful[0].userId).toEqual(userId) expect(json.deleted.successful[0].userId).toEqual(userId)
return [response, json] return [response, json]
} }
async delete(userId: string): Promise<[Response, UserDeletedEvent]> { async delete(userId: string): Promise<[Response, UserDeletedEvent]> {
const [response, json] = await this.client.del(`/global/users/${userId}`) const [response, json] = await this.del(`/global/users/${userId}`)
expect(response).toHaveStatusCode(200)
expect(json.message).toEqual(`User ${userId} deleted.`) expect(json.message).toEqual(`User ${userId} deleted.`)
return [response, json] return [response, json]
} }
async invite(body: any): Promise<[Response, MessageResponse]> { async invite(body: any): Promise<[Response, MessageResponse]> {
const [response, json] = await this.client.post( const [response, json] = await this.post(`/global/users/multi/invite`, body)
`/global/users/multi/invite`,
{ body }
)
expect(response).toHaveStatusCode(200)
expect(json.unsuccessful.length).toEqual(0) expect(json.unsuccessful.length).toEqual(0)
expect(json.successful.length).toEqual(body.length) expect(json.successful.length).toEqual(body.length)
return [response, json] return [response, json]
} }
async getRoles(): Promise<[Response, Role[]]> { async getRoles(): Promise<[Response, Role[]]> {
const [response, json] = await this.client.get(`/roles`) const [response, json] = await this.get(`/roles`)
expect(response).toHaveStatusCode(200)
return [response, json] return [response, json]
} }
async updateInfo(body: any): Promise<[Response, User]> { async updateInfo(body: any): Promise<[Response, User]> {
const [response, json] = await this.client.post(`/global/users/`, { body }) const [response, json] = await this.post(`/global/users/`, body)
expect(response).toHaveStatusCode(200)
expect(json._id).toEqual(body._id) expect(json._id).toEqual(body._id)
expect(json._rev).not.toEqual(body._rev) expect(json._rev).not.toEqual(body._rev)
return [response, json] return [response, json]
} }
async forcePasswordReset(body: any): Promise<[Response, User]> { async forcePasswordReset(body: any): Promise<[Response, User]> {
const [response, json] = await this.client.post(`/global/users/`, { body }) const [response, json] = await this.post(`/global/users/`, body)
expect(response).toHaveStatusCode(200)
expect(json._id).toEqual(body._id) expect(json._id).toEqual(body._id)
expect(json._rev).not.toEqual(body._rev) expect(json._rev).not.toEqual(body._rev)
return [response, json] return [response, json]
} }
async getInfo(userId: string): Promise<[Response, User]> { async getInfo(userId: string): Promise<[Response, User]> {
const [response, json] = await this.client.get(`/global/users/${userId}`) const [response, json] = await this.get(`/global/users/${userId}`)
expect(response).toHaveStatusCode(200)
return [response, json] return [response, json]
} }
async changeSelfPassword(body: Partial<User>): Promise<[Response, User]> { async changeSelfPassword(body: Partial<User>): Promise<[Response, User]> {
const [response, json] = await this.client.post(`/global/self`, { body }) const [response, json] = await this.post(`/global/self`, body)
expect(response).toHaveStatusCode(200)
expect(json._id).toEqual(body._id) expect(json._id).toEqual(body._id)
expect(json._rev).not.toEqual(body._rev) expect(json._rev).not.toEqual(body._rev)
return [response, json] return [response, json]
} }
async createRole(body: Partial<UserRoles>): Promise<[Response, UserRoles]> { async createRole(body: Partial<UserRoles>): Promise<[Response, UserRoles]> {
const [response, json] = await this.client.post(`/roles`, { body }) const [response, json] = await this.post(`/roles`, body)
expect(response).toHaveStatusCode(200)
return [response, json] return [response, json]
} }
} }