Fix tests

This commit is contained in:
Adria Navarro 2024-02-19 17:27:01 +01:00
parent 09dbc694fa
commit ae7a978998
4 changed files with 33 additions and 19 deletions

View File

@ -113,6 +113,7 @@ const environment = {
process.env[key] = value
// @ts-ignore
environment[key] = value
cleanVariables()
},
isTest: coreEnv.isTest,
isJest: coreEnv.isJest,
@ -126,12 +127,11 @@ const environment = {
getDefaults: () => {
return DEFAULTS
},
useIsolatedVM: {
QUERY_TRANSFORMERS: !!process.env.QUERY_TRANSFORMERS_ISOLATEDVM,
JS_RUNNER: !!process.env.JS_RUNNER_ISOLATEDVM,
},
ISOLATEDVM_QUERY_TRANSFORMERS: !!process.env.ISOLATEDVM_QUERY_TRANSFORMERS,
ISOLATEDVM_JS_RUNNER: !!process.env.ISOLATEDVM_JS_RUNNER,
}
function cleanVariables() {
// clean up any environment variable edge cases
for (let [key, value] of Object.entries(environment)) {
// handle the edge case of "0" to disable an environment variable
@ -145,5 +145,8 @@ for (let [key, value] of Object.entries(environment)) {
environment[key] = 0
}
}
}
cleanVariables()
export default environment

View File

@ -7,7 +7,8 @@ import { BuiltInVM, IsolatedVM } from "./vm"
export function init() {
setJSRunner((js: string, ctx: Record<string, any>) => {
return tracer.trace("runJS", {}, span => {
if (!env.useIsolatedVM.JS_RUNNER) {
const useIsolatedVm = env.ISOLATEDVM_JS_RUNNER
if (!useIsolatedVm) {
const vm = new BuiltInVM(ctx, span)
return vm.execute(js)
}

View File

@ -7,18 +7,28 @@ const { runJsHelpersTests } = require("@budibase/string-templates/test/utils")
import tk from "timekeeper"
import { init } from ".."
import TestConfiguration from "../../tests/utilities/TestConfiguration"
import environment from "../../environment"
tk.freeze("2021-01-21T12:00:00")
describe("jsRunner", () => {
describe.each([
["vm", false],
["isolated-vm", true],
])("jsRunner (using %s)", (_, useIsolatedVM) => {
const config = new TestConfiguration()
beforeAll(async () => {
environment._set("ISOLATEDVM_JS_RUNNER", useIsolatedVM)
// Register js runner
init()
await config.init()
})
afterAll(() => {
config.end()
})
const processJS = (js: string, context?: object) => {
return config.doInContext(config.getAppId(), async () =>
processStringSync(encodeJSBinding(js), context || {})
@ -30,7 +40,7 @@ describe("jsRunner", () => {
expect(output).toBe(3)
})
it("should prevent sandbox escape", async () => {
it.only("should prevent sandbox escape", async () => {
const output = await processJS(
`return this.constructor.constructor("return process")()`
)

View File

@ -129,7 +129,7 @@ class QueryRunner {
// transform as required
if (transformer) {
let runner: VM
if (!environment.useIsolatedVM.QUERY_TRANSFORMERS) {
if (!environment.ISOLATEDVM_QUERY_TRANSFORMERS) {
runner = new VM2({
data: rows,
params: enrichedParameters,