// test-debug.js - Debug the exact test case import { createLexer } from './src/core/lexer.js'; import { createParser } from './src/core/parser.js'; import { createInterpreter } from './src/core/interpreter.js'; function runBabaCode(code, jsBridgeConfig = {}) { const lexer = createLexer(code); const tokens = lexer.allTokens(); const parser = createParser(tokens); const ast = parser.parse(); const host = { jsBridgeConfig: { allowedFunctions: new Set([ 'JSON.parse', 'JSON.stringify', 'Math.abs', 'Math.floor', 'Math.ceil', 'Math.round', 'Math.min', 'Math.max', 'Math.random', 'console.log', 'console.warn', 'console.error', 'Date.now', 'performance.now', 'testFunction', 'testAsyncFunction', 'testErrorFunction' ]), ...jsBridgeConfig }, io: { out: () => {}, // Silent for tests debug: () => {} } }; // Add test functions to global scope for testing global.testFunction = (x) => x * 2; global.testAsyncFunction = async (x) => Promise.resolve(x + 10); global.testErrorFunction = () => { throw new Error('Test error'); }; // Add test functions to sandbox if (!host.jsBridgeConfig.sandbox) { host.jsBridgeConfig.sandbox = {}; } host.jsBridgeConfig.sandbox.testFunction = global.testFunction; host.jsBridgeConfig.sandbox.testAsyncFunction = global.testAsyncFunction; host.jsBridgeConfig.sandbox.testErrorFunction = global.testErrorFunction; const interpreter = createInterpreter(ast, host); interpreter.interpret(); return interpreter.scope.get('result'); } // Test the exact failing case const code = ` result : io.callJS "Math.abs" [-5]; result; `; const result = runBabaCode(code); console.log('Result:', result); console.log('Type:', result?.type); console.log('Properties:', result?.properties); console.log('Has Ok?', result?.properties?.has('Ok')); console.log('Ok value:', result?.properties?.get('Ok')); console.log('Ok value.value:', result?.properties?.get('Ok')?.value);