Fixing test case.

This commit is contained in:
mike12345567 2022-10-21 18:52:39 +01:00
parent a191989fdf
commit 49e103e8ef
5 changed files with 75 additions and 58 deletions

View File

@ -21,7 +21,7 @@ describe("/backups", () => {
.set(config.defaultHeaders()) .set(config.defaultHeaders())
.expect(200) .expect(200)
expect(res.text).toBeDefined() expect(res.text).toBeDefined()
expect(res.text.includes(`"db_name":"${config.getAppId()}"`)).toEqual(true) expect(res.headers["content-type"]).toEqual("application/gzip")
expect(events.app.exported.mock.calls.length).toBe(1) expect(events.app.exported.mock.calls.length).toBe(1)
}) })

View File

@ -1,7 +1,7 @@
import { db as dbCore } from "@budibase/backend-core" import { db as dbCore } from "@budibase/backend-core"
import { budibaseTempDir } from "../../../utilities/budibaseDir" import { budibaseTempDir } from "../../../utilities/budibaseDir"
import { retrieveDirectory } from "../../../utilities/fileSystem/utilities" import { retrieveDirectory } from "../../../utilities/fileSystem/utilities"
import { streamFile } from "../../../utilities/fileSystem" import { streamFile, createTempFolder } from "../../../utilities/fileSystem"
import { ObjectStoreBuckets } from "../../../constants" import { ObjectStoreBuckets } from "../../../constants"
import { import {
LINK_USER_METADATA_PREFIX, LINK_USER_METADATA_PREFIX,
@ -11,6 +11,7 @@ import {
import { DB_EXPORT_FILE, GLOBAL_DB_EXPORT_FILE } from "./constants" import { DB_EXPORT_FILE, GLOBAL_DB_EXPORT_FILE } from "./constants"
import fs from "fs" import fs from "fs"
import { join } from "path" import { join } from "path"
import env from "../../../environment"
const uuid = require("uuid/v4") const uuid = require("uuid/v4")
const tar = require("tar") const tar = require("tar")
const MemoryStream = require("memorystream") const MemoryStream = require("memorystream")
@ -85,7 +86,12 @@ export async function exportApp(appId: string, config?: ExportOpts) {
const prodAppId = dbCore.getProdAppID(appId) const prodAppId = dbCore.getProdAppID(appId)
const appPath = `${prodAppId}/` const appPath = `${prodAppId}/`
// export bucket contents // export bucket contents
const tmpPath = await retrieveDirectory(ObjectStoreBuckets.APPS, appPath) let tmpPath
if (!env.isTest()) {
tmpPath = await retrieveDirectory(ObjectStoreBuckets.APPS, appPath)
} else {
tmpPath = createTempFolder(uuid())
}
const downloadedPath = join(tmpPath, appPath) const downloadedPath = join(tmpPath, appPath)
if (fs.existsSync(downloadedPath)) { if (fs.existsSync(downloadedPath)) {
const allFiles = fs.readdirSync(downloadedPath) const allFiles = fs.readdirSync(downloadedPath)

View File

@ -1,23 +1,23 @@
import { Screen } from "@budibase/types" import { Screen } from "@budibase/types"
import { Response } from "node-fetch" import { Response } from "node-fetch"
import InternalAPIClient from "./InternalAPIClient" import InternalAPIClient from "./InternalAPIClient"
export default class ScreenApi {
api: InternalAPIClient
constructor(apiClient: InternalAPIClient) {
this.api = apiClient
}
async create(body: any): Promise<[Response, Screen]> {
const response = await this.api.post(`/screens`, { body })
const json = await response.json()
return [response, json]
}
async delete(screenId: string, rev: string): Promise<[Response, Screen]> { export default class ScreenApi {
const response = await this.api.del(`/screens/${screenId}/${rev}`) api: InternalAPIClient
const json = await response.json()
return [response, json] constructor(apiClient: InternalAPIClient) {
} this.api = apiClient
} }
async create(body: any): Promise<[Response, Screen]> {
const response = await this.api.post(`/screens`, { body })
const json = await response.json()
return [response, json]
}
async delete(screenId: string, rev: string): Promise<[Response, Screen]> {
const response = await this.api.del(`/screens/${screenId}/${rev}`)
const json = await response.json()
return [response, json]
}
}

View File

@ -3,32 +3,32 @@ import generator from "../../generator"
const randomId = generator.guid() const randomId = generator.guid()
const generateScreen = (roleId: string): any => ({ const generateScreen = (roleId: string): any => ({
showNavigation: true, showNavigation: true,
width: "Large", width: "Large",
name: randomId, name: randomId,
template: "createFromScratch", template: "createFromScratch",
props: { props: {
_id: randomId, _id: randomId,
_component: _component: "@budibase/standard-components/container",
"@budibase/standard-components/container", _styles: {
_styles: { normal: {},
normal: {}, hover: {},
hover: {}, active: {},
active: {}, selected: {},
selected: {}
},
_children: [],
_instanceName: "New Screen",
direction: "column",
hAlign: "stretch",
vAlign: "top",
size: "grow",
gap: "M"
}, routing: {
route: "/test",
roleId: roleId,
homeScreen: false
}, },
_children: [],
_instanceName: "New Screen",
direction: "column",
hAlign: "stretch",
vAlign: "top",
size: "grow",
gap: "M",
},
routing: {
route: "/test",
roleId: roleId,
homeScreen: false,
},
}) })
export default generateScreen export default generateScreen

View File

@ -2,10 +2,9 @@ import TestConfiguration from "../../../config/internal-api/TestConfiguration"
import { App } from "@budibase/types" import { App } from "@budibase/types"
import InternalAPIClient from "../../../config/internal-api/TestConfiguration/InternalAPIClient" import InternalAPIClient from "../../../config/internal-api/TestConfiguration/InternalAPIClient"
import generateApp from "../../../config/internal-api/fixtures/applications" import generateApp from "../../../config/internal-api/fixtures/applications"
import { Screen } from "@budibase/types" import { Screen } from "@budibase/types"
import generateScreen from "../../../config/internal-api/fixtures/screens" import generateScreen from "../../../config/internal-api/fixtures/screens"
describe("Internal API - /screens endpoints", () => { describe("Internal API - /screens endpoints", () => {
const api = new InternalAPIClient() const api = new InternalAPIClient()
const config = new TestConfiguration<Screen>(api) const config = new TestConfiguration<Screen>(api)
@ -21,13 +20,17 @@ describe("Internal API - /screens endpoints", () => {
it("POST - Create a screen with each role type", async () => { it("POST - Create a screen with each role type", async () => {
// Create app // Create app
const [appResponse, app] = await appConfig.applications.create(generateApp()) const [appResponse, app] = await appConfig.applications.create(
generateApp()
)
// Create Screen // Create Screen
const roleArray = ["BASIC", "POWER", "ADMIN", "PUBLIC"] const roleArray = ["BASIC", "POWER", "ADMIN", "PUBLIC"]
appConfig.applications.api.appId = app.appId appConfig.applications.api.appId = app.appId
for (let role in roleArray) { for (let role in roleArray) {
const [response, screen] = await config.screen.create(generateScreen(roleArray[role])) const [response, screen] = await config.screen.create(
generateScreen(roleArray[role])
)
expect(response).toHaveStatusCode(200) expect(response).toHaveStatusCode(200)
expect(screen.routing.roleId).toEqual(roleArray[role]) expect(screen.routing.roleId).toEqual(roleArray[role])
} }
@ -35,11 +38,15 @@ describe("Internal API - /screens endpoints", () => {
it("GET - Fetch screens", async () => { it("GET - Fetch screens", async () => {
// Create app // Create app
const [appResponse, app] = await appConfig.applications.create(generateApp()) const [appResponse, app] = await appConfig.applications.create(
generateApp()
)
// Create Screen // Create Screen
appConfig.applications.api.appId = app.appId appConfig.applications.api.appId = app.appId
const [response, screen] = await config.screen.create(generateScreen("BASIC")) const [response, screen] = await config.screen.create(
generateScreen("BASIC")
)
// Check screen exists // Check screen exists
const [routesResponse, routes] = await appConfig.applications.getRoutes() const [routesResponse, routes] = await appConfig.applications.getRoutes()
@ -49,11 +56,15 @@ describe("Internal API - /screens endpoints", () => {
it("DELETE - Delete a screen", async () => { it("DELETE - Delete a screen", async () => {
// Create app // Create app
const [appResponse, app] = await appConfig.applications.create(generateApp()) const [appResponse, app] = await appConfig.applications.create(
generateApp()
)
// Create Screen // Create Screen
appConfig.applications.api.appId = app.appId appConfig.applications.api.appId = app.appId
const [screenResponse, screen] = await config.screen.create(generateScreen("BASIC")) const [screenResponse, screen] = await config.screen.create(
generateScreen("BASIC")
)
// Delete Screen // Delete Screen
const [response] = await config.screen.delete(screen._id!, screen._rev!) const [response] = await config.screen.delete(screen._id!, screen._rev!)