n8n-mcp 2.22.5 → 2.22.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/data/nodes.db +0 -0
- package/dist/mcp/index.js +0 -0
- package/package.json +10 -1
- package/dist/mcp/absolute-minimal.d.ts +0 -4
- package/dist/mcp/absolute-minimal.d.ts.map +0 -1
- package/dist/mcp/absolute-minimal.js +0 -34
- package/dist/mcp/absolute-minimal.js.map +0 -1
- package/dist/mcp/fixed-protocol.d.ts +0 -17
- package/dist/mcp/fixed-protocol.d.ts.map +0 -1
- package/dist/mcp/fixed-protocol.js +0 -162
- package/dist/mcp/fixed-protocol.js.map +0 -1
- package/dist/mcp/handlers-documentation.d.ts +0 -18
- package/dist/mcp/handlers-documentation.d.ts.map +0 -1
- package/dist/mcp/handlers-documentation.js +0 -113
- package/dist/mcp/handlers-documentation.js.map +0 -1
- package/dist/mcp/minimal-test.d.ts +0 -3
- package/dist/mcp/minimal-test.d.ts.map +0 -1
- package/dist/mcp/minimal-test.js +0 -83
- package/dist/mcp/minimal-test.js.map +0 -1
- package/dist/mcp/stderr-test.d.ts +0 -2
- package/dist/mcp/stderr-test.d.ts.map +0 -1
- package/dist/mcp/stderr-test.js +0 -32
- package/dist/mcp/stderr-test.js.map +0 -1
- package/dist/mcp/tool-docs/special/code-node-guide.d.ts +0 -3
- package/dist/mcp/tool-docs/special/code-node-guide.d.ts.map +0 -1
- package/dist/mcp/tool-docs/special/code-node-guide.js +0 -61
- package/dist/mcp/tool-docs/special/code-node-guide.js.map +0 -1
- package/dist/mcp/tool-docs/special/index.d.ts +0 -2
- package/dist/mcp/tool-docs/special/index.d.ts.map +0 -1
- package/dist/mcp/tool-docs/special/index.js +0 -6
- package/dist/mcp/tool-docs/special/index.js.map +0 -1
- package/dist/mcp/tool-docs/templates/get-node-for-task.d.ts +0 -3
- package/dist/mcp/tool-docs/templates/get-node-for-task.d.ts.map +0 -1
- package/dist/mcp/tool-docs/templates/get-node-for-task.js +0 -50
- package/dist/mcp/tool-docs/templates/get-node-for-task.js.map +0 -1
- package/dist/mcp/tools-documentation-new.d.ts +0 -6
- package/dist/mcp/tools-documentation-new.d.ts.map +0 -1
- package/dist/mcp/tools-documentation-new.js +0 -163
- package/dist/mcp/tools-documentation-new.js.map +0 -1
- package/dist/mcp/ultra-minimal.d.ts +0 -8
- package/dist/mcp/ultra-minimal.d.ts.map +0 -1
- package/dist/mcp/ultra-minimal.js +0 -93
- package/dist/mcp/ultra-minimal.js.map +0 -1
- package/dist/mcp/working-test.d.ts +0 -3
- package/dist/mcp/working-test.d.ts.map +0 -1
- package/dist/mcp/working-test.js +0 -48
- package/dist/mcp/working-test.js.map +0 -1
- package/dist/mcp/wrapper.sh +0 -28
- package/dist/scripts/debug-n8n-auth.d.ts +0 -3
- package/dist/scripts/debug-n8n-auth.d.ts.map +0 -1
- package/dist/scripts/debug-n8n-auth.js +0 -97
- package/dist/scripts/debug-n8n-auth.js.map +0 -1
- package/dist/scripts/debug-node.d.ts +0 -3
- package/dist/scripts/debug-node.d.ts.map +0 -1
- package/dist/scripts/debug-node.js +0 -59
- package/dist/scripts/debug-node.js.map +0 -1
- package/dist/scripts/generate-metadata-only.d.ts +0 -3
- package/dist/scripts/generate-metadata-only.d.ts.map +0 -1
- package/dist/scripts/generate-metadata-only.js +0 -146
- package/dist/scripts/generate-metadata-only.js.map +0 -1
- package/dist/scripts/generate-metadata-sync.d.ts +0 -3
- package/dist/scripts/generate-metadata-sync.d.ts.map +0 -1
- package/dist/scripts/generate-metadata-sync.js +0 -136
- package/dist/scripts/generate-metadata-sync.js.map +0 -1
- package/dist/scripts/test-ai-workflow-validation.d.ts +0 -3
- package/dist/scripts/test-ai-workflow-validation.d.ts.map +0 -1
- package/dist/scripts/test-ai-workflow-validation.js +0 -191
- package/dist/scripts/test-ai-workflow-validation.js.map +0 -1
- package/dist/scripts/test-api-headers.d.ts +0 -3
- package/dist/scripts/test-api-headers.d.ts.map +0 -1
- package/dist/scripts/test-api-headers.js +0 -35
- package/dist/scripts/test-api-headers.js.map +0 -1
- package/dist/scripts/test-batch-processing.d.ts +0 -3
- package/dist/scripts/test-batch-processing.d.ts.map +0 -1
- package/dist/scripts/test-batch-processing.js +0 -144
- package/dist/scripts/test-batch-processing.js.map +0 -1
- package/dist/scripts/test-docker-config-simulation.d.ts +0 -3
- package/dist/scripts/test-docker-config-simulation.d.ts.map +0 -1
- package/dist/scripts/test-docker-config-simulation.js +0 -74
- package/dist/scripts/test-docker-config-simulation.js.map +0 -1
- package/dist/scripts/test-enhanced-validation.d.ts +0 -3
- package/dist/scripts/test-enhanced-validation.d.ts.map +0 -1
- package/dist/scripts/test-enhanced-validation.js +0 -117
- package/dist/scripts/test-enhanced-validation.js.map +0 -1
- package/dist/scripts/test-error-handling-validation.d.ts +0 -3
- package/dist/scripts/test-error-handling-validation.d.ts.map +0 -1
- package/dist/scripts/test-error-handling-validation.js +0 -340
- package/dist/scripts/test-error-handling-validation.js.map +0 -1
- package/dist/scripts/test-issue-45-fix.d.ts +0 -3
- package/dist/scripts/test-issue-45-fix.d.ts.map +0 -1
- package/dist/scripts/test-issue-45-fix.js +0 -136
- package/dist/scripts/test-issue-45-fix.js.map +0 -1
- package/dist/scripts/test-issue-74.d.ts +0 -3
- package/dist/scripts/test-issue-74.d.ts.map +0 -1
- package/dist/scripts/test-issue-74.js +0 -112
- package/dist/scripts/test-issue-74.js.map +0 -1
- package/dist/scripts/test-lazy-config.d.ts +0 -3
- package/dist/scripts/test-lazy-config.d.ts.map +0 -1
- package/dist/scripts/test-lazy-config.js +0 -60
- package/dist/scripts/test-lazy-config.js.map +0 -1
- package/dist/scripts/test-limited-results.d.ts +0 -3
- package/dist/scripts/test-limited-results.d.ts.map +0 -1
- package/dist/scripts/test-limited-results.js +0 -76
- package/dist/scripts/test-limited-results.js.map +0 -1
- package/dist/scripts/test-mcp-n8n-update-partial.d.ts +0 -3
- package/dist/scripts/test-mcp-n8n-update-partial.d.ts.map +0 -1
- package/dist/scripts/test-mcp-n8n-update-partial.js +0 -138
- package/dist/scripts/test-mcp-n8n-update-partial.js.map +0 -1
- package/dist/scripts/test-mcp-tools.d.ts +0 -3
- package/dist/scripts/test-mcp-tools.d.ts.map +0 -1
- package/dist/scripts/test-mcp-tools.js +0 -36
- package/dist/scripts/test-mcp-tools.js.map +0 -1
- package/dist/scripts/test-metadata-generation.d.ts +0 -3
- package/dist/scripts/test-metadata-generation.d.ts.map +0 -1
- package/dist/scripts/test-metadata-generation.js +0 -96
- package/dist/scripts/test-metadata-generation.js.map +0 -1
- package/dist/scripts/test-n8n-manager-integration.d.ts +0 -3
- package/dist/scripts/test-n8n-manager-integration.d.ts.map +0 -1
- package/dist/scripts/test-n8n-manager-integration.js +0 -122
- package/dist/scripts/test-n8n-manager-integration.js.map +0 -1
- package/dist/scripts/test-n8n-validate-workflow.d.ts +0 -3
- package/dist/scripts/test-n8n-validate-workflow.d.ts.map +0 -1
- package/dist/scripts/test-n8n-validate-workflow.js +0 -125
- package/dist/scripts/test-n8n-validate-workflow.js.map +0 -1
- package/dist/scripts/test-node-level-properties.d.ts +0 -3
- package/dist/scripts/test-node-level-properties.d.ts.map +0 -1
- package/dist/scripts/test-node-level-properties.js +0 -196
- package/dist/scripts/test-node-level-properties.js.map +0 -1
- package/dist/scripts/test-nodes.d.ts +0 -3
- package/dist/scripts/test-nodes.d.ts.map +0 -1
- package/dist/scripts/test-nodes.js +0 -91
- package/dist/scripts/test-nodes.js.map +0 -1
- package/dist/scripts/test-single-workflow.d.ts +0 -3
- package/dist/scripts/test-single-workflow.d.ts.map +0 -1
- package/dist/scripts/test-single-workflow.js +0 -112
- package/dist/scripts/test-single-workflow.js.map +0 -1
- package/dist/scripts/test-template-validation.d.ts +0 -3
- package/dist/scripts/test-template-validation.d.ts.map +0 -1
- package/dist/scripts/test-template-validation.js +0 -142
- package/dist/scripts/test-template-validation.js.map +0 -1
- package/dist/scripts/test-templates.d.ts +0 -4
- package/dist/scripts/test-templates.d.ts.map +0 -1
- package/dist/scripts/test-templates.js +0 -99
- package/dist/scripts/test-templates.js.map +0 -1
- package/dist/scripts/test-tools-documentation.d.ts +0 -2
- package/dist/scripts/test-tools-documentation.d.ts.map +0 -1
- package/dist/scripts/test-tools-documentation.js +0 -41
- package/dist/scripts/test-tools-documentation.js.map +0 -1
- package/dist/scripts/test-transactional-diff.d.ts +0 -2
- package/dist/scripts/test-transactional-diff.d.ts.map +0 -1
- package/dist/scripts/test-transactional-diff.js +0 -240
- package/dist/scripts/test-transactional-diff.js.map +0 -1
- package/dist/scripts/test-update-partial-debug.d.ts +0 -3
- package/dist/scripts/test-update-partial-debug.d.ts.map +0 -1
- package/dist/scripts/test-update-partial-debug.js +0 -92
- package/dist/scripts/test-update-partial-debug.js.map +0 -1
- package/dist/scripts/test-updatenode-null-fix.d.ts +0 -3
- package/dist/scripts/test-updatenode-null-fix.d.ts.map +0 -1
- package/dist/scripts/test-updatenode-null-fix.js +0 -156
- package/dist/scripts/test-updatenode-null-fix.js.map +0 -1
- package/dist/scripts/test-validation-parity.d.ts +0 -2
- package/dist/scripts/test-validation-parity.d.ts.map +0 -1
- package/dist/scripts/test-validation-parity.js +0 -153
- package/dist/scripts/test-validation-parity.js.map +0 -1
- package/dist/scripts/test-version-extraction.d.ts +0 -2
- package/dist/scripts/test-version-extraction.d.ts.map +0 -1
- package/dist/scripts/test-version-extraction.js +0 -74
- package/dist/scripts/test-version-extraction.js.map +0 -1
- package/dist/scripts/test-workflow-diff.d.ts +0 -3
- package/dist/scripts/test-workflow-diff.d.ts.map +0 -1
- package/dist/scripts/test-workflow-diff.js +0 -328
- package/dist/scripts/test-workflow-diff.js.map +0 -1
- package/dist/scripts/test-workflow-validation.d.ts +0 -3
- package/dist/scripts/test-workflow-validation.d.ts.map +0 -1
- package/dist/scripts/test-workflow-validation.js +0 -238
- package/dist/scripts/test-workflow-validation.js.map +0 -1
- package/dist/services/workflow-ownership.d.ts +0 -35
- package/dist/services/workflow-ownership.d.ts.map +0 -1
- package/dist/services/workflow-ownership.js +0 -195
- package/dist/services/workflow-ownership.js.map +0 -1
- package/dist/sse-server.d.ts +0 -8
- package/dist/sse-server.d.ts.map +0 -1
- package/dist/sse-server.js +0 -652
- package/dist/sse-server.js.map +0 -1
- package/dist/types/session-restoration.d.ts +0 -25
- package/dist/types/session-restoration.d.ts.map +0 -1
- package/dist/types/session-restoration.js +0 -3
- package/dist/types/session-restoration.js.map +0 -1
- package/dist/types/sse.d.ts +0 -42
- package/dist/types/sse.d.ts.map +0 -1
- package/dist/types/sse.js +0 -3
- package/dist/types/sse.js.map +0 -1
- package/dist/utils/sse-session-manager.d.ts +0 -23
- package/dist/utils/sse-session-manager.d.ts.map +0 -1
- package/dist/utils/sse-session-manager.js +0 -178
- package/dist/utils/sse-session-manager.js.map +0 -1
- package/dist/utils/version-utils.d.ts +0 -16
- package/dist/utils/version-utils.d.ts.map +0 -1
- package/dist/utils/version-utils.js +0 -129
- package/dist/utils/version-utils.js.map +0 -1
|
@@ -1,60 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
"use strict";
|
|
3
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
-
const n8n_api_1 = require("../config/n8n-api");
|
|
5
|
-
const tools_1 = require("../mcp/tools");
|
|
6
|
-
const tools_n8n_manager_1 = require("../mcp/tools-n8n-manager");
|
|
7
|
-
async function testLazyConfigLoading() {
|
|
8
|
-
console.log('=== Testing Lazy Configuration Loading ===\n');
|
|
9
|
-
console.log('Test 1: Initial state (no env vars)');
|
|
10
|
-
delete process.env.N8N_API_URL;
|
|
11
|
-
delete process.env.N8N_API_KEY;
|
|
12
|
-
let isConfigured = (0, n8n_api_1.isN8nApiConfigured)();
|
|
13
|
-
let config = (0, n8n_api_1.getN8nApiConfig)();
|
|
14
|
-
console.log(`- Is configured: ${isConfigured}`);
|
|
15
|
-
console.log(`- Config: ${config ? 'Present' : 'Null'}`);
|
|
16
|
-
console.log(`- Expected tools: ${tools_1.n8nDocumentationToolsFinal.length} (documentation only)\n`);
|
|
17
|
-
console.log('Test 2: After setting environment variables');
|
|
18
|
-
process.env.N8N_API_URL = 'https://example.n8n.cloud';
|
|
19
|
-
process.env.N8N_API_KEY = 'test-api-key';
|
|
20
|
-
await new Promise(resolve => setTimeout(resolve, 100));
|
|
21
|
-
isConfigured = (0, n8n_api_1.isN8nApiConfigured)();
|
|
22
|
-
config = (0, n8n_api_1.getN8nApiConfig)();
|
|
23
|
-
console.log(`- Is configured: ${isConfigured}`);
|
|
24
|
-
console.log(`- Config: ${config ? 'Present' : 'Null'}`);
|
|
25
|
-
console.log(`- Config URL: ${config?.baseUrl || 'N/A'}`);
|
|
26
|
-
console.log(`- Expected tools: ${tools_1.n8nDocumentationToolsFinal.length + tools_n8n_manager_1.n8nManagementTools.length} (documentation + management)\n`);
|
|
27
|
-
console.log('Test 3: Simulating MCP server tool listing');
|
|
28
|
-
const tools = [...tools_1.n8nDocumentationToolsFinal];
|
|
29
|
-
if ((0, n8n_api_1.isN8nApiConfigured)()) {
|
|
30
|
-
tools.push(...tools_n8n_manager_1.n8nManagementTools);
|
|
31
|
-
console.log(`- Management tools added: ${tools_n8n_manager_1.n8nManagementTools.length}`);
|
|
32
|
-
}
|
|
33
|
-
console.log(`- Total tools available: ${tools.length}`);
|
|
34
|
-
console.log(`- Documentation tools: ${tools_1.n8nDocumentationToolsFinal.length}`);
|
|
35
|
-
console.log(`- Management tools: ${(0, n8n_api_1.isN8nApiConfigured)() ? tools_n8n_manager_1.n8nManagementTools.length : 0}\n`);
|
|
36
|
-
console.log('Test 4: After removing environment variables');
|
|
37
|
-
delete process.env.N8N_API_URL;
|
|
38
|
-
delete process.env.N8N_API_KEY;
|
|
39
|
-
await new Promise(resolve => setTimeout(resolve, 5100));
|
|
40
|
-
isConfigured = (0, n8n_api_1.isN8nApiConfigured)();
|
|
41
|
-
config = (0, n8n_api_1.getN8nApiConfig)();
|
|
42
|
-
console.log(`- Is configured: ${isConfigured}`);
|
|
43
|
-
console.log(`- Config: ${config ? 'Present' : 'Null'}`);
|
|
44
|
-
console.log(`- Expected tools: ${tools_1.n8nDocumentationToolsFinal.length} (documentation only)\n`);
|
|
45
|
-
console.log('Test 5: Testing cache behavior');
|
|
46
|
-
process.env.N8N_API_URL = 'https://example2.n8n.cloud';
|
|
47
|
-
process.env.N8N_API_KEY = 'test-api-key-2';
|
|
48
|
-
await new Promise(resolve => setTimeout(resolve, 5100));
|
|
49
|
-
const config1 = (0, n8n_api_1.getN8nApiConfig)();
|
|
50
|
-
console.log(`- First call URL: ${config1?.baseUrl}`);
|
|
51
|
-
const config2 = (0, n8n_api_1.getN8nApiConfig)();
|
|
52
|
-
console.log(`- Second call URL: ${config2?.baseUrl}`);
|
|
53
|
-
console.log(`- URLs match: ${config1?.baseUrl === config2?.baseUrl}\n`);
|
|
54
|
-
console.log('=== All tests completed ===');
|
|
55
|
-
}
|
|
56
|
-
testLazyConfigLoading().catch(error => {
|
|
57
|
-
console.error('Test failed:', error);
|
|
58
|
-
process.exit(1);
|
|
59
|
-
});
|
|
60
|
-
//# sourceMappingURL=test-lazy-config.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"test-lazy-config.js","sourceRoot":"","sources":["../../src/scripts/test-lazy-config.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"test-limited-results.d.ts","sourceRoot":"","sources":["../../src/scripts/test-limited-results.ts"],"names":[],"mappings":""}
|
|
@@ -1,76 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
"use strict";
|
|
3
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
4
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
5
|
-
};
|
|
6
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
-
const n8n_api_client_1 = require("../services/n8n-api-client");
|
|
8
|
-
const dotenv_1 = require("dotenv");
|
|
9
|
-
const axios_1 = __importDefault(require("axios"));
|
|
10
|
-
(0, dotenv_1.config)();
|
|
11
|
-
async function testLimitedResults() {
|
|
12
|
-
const apiUrl = process.env.N8N_API_URL || 'https://n8n.energyhouse.com.pl';
|
|
13
|
-
const apiKey = process.env.N8N_API_KEY || 'n8n_api_f94c0b3fb3bf1a3a690f37bb0c5c0de43c7b690c0a33c88b6baaa37ae896dc96';
|
|
14
|
-
console.log('Testing for limited results issue...');
|
|
15
|
-
console.log('API URL:', apiUrl);
|
|
16
|
-
console.log('API Key:', apiKey.substring(0, 20) + '...\n');
|
|
17
|
-
try {
|
|
18
|
-
console.log('=== Test 1: Direct API call with X-N8N-API-KEY ===');
|
|
19
|
-
const directResponse = await axios_1.default.get(`${apiUrl}/api/v1/workflows`, {
|
|
20
|
-
headers: {
|
|
21
|
-
'X-N8N-API-KEY': apiKey,
|
|
22
|
-
'Content-Type': 'application/json'
|
|
23
|
-
},
|
|
24
|
-
params: { limit: 100 }
|
|
25
|
-
});
|
|
26
|
-
console.log(`Direct API: Found ${directResponse.data.data.length} workflows`);
|
|
27
|
-
console.log('\n=== Test 2: Using N8nApiClient ===');
|
|
28
|
-
const client = new n8n_api_client_1.N8nApiClient({
|
|
29
|
-
baseUrl: apiUrl,
|
|
30
|
-
apiKey: apiKey
|
|
31
|
-
});
|
|
32
|
-
const clientResponse = await client.listWorkflows({ limit: 100 });
|
|
33
|
-
console.log(`N8nApiClient: Found ${clientResponse.data.length} workflows`);
|
|
34
|
-
console.log('\n=== Comparison ===');
|
|
35
|
-
console.log(`Direct API returned: ${directResponse.data.data.length} workflows`);
|
|
36
|
-
console.log(`N8nApiClient returned: ${clientResponse.data.length} workflows`);
|
|
37
|
-
if (directResponse.data.data.length !== clientResponse.data.length) {
|
|
38
|
-
console.error('WARNING: Result mismatch detected!');
|
|
39
|
-
console.log('\nFirst workflow from direct API:');
|
|
40
|
-
console.log(JSON.stringify(directResponse.data.data[0], null, 2));
|
|
41
|
-
console.log('\nFirst workflow from N8nApiClient:');
|
|
42
|
-
console.log(JSON.stringify(clientResponse.data[0], null, 2));
|
|
43
|
-
}
|
|
44
|
-
else {
|
|
45
|
-
console.log('✅ Both methods returned the same number of workflows');
|
|
46
|
-
}
|
|
47
|
-
console.log('\n=== Test 3: Credentials ===');
|
|
48
|
-
const credentialsResponse = await client.listCredentials({ limit: 100 });
|
|
49
|
-
console.log(`Found ${credentialsResponse.data.length} credentials`);
|
|
50
|
-
console.log('\n=== Test 4: Pagination Test ===');
|
|
51
|
-
let allWorkflows = [];
|
|
52
|
-
let cursor = undefined;
|
|
53
|
-
let page = 0;
|
|
54
|
-
do {
|
|
55
|
-
const pageResponse = await client.listWorkflows({
|
|
56
|
-
limit: 10,
|
|
57
|
-
cursor: cursor
|
|
58
|
-
});
|
|
59
|
-
allWorkflows = allWorkflows.concat(pageResponse.data);
|
|
60
|
-
cursor = pageResponse.nextCursor || undefined;
|
|
61
|
-
page++;
|
|
62
|
-
console.log(`Page ${page}: ${pageResponse.data.length} workflows, nextCursor: ${cursor ? 'yes' : 'no'}`);
|
|
63
|
-
} while (cursor && page < 10);
|
|
64
|
-
console.log(`Total workflows via pagination: ${allWorkflows.length}`);
|
|
65
|
-
}
|
|
66
|
-
catch (error) {
|
|
67
|
-
console.error('Error:', error.message);
|
|
68
|
-
if (error.response) {
|
|
69
|
-
console.error('Response status:', error.response.status);
|
|
70
|
-
console.error('Response data:', error.response.data);
|
|
71
|
-
console.error('Response headers:', error.response.headers);
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
testLimitedResults().catch(console.error);
|
|
76
|
-
//# sourceMappingURL=test-limited-results.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"test-limited-results.js","sourceRoot":"","sources":["../../src/scripts/test-limited-results.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"test-mcp-n8n-update-partial.d.ts","sourceRoot":"","sources":["../../src/scripts/test-mcp-n8n-update-partial.ts"],"names":[],"mappings":""}
|
|
@@ -1,138 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
"use strict";
|
|
3
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
-
const dotenv_1 = require("dotenv");
|
|
5
|
-
const logger_1 = require("../utils/logger");
|
|
6
|
-
const n8n_api_1 = require("../config/n8n-api");
|
|
7
|
-
const handlers_workflow_diff_1 = require("../mcp/handlers-workflow-diff");
|
|
8
|
-
(0, dotenv_1.config)();
|
|
9
|
-
async function testMcpUpdatePartialWorkflow() {
|
|
10
|
-
logger_1.logger.info('Testing n8n_update_partial_workflow MCP tool...');
|
|
11
|
-
if (!(0, n8n_api_1.isN8nApiConfigured)()) {
|
|
12
|
-
logger_1.logger.warn('n8n API not configured. Set N8N_API_URL and N8N_API_KEY to test.');
|
|
13
|
-
logger_1.logger.info('Example:');
|
|
14
|
-
logger_1.logger.info(' N8N_API_URL=https://your-n8n.com N8N_API_KEY=your-key npm run test:mcp:update-partial');
|
|
15
|
-
return;
|
|
16
|
-
}
|
|
17
|
-
logger_1.logger.info('\n=== Test 1: Validate Only (no actual workflow needed) ===');
|
|
18
|
-
const validateOnlyRequest = {
|
|
19
|
-
id: 'test-workflow-123',
|
|
20
|
-
operations: [
|
|
21
|
-
{
|
|
22
|
-
type: 'addNode',
|
|
23
|
-
description: 'Add HTTP Request node',
|
|
24
|
-
node: {
|
|
25
|
-
name: 'HTTP Request',
|
|
26
|
-
type: 'n8n-nodes-base.httpRequest',
|
|
27
|
-
position: [400, 300],
|
|
28
|
-
parameters: {
|
|
29
|
-
url: 'https://api.example.com/data',
|
|
30
|
-
method: 'GET'
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
},
|
|
34
|
-
{
|
|
35
|
-
type: 'addConnection',
|
|
36
|
-
source: 'Start',
|
|
37
|
-
target: 'HTTP Request'
|
|
38
|
-
}
|
|
39
|
-
],
|
|
40
|
-
validateOnly: true
|
|
41
|
-
};
|
|
42
|
-
try {
|
|
43
|
-
const result = await (0, handlers_workflow_diff_1.handleUpdatePartialWorkflow)(validateOnlyRequest);
|
|
44
|
-
logger_1.logger.info('Validation result:', JSON.stringify(result, null, 2));
|
|
45
|
-
}
|
|
46
|
-
catch (error) {
|
|
47
|
-
logger_1.logger.error('Validation test failed:', error);
|
|
48
|
-
}
|
|
49
|
-
logger_1.logger.info('\n=== Test 2: Missing Required Fields ===');
|
|
50
|
-
const invalidRequest = {
|
|
51
|
-
operations: [{
|
|
52
|
-
type: 'addNode'
|
|
53
|
-
}]
|
|
54
|
-
};
|
|
55
|
-
try {
|
|
56
|
-
const result = await (0, handlers_workflow_diff_1.handleUpdatePartialWorkflow)(invalidRequest);
|
|
57
|
-
logger_1.logger.info('Should fail with validation error:', JSON.stringify(result, null, 2));
|
|
58
|
-
}
|
|
59
|
-
catch (error) {
|
|
60
|
-
logger_1.logger.info('Expected validation error:', error instanceof Error ? error.message : String(error));
|
|
61
|
-
}
|
|
62
|
-
logger_1.logger.info('\n=== Test 3: Complex Operations Array ===');
|
|
63
|
-
const complexRequest = {
|
|
64
|
-
id: 'workflow-456',
|
|
65
|
-
operations: [
|
|
66
|
-
{
|
|
67
|
-
type: 'updateNode',
|
|
68
|
-
nodeName: 'Webhook',
|
|
69
|
-
changes: {
|
|
70
|
-
'parameters.path': 'new-webhook-path',
|
|
71
|
-
'parameters.method': 'POST'
|
|
72
|
-
}
|
|
73
|
-
},
|
|
74
|
-
{
|
|
75
|
-
type: 'addNode',
|
|
76
|
-
node: {
|
|
77
|
-
name: 'Set',
|
|
78
|
-
type: 'n8n-nodes-base.set',
|
|
79
|
-
typeVersion: 3,
|
|
80
|
-
position: [600, 300],
|
|
81
|
-
parameters: {
|
|
82
|
-
mode: 'manual',
|
|
83
|
-
fields: {
|
|
84
|
-
values: [
|
|
85
|
-
{ name: 'status', value: 'processed' }
|
|
86
|
-
]
|
|
87
|
-
}
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
},
|
|
91
|
-
{
|
|
92
|
-
type: 'addConnection',
|
|
93
|
-
source: 'Webhook',
|
|
94
|
-
target: 'Set'
|
|
95
|
-
},
|
|
96
|
-
{
|
|
97
|
-
type: 'updateName',
|
|
98
|
-
name: 'Updated Workflow Name'
|
|
99
|
-
},
|
|
100
|
-
{
|
|
101
|
-
type: 'addTag',
|
|
102
|
-
tag: 'production'
|
|
103
|
-
}
|
|
104
|
-
],
|
|
105
|
-
validateOnly: true
|
|
106
|
-
};
|
|
107
|
-
try {
|
|
108
|
-
const result = await (0, handlers_workflow_diff_1.handleUpdatePartialWorkflow)(complexRequest);
|
|
109
|
-
logger_1.logger.info('Complex operations result:', JSON.stringify(result, null, 2));
|
|
110
|
-
}
|
|
111
|
-
catch (error) {
|
|
112
|
-
logger_1.logger.error('Complex operations test failed:', error);
|
|
113
|
-
}
|
|
114
|
-
logger_1.logger.info('\n=== Test 4: Invalid Operation Type ===');
|
|
115
|
-
const invalidTypeRequest = {
|
|
116
|
-
id: 'workflow-789',
|
|
117
|
-
operations: [{
|
|
118
|
-
type: 'invalidOperation',
|
|
119
|
-
something: 'else'
|
|
120
|
-
}],
|
|
121
|
-
validateOnly: true
|
|
122
|
-
};
|
|
123
|
-
try {
|
|
124
|
-
const result = await (0, handlers_workflow_diff_1.handleUpdatePartialWorkflow)(invalidTypeRequest);
|
|
125
|
-
logger_1.logger.info('Invalid type result:', JSON.stringify(result, null, 2));
|
|
126
|
-
}
|
|
127
|
-
catch (error) {
|
|
128
|
-
logger_1.logger.info('Expected error for invalid type:', error instanceof Error ? error.message : String(error));
|
|
129
|
-
}
|
|
130
|
-
logger_1.logger.info('\n✅ MCP tool integration tests completed!');
|
|
131
|
-
logger_1.logger.info('\nNOTE: These tests verify the MCP tool can be called without errors.');
|
|
132
|
-
logger_1.logger.info('To test with real workflows, ensure N8N_API_URL and N8N_API_KEY are set.');
|
|
133
|
-
}
|
|
134
|
-
testMcpUpdatePartialWorkflow().catch(error => {
|
|
135
|
-
logger_1.logger.error('Unhandled error:', error);
|
|
136
|
-
process.exit(1);
|
|
137
|
-
});
|
|
138
|
-
//# sourceMappingURL=test-mcp-n8n-update-partial.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"test-mcp-n8n-update-partial.js","sourceRoot":"","sources":["../../src/scripts/test-mcp-n8n-update-partial.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"test-mcp-tools.d.ts","sourceRoot":"","sources":["../../src/scripts/test-mcp-tools.ts"],"names":[],"mappings":""}
|
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
"use strict";
|
|
3
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
-
const server_1 = require("../mcp/server");
|
|
5
|
-
const logger_1 = require("../utils/logger");
|
|
6
|
-
const logger = new logger_1.Logger({ prefix: '[TestMCPTools]' });
|
|
7
|
-
async function testTool(server, toolName, args) {
|
|
8
|
-
try {
|
|
9
|
-
console.log(`\n🔧 Testing: ${toolName}`);
|
|
10
|
-
console.log('Args:', JSON.stringify(args, null, 2));
|
|
11
|
-
console.log('-'.repeat(60));
|
|
12
|
-
const result = await server[toolName].call(server, args);
|
|
13
|
-
console.log('Result:', JSON.stringify(result, null, 2));
|
|
14
|
-
}
|
|
15
|
-
catch (error) {
|
|
16
|
-
console.error(`❌ Error: ${error}`);
|
|
17
|
-
}
|
|
18
|
-
}
|
|
19
|
-
async function main() {
|
|
20
|
-
console.log('🤖 Testing MCP Tools\n');
|
|
21
|
-
const server = new server_1.N8NDocumentationMCPServer();
|
|
22
|
-
await new Promise(resolve => setTimeout(resolve, 100));
|
|
23
|
-
console.log('\n=== Testing get_node_as_tool_info ===');
|
|
24
|
-
await testTool(server, 'getNodeAsToolInfo', 'nodes-base.slack');
|
|
25
|
-
await testTool(server, 'getNodeAsToolInfo', 'nodes-base.googleSheets');
|
|
26
|
-
console.log('\n\n=== Testing get_node_info (with aiToolCapabilities) ===');
|
|
27
|
-
await testTool(server, 'getNodeInfo', 'nodes-base.httpRequest');
|
|
28
|
-
console.log('\n\n=== Testing list_ai_tools (enhanced) ===');
|
|
29
|
-
await testTool(server, 'listAITools', {});
|
|
30
|
-
console.log('\n✅ All tests completed!');
|
|
31
|
-
process.exit(0);
|
|
32
|
-
}
|
|
33
|
-
if (require.main === module) {
|
|
34
|
-
main().catch(console.error);
|
|
35
|
-
}
|
|
36
|
-
//# sourceMappingURL=test-mcp-tools.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"test-mcp-tools.js","sourceRoot":"","sources":["../../src/scripts/test-mcp-tools.ts"],"names":[],"mappings":";;;AAMA,0CAA0D;AAC1D,4CAAyC;AAEzC,MAAM,MAAM,GAAG,IAAI,eAAM,CAAC,EAAE,MAAM,EAAE,gBAAgB,EAAE,CAAC,CAAC;AAExD,KAAK,UAAU,QAAQ,CAAC,MAAW,EAAE,QAAgB,EAAE,IAAS;IAC9D,IAAI,CAAC;QACH,OAAO,CAAC,GAAG,CAAC,iBAAiB,QAAQ,EAAE,CAAC,CAAC;QACzC,OAAO,CAAC,GAAG,CAAC,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QACpD,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC;QAE5B,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QACzD,OAAO,CAAC,GAAG,CAAC,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;IAE1D,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,OAAO,CAAC,KAAK,CAAC,YAAY,KAAK,EAAE,CAAC,CAAC;IACrC,CAAC;AACH,CAAC;AAED,KAAK,UAAU,IAAI;IACjB,OAAO,CAAC,GAAG,CAAC,wBAAwB,CAAC,CAAC;IAGtC,MAAM,MAAM,GAAG,IAAI,kCAAyB,EAAE,CAAC;IAG/C,MAAM,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,UAAU,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,CAAC;IAGvD,OAAO,CAAC,GAAG,CAAC,yCAAyC,CAAC,CAAC;IACvD,MAAM,QAAQ,CAAC,MAAM,EAAE,mBAAmB,EAAE,kBAAkB,CAAC,CAAC;IAChE,MAAM,QAAQ,CAAC,MAAM,EAAE,mBAAmB,EAAE,yBAAyB,CAAC,CAAC;IAGvE,OAAO,CAAC,GAAG,CAAC,6DAA6D,CAAC,CAAC;IAC3E,MAAM,QAAQ,CAAC,MAAM,EAAE,aAAa,EAAE,wBAAwB,CAAC,CAAC;IAGhE,OAAO,CAAC,GAAG,CAAC,8CAA8C,CAAC,CAAC;IAC5D,MAAM,QAAQ,CAAC,MAAM,EAAE,aAAa,EAAE,EAAE,CAAC,CAAC;IAE1C,OAAO,CAAC,GAAG,CAAC,0BAA0B,CAAC,CAAC;IACxC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AAClB,CAAC;AAED,IAAI,OAAO,CAAC,IAAI,KAAK,MAAM,EAAE,CAAC;IAC5B,IAAI,EAAE,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;AAC9B,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"test-metadata-generation.d.ts","sourceRoot":"","sources":["../../src/scripts/test-metadata-generation.ts"],"names":[],"mappings":""}
|
|
@@ -1,96 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
"use strict";
|
|
3
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
4
|
-
if (k2 === undefined) k2 = k;
|
|
5
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
6
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
7
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
8
|
-
}
|
|
9
|
-
Object.defineProperty(o, k2, desc);
|
|
10
|
-
}) : (function(o, m, k, k2) {
|
|
11
|
-
if (k2 === undefined) k2 = k;
|
|
12
|
-
o[k2] = m[k];
|
|
13
|
-
}));
|
|
14
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
15
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
16
|
-
}) : function(o, v) {
|
|
17
|
-
o["default"] = v;
|
|
18
|
-
});
|
|
19
|
-
var __importStar = (this && this.__importStar) || (function () {
|
|
20
|
-
var ownKeys = function(o) {
|
|
21
|
-
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
22
|
-
var ar = [];
|
|
23
|
-
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
24
|
-
return ar;
|
|
25
|
-
};
|
|
26
|
-
return ownKeys(o);
|
|
27
|
-
};
|
|
28
|
-
return function (mod) {
|
|
29
|
-
if (mod && mod.__esModule) return mod;
|
|
30
|
-
var result = {};
|
|
31
|
-
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
32
|
-
__setModuleDefault(result, mod);
|
|
33
|
-
return result;
|
|
34
|
-
};
|
|
35
|
-
})();
|
|
36
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
37
|
-
const dotenv = __importStar(require("dotenv"));
|
|
38
|
-
const database_adapter_1 = require("../database/database-adapter");
|
|
39
|
-
const template_repository_1 = require("../templates/template-repository");
|
|
40
|
-
const metadata_generator_1 = require("../templates/metadata-generator");
|
|
41
|
-
dotenv.config();
|
|
42
|
-
async function testMetadataGeneration() {
|
|
43
|
-
console.log('🧪 Testing metadata generation with OpenAI...\n');
|
|
44
|
-
if (!process.env.OPENAI_API_KEY) {
|
|
45
|
-
console.error('❌ OPENAI_API_KEY not set in environment');
|
|
46
|
-
process.exit(1);
|
|
47
|
-
}
|
|
48
|
-
try {
|
|
49
|
-
const db = await (0, database_adapter_1.createDatabaseAdapter)('./data/nodes.db');
|
|
50
|
-
const repository = new template_repository_1.TemplateRepository(db);
|
|
51
|
-
const templates = repository.getTemplatesWithoutMetadata(3);
|
|
52
|
-
if (templates.length === 0) {
|
|
53
|
-
console.log('✅ All templates already have metadata');
|
|
54
|
-
return;
|
|
55
|
-
}
|
|
56
|
-
console.log(`Found ${templates.length} templates to test with:\n`);
|
|
57
|
-
const generator = new metadata_generator_1.MetadataGenerator(process.env.OPENAI_API_KEY, process.env.OPENAI_MODEL || 'gpt-4o-mini');
|
|
58
|
-
for (const template of templates) {
|
|
59
|
-
console.log(`\n📝 Template: ${template.name}`);
|
|
60
|
-
console.log(` ID: ${template.id}`);
|
|
61
|
-
console.log(` Nodes: ${JSON.parse(template.nodes_used).slice(0, 5).join(', ')}...`);
|
|
62
|
-
try {
|
|
63
|
-
const metadata = await generator.generateSingle({
|
|
64
|
-
templateId: template.id,
|
|
65
|
-
name: template.name,
|
|
66
|
-
description: template.description,
|
|
67
|
-
nodes: JSON.parse(template.nodes_used)
|
|
68
|
-
});
|
|
69
|
-
console.log(' ✅ Generated metadata:');
|
|
70
|
-
console.log(` Categories: ${metadata.categories.join(', ')}`);
|
|
71
|
-
console.log(` Complexity: ${metadata.complexity}`);
|
|
72
|
-
console.log(` Setup time: ${metadata.estimated_setup_minutes} minutes`);
|
|
73
|
-
console.log(` Use cases: ${metadata.use_cases.slice(0, 2).join(', ')}`);
|
|
74
|
-
repository.updateTemplateMetadata(template.id, metadata);
|
|
75
|
-
console.log(' 💾 Saved to database');
|
|
76
|
-
}
|
|
77
|
-
catch (error) {
|
|
78
|
-
console.error(` ❌ Error generating metadata:`, error);
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
const stats = repository.getMetadataStats();
|
|
82
|
-
console.log('\n📊 Metadata Statistics:');
|
|
83
|
-
console.log(` - Total templates: ${stats.total}`);
|
|
84
|
-
console.log(` - With metadata: ${stats.withMetadata}`);
|
|
85
|
-
console.log(` - Without metadata: ${stats.withoutMetadata}`);
|
|
86
|
-
if ('close' in db && typeof db.close === 'function') {
|
|
87
|
-
db.close();
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
catch (error) {
|
|
91
|
-
console.error('❌ Error:', error);
|
|
92
|
-
process.exit(1);
|
|
93
|
-
}
|
|
94
|
-
}
|
|
95
|
-
testMetadataGeneration().catch(console.error);
|
|
96
|
-
//# sourceMappingURL=test-metadata-generation.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"test-metadata-generation.js","sourceRoot":"","sources":["../../src/scripts/test-metadata-generation.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"test-n8n-manager-integration.d.ts","sourceRoot":"","sources":["../../src/scripts/test-n8n-manager-integration.ts"],"names":[],"mappings":""}
|
|
@@ -1,122 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env node
|
|
2
|
-
"use strict";
|
|
3
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
-
const dotenv_1 = require("dotenv");
|
|
5
|
-
const logger_1 = require("../utils/logger");
|
|
6
|
-
const n8n_api_1 = require("../config/n8n-api");
|
|
7
|
-
const handlers_n8n_manager_1 = require("../mcp/handlers-n8n-manager");
|
|
8
|
-
(0, dotenv_1.config)();
|
|
9
|
-
async function testN8nManagerIntegration() {
|
|
10
|
-
logger_1.logger.info('Testing n8n Manager Integration...');
|
|
11
|
-
if (!(0, n8n_api_1.isN8nApiConfigured)()) {
|
|
12
|
-
logger_1.logger.warn('n8n API not configured. Set N8N_API_URL and N8N_API_KEY to test.');
|
|
13
|
-
logger_1.logger.info('Example:');
|
|
14
|
-
logger_1.logger.info(' N8N_API_URL=https://your-n8n.com N8N_API_KEY=your-key npm run test:n8n-manager');
|
|
15
|
-
return;
|
|
16
|
-
}
|
|
17
|
-
const apiConfig = (0, n8n_api_1.getN8nApiConfig)();
|
|
18
|
-
logger_1.logger.info('n8n API Configuration:', {
|
|
19
|
-
url: apiConfig.baseUrl,
|
|
20
|
-
timeout: apiConfig.timeout,
|
|
21
|
-
maxRetries: apiConfig.maxRetries
|
|
22
|
-
});
|
|
23
|
-
const client = (0, handlers_n8n_manager_1.getN8nApiClient)();
|
|
24
|
-
if (!client) {
|
|
25
|
-
logger_1.logger.error('Failed to create n8n API client');
|
|
26
|
-
return;
|
|
27
|
-
}
|
|
28
|
-
try {
|
|
29
|
-
logger_1.logger.info('\n=== Test 1: Health Check ===');
|
|
30
|
-
const health = await client.healthCheck();
|
|
31
|
-
logger_1.logger.info('Health check passed:', health);
|
|
32
|
-
logger_1.logger.info('\n=== Test 2: List Workflows ===');
|
|
33
|
-
const workflows = await client.listWorkflows({ limit: 5 });
|
|
34
|
-
logger_1.logger.info(`Found ${workflows.data.length} workflows`);
|
|
35
|
-
workflows.data.forEach(wf => {
|
|
36
|
-
logger_1.logger.info(`- ${wf.name} (ID: ${wf.id}, Active: ${wf.active})`);
|
|
37
|
-
});
|
|
38
|
-
logger_1.logger.info('\n=== Test 3: Create Test Workflow ===');
|
|
39
|
-
const testWorkflow = {
|
|
40
|
-
name: `Test Workflow - MCP Integration ${Date.now()}`,
|
|
41
|
-
nodes: [
|
|
42
|
-
{
|
|
43
|
-
id: '1',
|
|
44
|
-
name: 'Start',
|
|
45
|
-
type: 'n8n-nodes-base.start',
|
|
46
|
-
typeVersion: 1,
|
|
47
|
-
position: [250, 300],
|
|
48
|
-
parameters: {}
|
|
49
|
-
},
|
|
50
|
-
{
|
|
51
|
-
id: '2',
|
|
52
|
-
name: 'Set',
|
|
53
|
-
type: 'n8n-nodes-base.set',
|
|
54
|
-
typeVersion: 1,
|
|
55
|
-
position: [450, 300],
|
|
56
|
-
parameters: {
|
|
57
|
-
values: {
|
|
58
|
-
string: [
|
|
59
|
-
{
|
|
60
|
-
name: 'message',
|
|
61
|
-
value: 'Hello from MCP!'
|
|
62
|
-
}
|
|
63
|
-
]
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
],
|
|
68
|
-
connections: {
|
|
69
|
-
'1': {
|
|
70
|
-
main: [[{ node: '2', type: 'main', index: 0 }]]
|
|
71
|
-
}
|
|
72
|
-
},
|
|
73
|
-
settings: {
|
|
74
|
-
executionOrder: 'v1',
|
|
75
|
-
saveDataErrorExecution: 'all',
|
|
76
|
-
saveDataSuccessExecution: 'all',
|
|
77
|
-
saveManualExecutions: true,
|
|
78
|
-
saveExecutionProgress: true
|
|
79
|
-
}
|
|
80
|
-
};
|
|
81
|
-
const createdWorkflow = await client.createWorkflow(testWorkflow);
|
|
82
|
-
logger_1.logger.info('Created workflow:', {
|
|
83
|
-
id: createdWorkflow.id,
|
|
84
|
-
name: createdWorkflow.name,
|
|
85
|
-
active: createdWorkflow.active
|
|
86
|
-
});
|
|
87
|
-
logger_1.logger.info('\n=== Test 4: Get Workflow Details ===');
|
|
88
|
-
const workflowDetails = await client.getWorkflow(createdWorkflow.id);
|
|
89
|
-
logger_1.logger.info('Retrieved workflow:', {
|
|
90
|
-
id: workflowDetails.id,
|
|
91
|
-
name: workflowDetails.name,
|
|
92
|
-
nodeCount: workflowDetails.nodes.length
|
|
93
|
-
});
|
|
94
|
-
logger_1.logger.info('\n=== Test 5: Update Workflow ===');
|
|
95
|
-
const updatedWorkflow = await client.updateWorkflow(createdWorkflow.id, {
|
|
96
|
-
name: `${createdWorkflow.name} - Updated`,
|
|
97
|
-
nodes: workflowDetails.nodes,
|
|
98
|
-
connections: workflowDetails.connections,
|
|
99
|
-
settings: workflowDetails.settings
|
|
100
|
-
});
|
|
101
|
-
logger_1.logger.info('Updated workflow name:', updatedWorkflow.name);
|
|
102
|
-
logger_1.logger.info('\n=== Test 6: List Recent Executions ===');
|
|
103
|
-
const executions = await client.listExecutions({ limit: 5 });
|
|
104
|
-
logger_1.logger.info(`Found ${executions.data.length} recent executions`);
|
|
105
|
-
executions.data.forEach(exec => {
|
|
106
|
-
logger_1.logger.info(`- Workflow: ${exec.workflowName || exec.workflowId}, Status: ${exec.status}, Started: ${exec.startedAt}`);
|
|
107
|
-
});
|
|
108
|
-
logger_1.logger.info('\n=== Test 7: Cleanup ===');
|
|
109
|
-
await client.deleteWorkflow(createdWorkflow.id);
|
|
110
|
-
logger_1.logger.info('Deleted test workflow');
|
|
111
|
-
logger_1.logger.info('\n✅ All tests passed successfully!');
|
|
112
|
-
}
|
|
113
|
-
catch (error) {
|
|
114
|
-
logger_1.logger.error('Test failed:', error);
|
|
115
|
-
process.exit(1);
|
|
116
|
-
}
|
|
117
|
-
}
|
|
118
|
-
testN8nManagerIntegration().catch(error => {
|
|
119
|
-
logger_1.logger.error('Unhandled error:', error);
|
|
120
|
-
process.exit(1);
|
|
121
|
-
});
|
|
122
|
-
//# sourceMappingURL=test-n8n-manager-integration.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"test-n8n-manager-integration.js","sourceRoot":"","sources":["../../src/scripts/test-n8n-manager-integration.ts"],"names":[],"mappings":";;;AAEA,mCAAgC;AAChC,4CAAyC;AACzC,+CAAwE;AACxE,sEAA8D;AAK9D,IAAA,eAAM,GAAE,CAAC;AAET,KAAK,UAAU,yBAAyB;IACtC,eAAM,CAAC,IAAI,CAAC,oCAAoC,CAAC,CAAC;IAGlD,IAAI,CAAC,IAAA,4BAAkB,GAAE,EAAE,CAAC;QAC1B,eAAM,CAAC,IAAI,CAAC,kEAAkE,CAAC,CAAC;QAChF,eAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACxB,eAAM,CAAC,IAAI,CAAC,kFAAkF,CAAC,CAAC;QAChG,OAAO;IACT,CAAC;IAED,MAAM,SAAS,GAAG,IAAA,yBAAe,GAAE,CAAC;IACpC,eAAM,CAAC,IAAI,CAAC,wBAAwB,EAAE;QACpC,GAAG,EAAE,SAAU,CAAC,OAAO;QACvB,OAAO,EAAE,SAAU,CAAC,OAAO;QAC3B,UAAU,EAAE,SAAU,CAAC,UAAU;KAClC,CAAC,CAAC;IAEH,MAAM,MAAM,GAAG,IAAA,sCAAe,GAAE,CAAC;IACjC,IAAI,CAAC,MAAM,EAAE,CAAC;QACZ,eAAM,CAAC,KAAK,CAAC,iCAAiC,CAAC,CAAC;QAChD,OAAO;IACT,CAAC;IAED,IAAI,CAAC;QAEH,eAAM,CAAC,IAAI,CAAC,gCAAgC,CAAC,CAAC;QAC9C,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,WAAW,EAAE,CAAC;QAC1C,eAAM,CAAC,IAAI,CAAC,sBAAsB,EAAE,MAAM,CAAC,CAAC;QAG5C,eAAM,CAAC,IAAI,CAAC,kCAAkC,CAAC,CAAC;QAChD,MAAM,SAAS,GAAG,MAAM,MAAM,CAAC,aAAa,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC;QAC3D,eAAM,CAAC,IAAI,CAAC,SAAS,SAAS,CAAC,IAAI,CAAC,MAAM,YAAY,CAAC,CAAC;QACxD,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE;YAC1B,eAAM,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,IAAI,SAAS,EAAE,CAAC,EAAE,aAAa,EAAE,CAAC,MAAM,GAAG,CAAC,CAAC;QACnE,CAAC,CAAC,CAAC;QAGH,eAAM,CAAC,IAAI,CAAC,wCAAwC,CAAC,CAAC;QACtD,MAAM,YAAY,GAAsB;YACtC,IAAI,EAAE,mCAAmC,IAAI,CAAC,GAAG,EAAE,EAAE;YACrD,KAAK,EAAE;gBACL;oBACE,EAAE,EAAE,GAAG;oBACP,IAAI,EAAE,OAAO;oBACb,IAAI,EAAE,sBAAsB;oBAC5B,WAAW,EAAE,CAAC;oBACd,QAAQ,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC;oBACpB,UAAU,EAAE,EAAE;iBACf;gBACD;oBACE,EAAE,EAAE,GAAG;oBACP,IAAI,EAAE,KAAK;oBACX,IAAI,EAAE,oBAAoB;oBAC1B,WAAW,EAAE,CAAC;oBACd,QAAQ,EAAE,CAAC,GAAG,EAAE,GAAG,CAAC;oBACpB,UAAU,EAAE;wBACV,MAAM,EAAE;4BACN,MAAM,EAAE;gCACN;oCACE,IAAI,EAAE,SAAS;oCACf,KAAK,EAAE,iBAAiB;iCACzB;6BACF;yBACF;qBACF;iBACF;aACF;YACD,WAAW,EAAE;gBACX,GAAG,EAAE;oBACH,IAAI,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC;iBAChD;aACF;YACD,QAAQ,EAAE;gBACR,cAAc,EAAE,IAAI;gBACpB,sBAAsB,EAAE,KAAK;gBAC7B,wBAAwB,EAAE,KAAK;gBAC/B,oBAAoB,EAAE,IAAI;gBAC1B,qBAAqB,EAAE,IAAI;aAC5B;SACF,CAAC;QAEF,MAAM,eAAe,GAAG,MAAM,MAAM,CAAC,cAAc,CAAC,YAAY,CAAC,CAAC;QAClE,eAAM,CAAC,IAAI,CAAC,mBAAmB,EAAE;YAC/B,EAAE,EAAE,eAAe,CAAC,EAAE;YACtB,IAAI,EAAE,eAAe,CAAC,IAAI;YAC1B,MAAM,EAAE,eAAe,CAAC,MAAM;SAC/B,CAAC,CAAC;QAGH,eAAM,CAAC,IAAI,CAAC,wCAAwC,CAAC,CAAC;QACtD,MAAM,eAAe,GAAG,MAAM,MAAM,CAAC,WAAW,CAAC,eAAe,CAAC,EAAG,CAAC,CAAC;QACtE,eAAM,CAAC,IAAI,CAAC,qBAAqB,EAAE;YACjC,EAAE,EAAE,eAAe,CAAC,EAAE;YACtB,IAAI,EAAE,eAAe,CAAC,IAAI;YAC1B,SAAS,EAAE,eAAe,CAAC,KAAK,CAAC,MAAM;SACxC,CAAC,CAAC;QAGH,eAAM,CAAC,IAAI,CAAC,mCAAmC,CAAC,CAAC;QAEjD,MAAM,eAAe,GAAG,MAAM,MAAM,CAAC,cAAc,CAAC,eAAe,CAAC,EAAG,EAAE;YACvE,IAAI,EAAE,GAAG,eAAe,CAAC,IAAI,YAAY;YACzC,KAAK,EAAE,eAAe,CAAC,KAAK;YAC5B,WAAW,EAAE,eAAe,CAAC,WAAW;YACxC,QAAQ,EAAE,eAAe,CAAC,QAAQ;SACnC,CAAC,CAAC;QACH,eAAM,CAAC,IAAI,CAAC,wBAAwB,EAAE,eAAe,CAAC,IAAI,CAAC,CAAC;QAG5D,eAAM,CAAC,IAAI,CAAC,0CAA0C,CAAC,CAAC;QACxD,MAAM,UAAU,GAAG,MAAM,MAAM,CAAC,cAAc,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC;QAC7D,eAAM,CAAC,IAAI,CAAC,SAAS,UAAU,CAAC,IAAI,CAAC,MAAM,oBAAoB,CAAC,CAAC;QACjE,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YAC7B,eAAM,CAAC,IAAI,CAAC,eAAe,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,UAAU,aAAa,IAAI,CAAC,MAAM,cAAc,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;QACzH,CAAC,CAAC,CAAC;QAGH,eAAM,CAAC,IAAI,CAAC,2BAA2B,CAAC,CAAC;QACzC,MAAM,MAAM,CAAC,cAAc,CAAC,eAAe,CAAC,EAAG,CAAC,CAAC;QACjD,eAAM,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC;QAErC,eAAM,CAAC,IAAI,CAAC,oCAAoC,CAAC,CAAC;IAEpD,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,eAAM,CAAC,KAAK,CAAC,cAAc,EAAE,KAAK,CAAC,CAAC;QACpC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;AACH,CAAC;AAGD,yBAAyB,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE;IACxC,eAAM,CAAC,KAAK,CAAC,kBAAkB,EAAE,KAAK,CAAC,CAAC;IACxC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AAClB,CAAC,CAAC,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"test-n8n-validate-workflow.d.ts","sourceRoot":"","sources":["../../src/scripts/test-n8n-validate-workflow.ts"],"names":[],"mappings":""}
|