Files
payload-automation/src/steps/create-document.ts
Bas van den Aakster 74217d532d Implement independent error storage system and comprehensive improvements
Major Features:
• Add persistent error tracking for timeout/network failures that bypasses PayloadCMS output limitations
• Implement smart error classification (timeout, DNS, connection, network) with duration-based detection
• Add comprehensive test infrastructure with MongoDB in-memory testing and enhanced mocking
• Fix HTTP request handler error preservation with detailed context storage
• Add independent execution tracking with success/failure status and duration metrics

Technical Improvements:
• Update JSONPath documentation to use correct $.trigger.doc syntax across all step types
• Fix PayloadCMS job execution to use runByID instead of run() for reliable task processing
• Add enhanced HTTP error handling that preserves outputs for 4xx/5xx status codes
• Implement proper nock configuration with undici for Node.js 22 fetch interception
• Add comprehensive unit tests for WorkflowExecutor with mocked PayloadCMS instances

Developer Experience:
• Add detailed error information in workflow context with URL, method, timeout, attempts
• Update README with HTTP error handling patterns and enhanced error tracking examples
• Add test helpers and setup infrastructure for reliable integration testing
• Fix workflow step validation and JSONPath field descriptions

Breaking Changes: None - fully backward compatible

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-09-04 18:03:30 +02:00

56 lines
1.3 KiB
TypeScript

import type { TaskConfig } from "payload"
import { createDocumentHandler } from "./create-document-handler.js"
export const CreateDocumentStepTask = {
slug: 'create-document',
handler: createDocumentHandler,
inputSchema: [
{
name: 'collectionSlug',
type: 'text',
admin: {
description: 'The collection slug to create a document in'
},
required: true
},
{
name: 'data',
type: 'json',
admin: {
description: 'The document data to create. Use JSONPath to reference trigger data (e.g., {"title": "$.trigger.doc.title", "author": "$.trigger.doc.author"})'
},
required: true
},
{
name: 'draft',
type: 'checkbox',
admin: {
description: 'Create as draft (if collection has drafts enabled)'
}
},
{
name: 'locale',
type: 'text',
admin: {
description: 'Locale for the document (if localization is enabled)'
}
}
],
outputSchema: [
{
name: 'doc',
type: 'json',
admin: {
description: 'The created document'
}
},
{
name: 'id',
type: 'text',
admin: {
description: 'The ID of the created document'
}
}
]
} satisfies TaskConfig<'create-document'>