about summary refs log tree commit diff stats
path: root/js/baba-yaga/test-debug.js
blob: 6be12cd880307bc18b37124876b489ff57ae5809 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
// 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);