Improve internal API classes
This commit is contained in:
parent
62238611bf
commit
fc61623e32
|
@ -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]
|
||||||
|
|
|
@ -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
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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]
|
||||||
|
|
|
@ -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]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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]
|
||||||
|
|
|
@ -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]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
||||||
}
|
}
|
||||||
|
|
|
@ -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]
|
||||||
}
|
}
|
||||||
|
|
|
@ -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]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue