Fix types in table migration tests

This commit is contained in:
Andrew Kingston 2022-11-29 16:27:06 +00:00
parent 0b6c459fbd
commit a0776ac73a
1 changed files with 55 additions and 39 deletions

View File

@ -1,4 +1,4 @@
import { App, Screen, ScreenProps, Component } from "@budibase/types" import { App, Screen } from "@budibase/types"
import { db as dbCore } from "@budibase/backend-core" import { db as dbCore } from "@budibase/backend-core"
import TestConfig from "../../../tests/utilities/TestConfiguration" import TestConfig from "../../../tests/utilities/TestConfiguration"
@ -7,7 +7,7 @@ import { run as runMigration } from "../tableSettings"
describe("run", () => { describe("run", () => {
const config = new TestConfig(false) const config = new TestConfig(false)
let app: App let app: App
let screen: Component let screen: Screen
beforeAll(async () => { beforeAll(async () => {
await config.init() await config.init()
@ -19,14 +19,18 @@ describe("run", () => {
it("migrates table block row on click settings", async () => { it("migrates table block row on click settings", async () => {
// Add legacy table block as first child // Add legacy table block as first child
screen.props._children[0] = { screen.props._children = [
_component: "@budibase/standard-components/tableblock", {
_id: "foo", _instanceName: "Table Block",
linkRows: true, _styles: {},
linkURL: "/rows/:id", _component: "@budibase/standard-components/tableblock",
linkPeek: true, _id: "foo",
linkColumn: "name", linkRows: true,
} linkURL: "/rows/:id",
linkPeek: true,
linkColumn: "name",
},
]
await config.createScreen(screen) await config.createScreen(screen)
// Run migration // Run migration
@ -36,7 +40,7 @@ describe("run", () => {
}) })
// Verify new "onClick" setting // Verify new "onClick" setting
const onClick = screen.props._children[0].onClick const onClick = screen.props._children?.[0].onClick
expect(onClick).toBeDefined() expect(onClick).toBeDefined()
expect(onClick.length).toBe(1) expect(onClick.length).toBe(1)
expect(onClick[0]["##eventHandlerType"]).toBe("Navigate To") expect(onClick[0]["##eventHandlerType"]).toBe("Navigate To")
@ -48,14 +52,18 @@ describe("run", () => {
it("migrates table row on click settings", async () => { it("migrates table row on click settings", async () => {
// Add legacy table block as first child // Add legacy table block as first child
screen.props._children[0] = { screen.props._children = [
_component: "@budibase/standard-components/table", {
_id: "foo", _instanceName: "Table",
linkRows: true, _styles: {},
linkURL: "/rows/:id", _component: "@budibase/standard-components/table",
linkPeek: true, _id: "foo",
linkColumn: "name", linkRows: true,
} linkURL: "/rows/:id",
linkPeek: true,
linkColumn: "name",
},
]
await config.createScreen(screen) await config.createScreen(screen)
// Run migration // Run migration
@ -65,7 +73,7 @@ describe("run", () => {
}) })
// Verify new "onClick" setting // Verify new "onClick" setting
const onClick = screen.props._children[0].onClick const onClick = screen.props._children?.[0].onClick
expect(onClick).toBeDefined() expect(onClick).toBeDefined()
expect(onClick.length).toBe(1) expect(onClick.length).toBe(1)
expect(onClick[0]["##eventHandlerType"]).toBe("Navigate To") expect(onClick[0]["##eventHandlerType"]).toBe("Navigate To")
@ -77,13 +85,17 @@ describe("run", () => {
it("migrates table block title button settings", async () => { it("migrates table block title button settings", async () => {
// Add legacy table block as first child // Add legacy table block as first child
screen.props._children[0] = { screen.props._children = [
_component: "@budibase/standard-components/tableblock", {
_id: "foo", _instanceName: "Table Block",
showTitleButton: true, _styles: {},
titleButtonURL: "/url", _component: "@budibase/standard-components/tableblock",
titleButtonPeek: true, _id: "foo",
} showTitleButton: true,
titleButtonURL: "/url",
titleButtonPeek: true,
},
]
await config.createScreen(screen) await config.createScreen(screen)
// Run migration // Run migration
@ -93,7 +105,7 @@ describe("run", () => {
}) })
// Verify new "onClickTitleButton" setting // Verify new "onClickTitleButton" setting
const onClick = screen.props._children[0].onClickTitleButton const onClick = screen.props._children?.[0].onClickTitleButton
expect(onClick).toBeDefined() expect(onClick).toBeDefined()
expect(onClick.length).toBe(1) expect(onClick.length).toBe(1)
expect(onClick[0]["##eventHandlerType"]).toBe("Navigate To") expect(onClick[0]["##eventHandlerType"]).toBe("Navigate To")
@ -103,16 +115,20 @@ describe("run", () => {
it("ignores components that have already been migrated", async () => { it("ignores components that have already been migrated", async () => {
// Add legacy table block as first child // Add legacy table block as first child
screen.props._children[0] = { screen.props._children = [
_component: "@budibase/standard-components/tableblock", {
_id: "foo", _instanceName: "Table Block",
linkRows: true, _styles: {},
linkURL: "/rows/:id", _component: "@budibase/standard-components/tableblock",
linkPeek: true, _id: "foo",
linkColumn: "name", linkRows: true,
onClick: "foo", linkURL: "/rows/:id",
} linkPeek: true,
const initialDefinition = JSON.stringify(screen.props._children[0]) linkColumn: "name",
onClick: "foo",
},
]
const initialDefinition = JSON.stringify(screen.props._children?.[0])
await config.createScreen(screen) await config.createScreen(screen)
// Run migration // Run migration
@ -122,7 +138,7 @@ describe("run", () => {
}) })
// Verify new "onClick" setting // Verify new "onClick" setting
const newDefinition = JSON.stringify(screen.props._children[0]) const newDefinition = JSON.stringify(screen.props._children?.[0])
expect(initialDefinition).toEqual(newDefinition) expect(initialDefinition).toEqual(newDefinition)
}) })
}) })