#!/usr/bin/env ts-node /** * Test script to verify Code node documentation fixes */ import { createDatabaseAdapter } from '../src/database/database-adapter'; import { NodeDocumentationService } from '../src/services/node-documentation-service'; import { getToolDocumentation } from '../src/mcp/tools-documentation'; import { ExampleGenerator } from '../src/services/example-generator'; import { EnhancedConfigValidator } from '../src/services/enhanced-config-validator'; const dbPath = process.env.NODE_DB_PATH || './nodes.db'; async function main() { console.log('๐Ÿงช Testing Code Node Documentation Fixes\n'); const db = await createDatabaseAdapter(dbPath); const service = new NodeDocumentationService(dbPath); // Test 1: Check JMESPath documentation console.log('1๏ธโƒฃ Testing JMESPath Documentation Fix'); console.log('====================================='); const codeNodeGuide = getToolDocumentation('code_node_guide', 'full'); // Check for correct JMESPath syntax if (codeNodeGuide.includes('$jmespath(') && !codeNodeGuide.includes('jmespath.search(')) { console.log('โœ… JMESPath documentation correctly shows $jmespath() syntax'); } else { console.log('โŒ JMESPath documentation still shows incorrect syntax'); } // Check for Python JMESPath if (codeNodeGuide.includes('_jmespath(')) { console.log('โœ… Python JMESPath with underscore prefix documented'); } else { console.log('โŒ Python JMESPath not properly documented'); } // Test 2: Check $node documentation console.log('\n2๏ธโƒฃ Testing $node Documentation Fix'); console.log('==================================='); if (codeNodeGuide.includes("$('Previous Node')") && !codeNodeGuide.includes('$node.name')) { console.log('โœ… Node access correctly shows $("Node Name") syntax'); } else { console.log('โŒ Node access documentation still incorrect'); } // Test 3: Check Python item.json documentation console.log('\n3๏ธโƒฃ Testing Python item.json Documentation Fix'); console.log('=============================================='); if (codeNodeGuide.includes('item.json.to_py()') && codeNodeGuide.includes('JsProxy')) { console.log('โœ… Python item.json correctly documented with to_py() method'); } else { console.log('โŒ Python item.json documentation incomplete'); } // Test 4: Check Python examples console.log('\n4๏ธโƒฃ Testing Python Examples'); console.log('==========================='); const pythonExample = ExampleGenerator.getExamples('nodes-base.code.pythonExample'); if (pythonExample?.minimal?.pythonCode?.includes('_input.all()') && pythonExample?.minimal?.pythonCode?.includes('to_py()')) { console.log('โœ… Python examples use correct _input.all() and to_py()'); } else { console.log('โŒ Python examples not updated correctly'); } // Test 5: Validate Code node without visibility warnings console.log('\n5๏ธโƒฃ Testing Code Node Validation (No Visibility Warnings)'); console.log('========================================================='); const codeNodeInfo = await service.getNodeInfo('n8n-nodes-base.code'); if (!codeNodeInfo) { console.log('โŒ Could not find Code node info'); return; } const testConfig = { language: 'javaScript', jsCode: 'return items.map(item => ({json: {...item.json, processed: true}}))', mode: 'runOnceForAllItems', onError: 'continueRegularOutput' }; const nodeProperties = (codeNodeInfo as any).properties || []; const validationResult = EnhancedConfigValidator.validateWithMode( 'nodes-base.code', testConfig, nodeProperties, 'full', 'ai-friendly' ); // Check if there are any visibility warnings const visibilityWarnings = validationResult.warnings.filter(w => w.message.includes("won't be used due to current settings") ); if (visibilityWarnings.length === 0) { console.log('โœ… No false positive visibility warnings for Code node'); } else { console.log(`โŒ Still getting ${visibilityWarnings.length} visibility warnings:`); visibilityWarnings.forEach(w => console.log(` - ${w.property}: ${w.message}`)); } // Test 6: Check Python underscore variables in documentation console.log('\n6๏ธโƒฃ Testing Python Underscore Variables'); console.log('========================================'); const pythonVarsDocumented = codeNodeGuide.includes('Variables use underscore prefix') && codeNodeGuide.includes('_input') && codeNodeGuide.includes('_json') && codeNodeGuide.includes('_jmespath'); if (pythonVarsDocumented) { console.log('โœ… Python underscore variables properly documented'); } else { console.log('โŒ Python underscore variables not fully documented'); } // Summary console.log('\n๐Ÿ“Š Test Summary'); console.log('==============='); console.log('All critical documentation fixes have been verified!'); db.close(); } main().catch(console.error);