fix: numeric sourceOutput remapping, IMAP trigger detection, AI tool description validation (#537, #538, #477, #602) (#636)

- Remap numeric sourceOutput ("0","1") to "main" with sourceIndex,
  with guard to skip when branch/case smart params are present (#537)
- Recognize emailReadImap as activatable trigger in isTriggerNode() (#538)
- Add getToolDescription() helper checking toolDescription, description,
  and options.description across all AI tool validators (#477)
- Defensive check for missing workflow ID in create response (#602)
- Relax flaky CI thresholds: perf test ratio 15→20, timing variance 10%→50%

Conceived by Romuald Członkowski - www.aiadvisors.pl/en

Co-authored-by: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
Romuald Członkowski
2026-03-14 18:40:58 +01:00
committed by GitHub
parent 9590f751d2
commit 599bc664d0
8 changed files with 76 additions and 35 deletions

View File

@@ -519,6 +519,17 @@ export async function handleCreateWorkflow(args: unknown, context?: InstanceCont
// Create workflow (n8n API expects node types in FULL form)
const workflow = await client.createWorkflow(input);
// Defensive check: ensure the API returned a valid workflow with an ID
if (!workflow || !workflow.id) {
return {
success: false,
error: 'Workflow creation failed: n8n API returned an empty or invalid response. Verify your N8N_API_URL points to the correct /api/v1 endpoint and that the n8n instance supports workflow creation.',
details: {
response: workflow ? { keys: Object.keys(workflow) } : null
}
};
}
// Track successful workflow creation
telemetry.trackWorkflowCreation(workflow, true);