From 576f47e4a9b957ed92a9fc336c50f9111712269e Mon Sep 17 00:00:00 2001 From: Pedro Silva Date: Wed, 11 Jan 2023 15:55:41 +0000 Subject: [PATCH] Split application tests --- .../applications/applications.spec.ts | 138 ------------------ .../internal-api/applications/create.spec.ts | 55 +++++++ .../internal-api/applications/delete.spec.ts | 29 ++++ .../internal-api/applications/publish.spec.ts | 70 +++++++++ .../internal-api/applications/update.spec.ts | 58 ++++++++ 5 files changed, 212 insertions(+), 138 deletions(-) delete mode 100644 qa-core/src/tests/internal-api/applications/applications.spec.ts create mode 100644 qa-core/src/tests/internal-api/applications/create.spec.ts create mode 100644 qa-core/src/tests/internal-api/applications/delete.spec.ts create mode 100644 qa-core/src/tests/internal-api/applications/publish.spec.ts create mode 100644 qa-core/src/tests/internal-api/applications/update.spec.ts diff --git a/qa-core/src/tests/internal-api/applications/applications.spec.ts b/qa-core/src/tests/internal-api/applications/applications.spec.ts deleted file mode 100644 index de5f3e1c95..0000000000 --- a/qa-core/src/tests/internal-api/applications/applications.spec.ts +++ /dev/null @@ -1,138 +0,0 @@ -import TestConfiguration from "../../../config/internal-api/TestConfiguration" -import { Application } from "@budibase/server/api/controllers/public/mapping/types" -import { db } from "@budibase/backend-core" -import InternalAPIClient from "../../../config/internal-api/TestConfiguration/InternalAPIClient" -import AccountsAPIClient from "../../../config/internal-api/TestConfiguration/accountsAPIClient" -import { generateApp, appFromTemplate } from "../../../config/internal-api/fixtures/applications" -import generator from "../../../config/generator" -import generateScreen from "../../../config/internal-api/fixtures/screens" - -describe("Internal API - Application creation, update, publish and delete", () => { - const api = new InternalAPIClient() - const accountsAPI = new AccountsAPIClient() - const config = new TestConfiguration(api, accountsAPI) - - beforeEach(async () => { - await config.setupAccountAndTenant() - }) - - afterAll(async () => { - await config.afterAll() - }) - - - it("Get applications without applications", async () => { - await config.applications.fetchEmptyAppList() - }) - - it("Get all Applications after creating an application", async () => { - await config.applications.create({ - ...generateApp(), - useTemplate: false, - }) - - await config.applications.fetchAllApplications() - }) - - it("Get application details", async () => { - const app = await config.applications.create({ - ...generateApp(), - useTemplate: false, - }) - config.applications.api.appId = app.appId - - const [appPackageResponse, appPackageJson] = - await config.applications.getAppPackage(app.appId) - expect(appPackageJson.application.name).toEqual(app.name) - expect(appPackageJson.application.version).toEqual(app.version) - expect(appPackageJson.application.url).toEqual(app.url) - expect(appPackageJson.application.tenantId).toEqual(app.tenantId) - expect(appPackageJson.application.status).toEqual(app.status) - }) - - it("Publish app", async () => { - // create the app - const app = await config.applications.create(appFromTemplate()) - config.applications.api.appId = app.appId - - // check preview renders - await config.applications.canRender() - - // publish app - await config.applications.publish(app.appId) - - // check published app renders - config.applications.api.appId = db.getProdAppID(app.appId!) - await config.applications.canRender() - - // unpublish app - await config.applications.unpublish(app.appId) - }) - - it("Sync application before deployment", async () => { - const app = await config.applications.create(generateApp()) - config.applications.api.appId = app.appId - - const [syncResponse, sync] = await config.applications.sync( - app.appId - ) - expect(sync).toEqual({ - message: "App sync not required, app not deployed.", - }) - }) - - it("Sync application after deployment", async () => { - const app = await config.applications.create(generateApp()) - config.applications.api.appId = app.appId - - // publish app - await config.applications.publish(app._id) - - const [syncResponse, sync] = await config.applications.sync( - app.appId - ) - expect(sync).toEqual({ - message: "App sync completed successfully.", - }) - }) - - it("Update an application", async () => { - const app = await config.applications.create(generateApp()) - - config.applications.api.appId = app.appId - - await config.applications.update(app.appId, app.name, { - name: generator.word(), - }) - }) - - it("Revert Changes without changes", async () => { - const app = await config.applications.create(generateApp()) - config.applications.api.appId = app.appId - - await config.applications.revertUnpublished(app.appId) - }) - - it("Revert Changes", async () => { - const app = await config.applications.create(generateApp()) - config.applications.api.appId = app.appId - - // publish app - await config.applications.publish(app._id) - - // Change/add component to the app - await config.screen.create(generateScreen("BASIC")) - - // // Revert the app to published state - await config.applications.revertPublished(app.appId) - - // Check screen is removed - await config.applications.getRoutes() - }) - - it("DELETE - Delete an application", async () => { - const app = await config.applications.create(generateApp()) - - await config.applications.delete(app.appId) - }) -}) diff --git a/qa-core/src/tests/internal-api/applications/create.spec.ts b/qa-core/src/tests/internal-api/applications/create.spec.ts new file mode 100644 index 0000000000..ba3f4e897b --- /dev/null +++ b/qa-core/src/tests/internal-api/applications/create.spec.ts @@ -0,0 +1,55 @@ +import TestConfiguration from "../../../config/internal-api/TestConfiguration" +import { Application } from "@budibase/server/api/controllers/public/mapping/types" +import { db } from "@budibase/backend-core" +import InternalAPIClient from "../../../config/internal-api/TestConfiguration/InternalAPIClient" +import AccountsAPIClient from "../../../config/internal-api/TestConfiguration/accountsAPIClient" +import { generateApp, appFromTemplate } from "../../../config/internal-api/fixtures/applications" +import generator from "../../../config/generator" +import generateScreen from "../../../config/internal-api/fixtures/screens" + +describe("Internal API - Application creation", () => { + const api = new InternalAPIClient() + const accountsAPI = new AccountsAPIClient() + const config = new TestConfiguration(api, accountsAPI) + + beforeAll(async () => { + await config.setupAccountAndTenant() + }) + + afterAll(async () => { + await config.afterAll() + }) + + + it("Get applications without applications", async () => { + await config.applications.fetchEmptyAppList() + }) + + it("Get all Applications after creating an application", async () => { + await config.applications.create({ + ...generateApp(), + useTemplate: false, + }) + + await config.applications.fetchAllApplications() + }) + + it("Get application details", async () => { + const app = await config.applications.create({ + ...generateApp(), + useTemplate: false, + }) + config.applications.api.appId = app.appId + + const [appPackageResponse, appPackageJson] = + await config.applications.getAppPackage(app.appId) + expect(appPackageJson.application.name).toEqual(app.name) + expect(appPackageJson.application.version).toEqual(app.version) + expect(appPackageJson.application.url).toEqual(app.url) + expect(appPackageJson.application.tenantId).toEqual(app.tenantId) + expect(appPackageJson.application.status).toEqual(app.status) + }) + + + +}) diff --git a/qa-core/src/tests/internal-api/applications/delete.spec.ts b/qa-core/src/tests/internal-api/applications/delete.spec.ts new file mode 100644 index 0000000000..cb427f7a6e --- /dev/null +++ b/qa-core/src/tests/internal-api/applications/delete.spec.ts @@ -0,0 +1,29 @@ +import TestConfiguration from "../../../config/internal-api/TestConfiguration" +import { Application } from "@budibase/server/api/controllers/public/mapping/types" +import { db } from "@budibase/backend-core" +import InternalAPIClient from "../../../config/internal-api/TestConfiguration/InternalAPIClient" +import AccountsAPIClient from "../../../config/internal-api/TestConfiguration/accountsAPIClient" +import { generateApp, appFromTemplate } from "../../../config/internal-api/fixtures/applications" +import generator from "../../../config/generator" +import generateScreen from "../../../config/internal-api/fixtures/screens" + +describe("Internal API - Application creation, update, publish and delete", () => { + const api = new InternalAPIClient() + const accountsAPI = new AccountsAPIClient() + const config = new TestConfiguration(api, accountsAPI) + + beforeAll(async () => { + await config.setupAccountAndTenant() + }) + + afterAll(async () => { + await config.afterAll() + }) + + + it("DELETE - Delete an application", async () => { + const app = await config.applications.create(generateApp()) + + await config.applications.delete(app.appId) + }) +}) diff --git a/qa-core/src/tests/internal-api/applications/publish.spec.ts b/qa-core/src/tests/internal-api/applications/publish.spec.ts new file mode 100644 index 0000000000..6f54dc7f6e --- /dev/null +++ b/qa-core/src/tests/internal-api/applications/publish.spec.ts @@ -0,0 +1,70 @@ +import TestConfiguration from "../../../config/internal-api/TestConfiguration" +import { Application } from "@budibase/server/api/controllers/public/mapping/types" +import { db } from "@budibase/backend-core" +import InternalAPIClient from "../../../config/internal-api/TestConfiguration/InternalAPIClient" +import AccountsAPIClient from "../../../config/internal-api/TestConfiguration/accountsAPIClient" +import { generateApp, appFromTemplate } from "../../../config/internal-api/fixtures/applications" +import generator from "../../../config/generator" +import generateScreen from "../../../config/internal-api/fixtures/screens" + +describe("Internal API - Application creation, update, publish and delete", () => { + const api = new InternalAPIClient() + const accountsAPI = new AccountsAPIClient() + const config = new TestConfiguration(api, accountsAPI) + + beforeAll(async () => { + await config.setupAccountAndTenant() + }) + + afterAll(async () => { + await config.afterAll() + }) + + + it("Publish app", async () => { + // create the app + const app = await config.applications.create(appFromTemplate()) + config.applications.api.appId = app.appId + + // check preview renders + await config.applications.canRender() + + // publish app + await config.applications.publish(app.appId) + + // check published app renders + config.applications.api.appId = db.getProdAppID(app.appId!) + await config.applications.canRender() + + // unpublish app + await config.applications.unpublish(app.appId) + }) + + it("Sync application before deployment", async () => { + const app = await config.applications.create(generateApp()) + config.applications.api.appId = app.appId + + const [syncResponse, sync] = await config.applications.sync( + app.appId + ) + expect(sync).toEqual({ + message: "App sync not required, app not deployed.", + }) + }) + + it("Sync application after deployment", async () => { + const app = await config.applications.create(generateApp()) + config.applications.api.appId = app.appId + + // publish app + await config.applications.publish(app._id) + + const [syncResponse, sync] = await config.applications.sync( + app.appId + ) + expect(sync).toEqual({ + message: "App sync completed successfully.", + }) + }) + +}) diff --git a/qa-core/src/tests/internal-api/applications/update.spec.ts b/qa-core/src/tests/internal-api/applications/update.spec.ts new file mode 100644 index 0000000000..d85d39f4c9 --- /dev/null +++ b/qa-core/src/tests/internal-api/applications/update.spec.ts @@ -0,0 +1,58 @@ +import TestConfiguration from "../../../config/internal-api/TestConfiguration" +import { Application } from "@budibase/server/api/controllers/public/mapping/types" +import { db } from "@budibase/backend-core" +import InternalAPIClient from "../../../config/internal-api/TestConfiguration/InternalAPIClient" +import AccountsAPIClient from "../../../config/internal-api/TestConfiguration/accountsAPIClient" +import { generateApp, appFromTemplate } from "../../../config/internal-api/fixtures/applications" +import generator from "../../../config/generator" +import generateScreen from "../../../config/internal-api/fixtures/screens" + +describe("Internal API - Application creation, update, publish and delete", () => { + const api = new InternalAPIClient() + const accountsAPI = new AccountsAPIClient() + const config = new TestConfiguration(api, accountsAPI) + + beforeAll(async () => { + await config.setupAccountAndTenant() + }) + + afterAll(async () => { + await config.afterAll() + }) + + + + it("Update an application", async () => { + const app = await config.applications.create(generateApp()) + + config.applications.api.appId = app.appId + + await config.applications.update(app.appId, app.name, { + name: generator.word(), + }) + }) + + it("Revert Changes without changes", async () => { + const app = await config.applications.create(generateApp()) + config.applications.api.appId = app.appId + + await config.applications.revertUnpublished(app.appId) + }) + + it("Revert Changes", async () => { + const app = await config.applications.create(generateApp()) + config.applications.api.appId = app.appId + + // publish app + await config.applications.publish(app._id) + + // Change/add component to the app + await config.screen.create(generateScreen("BASIC")) + + // // Revert the app to published state + await config.applications.revertPublished(app.appId) + + // Check screen is removed + await config.applications.getRoutes() + }) +})