Merge pull request #12932 from Budibase/fix/automation-js-scripts

Fix automation JS scripts
This commit is contained in:
Michael Drury 2024-02-01 16:23:33 +00:00 committed by GitHub
commit a6e8bdf1a5
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 28 additions and 23 deletions

View File

@ -1,12 +1,12 @@
import ScriptRunner from "../../utilities/scriptRunner" import ScriptRunner from "../../utilities/scriptRunner"
import { BBContext } from "@budibase/types" import { Ctx } from "@budibase/types"
export async function execute(ctx: BBContext) { export async function execute(ctx: Ctx) {
const { script, context } = ctx.request.body const { script, context } = ctx.request.body
const runner = new ScriptRunner(script, context) const runner = new ScriptRunner(script, context)
ctx.body = runner.execute() ctx.body = runner.execute()
} }
export async function save(ctx: BBContext) { export async function save(ctx: Ctx) {
ctx.throw(501, "Not currently implemented") ctx.throw(501, "Not currently implemented")
} }

View File

@ -9,34 +9,40 @@ describe("test the execute script action", () => {
afterAll(setup.afterAll) afterAll(setup.afterAll)
it("should be able to execute a script", async () => { it("should be able to execute a script", async () => {
let res = await setup.runStep( const res = await setup.runStep(setup.actions.EXECUTE_SCRIPT.stepId, {
setup.actions.EXECUTE_SCRIPT.stepId, code: "return 1 + 1",
(inputs = { })
code: "return 1 + 1",
})
)
expect(res.value).toEqual(2) expect(res.value).toEqual(2)
expect(res.success).toEqual(true) expect(res.success).toEqual(true)
}) })
it("should handle a null value", async () => { it("should handle a null value", async () => {
let res = await setup.runStep( const res = await setup.runStep(setup.actions.EXECUTE_SCRIPT.stepId, {
setup.actions.EXECUTE_SCRIPT.stepId, code: null,
(inputs = { })
code: null,
})
)
expect(res.response.message).toEqual("Invalid inputs") expect(res.response.message).toEqual("Invalid inputs")
expect(res.success).toEqual(false) expect(res.success).toEqual(false)
}) })
it("should be able to handle an error gracefully", async () => { it("should be able to get a value from context", async () => {
let res = await setup.runStep( const res = await setup.runStep(
setup.actions.EXECUTE_SCRIPT.stepId, setup.actions.EXECUTE_SCRIPT.stepId,
(inputs = { {
code: "return something.map(x => x.name)", code: "return steps.map(d => d.value)",
}) },
{
steps: [{ value: 0 }, { value: 1 }],
}
) )
expect(res.value).toEqual([0, 1])
expect(res.response).toBeUndefined()
expect(res.success).toEqual(true)
})
it("should be able to handle an error gracefully", async () => {
const res = await setup.runStep(setup.actions.EXECUTE_SCRIPT.stepId, {
code: "return something.map(x => x.name)",
})
expect(res.response).toEqual("ReferenceError: something is not defined") expect(res.response).toEqual("ReferenceError: something is not defined")
expect(res.success).toEqual(false) expect(res.success).toEqual(false)
}) })

View File

@ -1,4 +1,4 @@
import ivm, { Context, Script } from "isolated-vm" import ivm from "isolated-vm"
const JS_TIMEOUT_MS = 1000 const JS_TIMEOUT_MS = 1000
@ -9,8 +9,7 @@ class ScriptRunner {
const code = `let fn = () => {\n${script}\n}; results.out = fn();` const code = `let fn = () => {\n${script}\n}; results.out = fn();`
this.vm = new IsolatedVM({ memoryLimit: 8 }) this.vm = new IsolatedVM({ memoryLimit: 8 })
this.vm.context = { this.vm.context = {
data: context.data, ...context,
params: context.params,
results: { out: "" }, results: { out: "" },
} }
this.vm.code = code this.vm.code = code