foliko 1.0.75 → 1.0.76
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/.claude/settings.local.json +159 -157
- package/cli/bin/foliko.js +12 -12
- package/cli/src/commands/chat.js +143 -143
- package/cli/src/commands/list.js +93 -93
- package/cli/src/index.js +75 -75
- package/cli/src/ui/chat-ui.js +201 -201
- package/cli/src/utils/ansi.js +40 -40
- package/cli/src/utils/markdown.js +292 -292
- package/examples/ambient-example.js +194 -194
- package/examples/basic.js +115 -115
- package/examples/bootstrap.js +121 -121
- package/examples/mcp-example.js +56 -56
- package/examples/skill-example.js +49 -49
- package/examples/test-chat.js +137 -137
- package/examples/test-mcp.js +85 -85
- package/examples/test-reload.js +59 -59
- package/examples/test-telegram.js +50 -50
- package/examples/test-tg-bot.js +45 -45
- package/examples/test-tg-simple.js +47 -47
- package/examples/test-tg.js +62 -62
- package/examples/test-think.js +43 -43
- package/examples/test-web-plugin.js +103 -103
- package/examples/test-weixin-feishu.js +103 -103
- package/examples/workflow.js +158 -158
- package/package.json +1 -1
- package/plugins/ai-plugin.js +102 -102
- package/plugins/ambient-agent/EventWatcher.js +113 -113
- package/plugins/ambient-agent/ExplorerLoop.js +640 -640
- package/plugins/ambient-agent/GoalManager.js +197 -197
- package/plugins/ambient-agent/Reflector.js +95 -95
- package/plugins/ambient-agent/StateStore.js +90 -90
- package/plugins/ambient-agent/constants.js +101 -101
- package/plugins/ambient-agent/index.js +579 -579
- package/plugins/audit-plugin.js +187 -187
- package/plugins/default-plugins.js +662 -662
- package/plugins/email/constants.js +64 -64
- package/plugins/email/handlers.js +461 -461
- package/plugins/email/index.js +278 -278
- package/plugins/email/monitor.js +269 -269
- package/plugins/email/parser.js +138 -138
- package/plugins/email/reply.js +151 -151
- package/plugins/email/utils.js +124 -124
- package/plugins/feishu-plugin.js +481 -481
- package/plugins/file-system-plugin.js +826 -826
- package/plugins/install-plugin.js +199 -199
- package/plugins/python-executor-plugin.js +367 -367
- package/plugins/python-plugin-loader.js +481 -481
- package/plugins/rules-plugin.js +294 -294
- package/plugins/scheduler-plugin.js +691 -691
- package/plugins/session-plugin.js +369 -369
- package/plugins/shell-executor-plugin.js +197 -197
- package/plugins/storage-plugin.js +240 -240
- package/plugins/subagent-plugin.js +845 -845
- package/plugins/telegram-plugin.js +482 -482
- package/plugins/think-plugin.js +345 -345
- package/plugins/tools-plugin.js +196 -196
- package/plugins/web-plugin.js +606 -606
- package/plugins/weixin-plugin.js +545 -545
- package/src/capabilities/index.js +11 -11
- package/src/capabilities/skill-manager.js +609 -609
- package/src/capabilities/workflow-engine.js +1109 -1109
- package/src/core/agent-chat.js +882 -882
- package/src/core/agent.js +892 -892
- package/src/core/framework.js +465 -465
- package/src/core/index.js +19 -19
- package/src/core/plugin-base.js +219 -219
- package/src/core/plugin-manager.js +863 -863
- package/src/core/provider.js +114 -114
- package/src/core/sub-agent-config.js +264 -264
- package/src/core/system-prompt-builder.js +120 -120
- package/src/core/tool-registry.js +517 -517
- package/src/core/tool-router.js +297 -297
- package/src/executors/executor-base.js +58 -58
- package/src/executors/mcp-executor.js +741 -741
- package/src/index.js +25 -25
- package/src/utils/circuit-breaker.js +301 -301
- package/src/utils/error-boundary.js +363 -363
- package/src/utils/error.js +374 -374
- package/src/utils/event-emitter.js +97 -97
- package/src/utils/id.js +133 -133
- package/src/utils/index.js +217 -217
- package/src/utils/logger.js +181 -181
- package/src/utils/plugin-helpers.js +90 -90
- package/src/utils/retry.js +122 -122
- package/src/utils/sandbox.js +292 -292
- package/test/tool-registry-validation.test.js +218 -218
- package/website/script.js +136 -136
- package/foliko-1.0.75.tgz +0 -0
|
@@ -1,218 +1,218 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* 工具参数验证测试
|
|
3
|
-
*/
|
|
4
|
-
|
|
5
|
-
const { ToolRegistry } = require('../src/core/tool-registry');
|
|
6
|
-
const { z } = require('zod');
|
|
7
|
-
|
|
8
|
-
async function runTests() {
|
|
9
|
-
console.log('🧪 开始工具参数验证测试\n');
|
|
10
|
-
let passed = 0;
|
|
11
|
-
let failed = 0;
|
|
12
|
-
|
|
13
|
-
// 创建工具注册表
|
|
14
|
-
const registry = new ToolRegistry({ circuitBreaker: false });
|
|
15
|
-
|
|
16
|
-
// 注册带 Zod schema 的工具
|
|
17
|
-
registry.register({
|
|
18
|
-
name: 'greet',
|
|
19
|
-
description: '打招呼工具',
|
|
20
|
-
inputSchema: z.object({
|
|
21
|
-
name: z.string().describe('姓名'),
|
|
22
|
-
age: z.number().optional().describe('年龄'),
|
|
23
|
-
role: z.enum(['admin', 'user', 'guest']).optional().describe('角色'),
|
|
24
|
-
}),
|
|
25
|
-
execute: async (args) => {
|
|
26
|
-
return `Hello, ${args.name}! You are ${args.age || 'unknown age'}.`;
|
|
27
|
-
},
|
|
28
|
-
});
|
|
29
|
-
|
|
30
|
-
// 注册带 JSON Schema 的工具
|
|
31
|
-
registry.register({
|
|
32
|
-
name: 'calculate',
|
|
33
|
-
description: '计算工具',
|
|
34
|
-
inputSchema: {
|
|
35
|
-
type: 'object',
|
|
36
|
-
properties: {
|
|
37
|
-
expression: {
|
|
38
|
-
type: 'string',
|
|
39
|
-
description: '数学表达式',
|
|
40
|
-
},
|
|
41
|
-
precision: {
|
|
42
|
-
type: 'integer',
|
|
43
|
-
description: '精度',
|
|
44
|
-
minimum: 0,
|
|
45
|
-
maximum: 10,
|
|
46
|
-
},
|
|
47
|
-
},
|
|
48
|
-
required: ['expression'],
|
|
49
|
-
},
|
|
50
|
-
execute: async (args) => {
|
|
51
|
-
return `Calculating: ${args.expression}`;
|
|
52
|
-
},
|
|
53
|
-
});
|
|
54
|
-
|
|
55
|
-
// 注册无 schema 的工具
|
|
56
|
-
registry.register({
|
|
57
|
-
name: 'echo',
|
|
58
|
-
description: '回声工具',
|
|
59
|
-
execute: async (args) => {
|
|
60
|
-
return args;
|
|
61
|
-
},
|
|
62
|
-
});
|
|
63
|
-
|
|
64
|
-
// 测试1: 有效的 Zod schema 参数
|
|
65
|
-
try {
|
|
66
|
-
const result = await registry.execute('greet', { name: 'Alice', age: 25 });
|
|
67
|
-
console.log('✅ 测试1 通过: 有效的 Zod schema 参数');
|
|
68
|
-
console.log(` 结果: ${result}\n`);
|
|
69
|
-
passed++;
|
|
70
|
-
} catch (err) {
|
|
71
|
-
console.log('❌ 测试1 失败:', err.message, '\n');
|
|
72
|
-
failed++;
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
// 测试2: 缺少必需参数(Zod schema)
|
|
76
|
-
try {
|
|
77
|
-
await registry.execute('greet', { age: 25 });
|
|
78
|
-
console.log('❌ 测试2 失败: 应该抛出验证错误\n');
|
|
79
|
-
failed++;
|
|
80
|
-
} catch (err) {
|
|
81
|
-
if (err.validationErrors) {
|
|
82
|
-
console.log('✅ 测试2 通过: 缺少必需参数正确抛出验证错误');
|
|
83
|
-
console.log(` 错误详情: ${JSON.stringify(err.validationErrors, null, 2)}\n`);
|
|
84
|
-
passed++;
|
|
85
|
-
} else {
|
|
86
|
-
console.log('❌ 测试2 失败: 错误格式不正确\n');
|
|
87
|
-
failed++;
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
// 测试3: 参数类型错误(Zod schema)
|
|
92
|
-
try {
|
|
93
|
-
await registry.execute('greet', { name: 123, age: 'twenty-five' });
|
|
94
|
-
console.log('❌ 测试3 失败: 应该抛出验证错误\n');
|
|
95
|
-
failed++;
|
|
96
|
-
} catch (err) {
|
|
97
|
-
if (err.validationErrors) {
|
|
98
|
-
console.log('✅ 测试3 通过: 参数类型错误正确抛出验证错误');
|
|
99
|
-
console.log(` 错误详情: ${JSON.stringify(err.validationErrors, null, 2)}\n`);
|
|
100
|
-
passed++;
|
|
101
|
-
} else {
|
|
102
|
-
console.log('❌ 测试3 失败: 错误格式不正确\n');
|
|
103
|
-
failed++;
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
// 测试4: 有效的 JSON Schema 参数
|
|
108
|
-
try {
|
|
109
|
-
const result = await registry.execute('calculate', { expression: '2+2', precision: 2 });
|
|
110
|
-
console.log('✅ 测试4 通过: 有效的 JSON Schema 参数');
|
|
111
|
-
console.log(` 结果: ${result}\n`);
|
|
112
|
-
passed++;
|
|
113
|
-
} catch (err) {
|
|
114
|
-
console.log('❌ 测试4 失败:', err.message, '\n');
|
|
115
|
-
failed++;
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
// 测试5: 缺少必需参数(JSON Schema)
|
|
119
|
-
try {
|
|
120
|
-
await registry.execute('calculate', { precision: 2 });
|
|
121
|
-
console.log('❌ 测试5 失败: 应该抛出验证错误\n');
|
|
122
|
-
failed++;
|
|
123
|
-
} catch (err) {
|
|
124
|
-
if (err.validationErrors) {
|
|
125
|
-
console.log('✅ 测试5 通过: JSON Schema 缺少必需参数正确抛出验证错误');
|
|
126
|
-
console.log(` 错误详情: ${JSON.stringify(err.validationErrors, null, 2)}\n`);
|
|
127
|
-
passed++;
|
|
128
|
-
} else {
|
|
129
|
-
console.log('❌ 测试5 失败: 错误格式不正确\n');
|
|
130
|
-
failed++;
|
|
131
|
-
}
|
|
132
|
-
}
|
|
133
|
-
|
|
134
|
-
// 测试6: 超出范围验证(JSON Schema)
|
|
135
|
-
try {
|
|
136
|
-
await registry.execute('calculate', { expression: '2+2', precision: 15 });
|
|
137
|
-
console.log('❌ 测试6 失败: 应该抛出验证错误\n');
|
|
138
|
-
failed++;
|
|
139
|
-
} catch (err) {
|
|
140
|
-
if (err.validationErrors) {
|
|
141
|
-
console.log('✅ 测试6 通过: JSON Schema 范围验证正确');
|
|
142
|
-
console.log(` 错误详情: ${JSON.stringify(err.validationErrors, null, 2)}\n`);
|
|
143
|
-
passed++;
|
|
144
|
-
} else {
|
|
145
|
-
console.log('❌ 测试6 失败: 错误格式不正确\n');
|
|
146
|
-
failed++;
|
|
147
|
-
}
|
|
148
|
-
}
|
|
149
|
-
|
|
150
|
-
// 测试7: 无 schema 工具接受任意参数
|
|
151
|
-
try {
|
|
152
|
-
const result = await registry.execute('echo', { foo: 'bar', num: 42 });
|
|
153
|
-
console.log('✅ 测试7 通过: 无 schema 工具接受任意参数');
|
|
154
|
-
console.log(` 结果: ${JSON.stringify(result)}\n`);
|
|
155
|
-
passed++;
|
|
156
|
-
} catch (err) {
|
|
157
|
-
console.log('❌ 测试7 失败:', err.message, '\n');
|
|
158
|
-
failed++;
|
|
159
|
-
}
|
|
160
|
-
|
|
161
|
-
// 测试8: 不存在的工具
|
|
162
|
-
try {
|
|
163
|
-
await registry.execute('nonexistent', {});
|
|
164
|
-
console.log('❌ 测试8 失败: 应该抛出工具不存在错误\n');
|
|
165
|
-
failed++;
|
|
166
|
-
} catch (err) {
|
|
167
|
-
if (err.message.includes('not found')) {
|
|
168
|
-
console.log('✅ 测试8 通过: 工具不存在正确抛出错误\n');
|
|
169
|
-
passed++;
|
|
170
|
-
} else {
|
|
171
|
-
console.log('❌ 测试8 失败: 错误类型不正确\n');
|
|
172
|
-
failed++;
|
|
173
|
-
}
|
|
174
|
-
}
|
|
175
|
-
|
|
176
|
-
// 测试9: 可选参数默认值
|
|
177
|
-
try {
|
|
178
|
-
const result = await registry.execute('greet', { name: 'Bob' });
|
|
179
|
-
console.log('✅ 测试9 通过: 可选参数使用默认值');
|
|
180
|
-
console.log(` 结果: ${result}\n`);
|
|
181
|
-
passed++;
|
|
182
|
-
} catch (err) {
|
|
183
|
-
console.log('❌ 测试9 失败:', err.message, '\n');
|
|
184
|
-
failed++;
|
|
185
|
-
}
|
|
186
|
-
|
|
187
|
-
// 测试10: enum 验证
|
|
188
|
-
try {
|
|
189
|
-
await registry.execute('greet', { name: 'Charlie', role: 'hacker' });
|
|
190
|
-
console.log('❌ 测试10 失败: enum 值不正确应抛出错误\n');
|
|
191
|
-
failed++;
|
|
192
|
-
} catch (err) {
|
|
193
|
-
if (err.validationErrors) {
|
|
194
|
-
console.log('✅ 测试10 通过: enum 验证正确');
|
|
195
|
-
console.log(` 错误详情: ${JSON.stringify(err.validationErrors, null, 2)}\n`);
|
|
196
|
-
passed++;
|
|
197
|
-
} else {
|
|
198
|
-
console.log('❌ 测试10 失败: 错误格式不正确\n');
|
|
199
|
-
failed++;
|
|
200
|
-
}
|
|
201
|
-
}
|
|
202
|
-
|
|
203
|
-
// 输出测试摘要
|
|
204
|
-
console.log('='.repeat(50));
|
|
205
|
-
console.log(`测试摘要: ${passed} 通过, ${failed} 失败`);
|
|
206
|
-
console.log('='.repeat(50));
|
|
207
|
-
|
|
208
|
-
return failed === 0;
|
|
209
|
-
}
|
|
210
|
-
|
|
211
|
-
runTests()
|
|
212
|
-
.then((success) => {
|
|
213
|
-
process.exit(success ? 0 : 1);
|
|
214
|
-
})
|
|
215
|
-
.catch((err) => {
|
|
216
|
-
console.error('测试执行失败:', err);
|
|
217
|
-
process.exit(1);
|
|
218
|
-
});
|
|
1
|
+
/**
|
|
2
|
+
* 工具参数验证测试
|
|
3
|
+
*/
|
|
4
|
+
|
|
5
|
+
const { ToolRegistry } = require('../src/core/tool-registry');
|
|
6
|
+
const { z } = require('zod');
|
|
7
|
+
|
|
8
|
+
async function runTests() {
|
|
9
|
+
console.log('🧪 开始工具参数验证测试\n');
|
|
10
|
+
let passed = 0;
|
|
11
|
+
let failed = 0;
|
|
12
|
+
|
|
13
|
+
// 创建工具注册表
|
|
14
|
+
const registry = new ToolRegistry({ circuitBreaker: false });
|
|
15
|
+
|
|
16
|
+
// 注册带 Zod schema 的工具
|
|
17
|
+
registry.register({
|
|
18
|
+
name: 'greet',
|
|
19
|
+
description: '打招呼工具',
|
|
20
|
+
inputSchema: z.object({
|
|
21
|
+
name: z.string().describe('姓名'),
|
|
22
|
+
age: z.number().optional().describe('年龄'),
|
|
23
|
+
role: z.enum(['admin', 'user', 'guest']).optional().describe('角色'),
|
|
24
|
+
}),
|
|
25
|
+
execute: async (args) => {
|
|
26
|
+
return `Hello, ${args.name}! You are ${args.age || 'unknown age'}.`;
|
|
27
|
+
},
|
|
28
|
+
});
|
|
29
|
+
|
|
30
|
+
// 注册带 JSON Schema 的工具
|
|
31
|
+
registry.register({
|
|
32
|
+
name: 'calculate',
|
|
33
|
+
description: '计算工具',
|
|
34
|
+
inputSchema: {
|
|
35
|
+
type: 'object',
|
|
36
|
+
properties: {
|
|
37
|
+
expression: {
|
|
38
|
+
type: 'string',
|
|
39
|
+
description: '数学表达式',
|
|
40
|
+
},
|
|
41
|
+
precision: {
|
|
42
|
+
type: 'integer',
|
|
43
|
+
description: '精度',
|
|
44
|
+
minimum: 0,
|
|
45
|
+
maximum: 10,
|
|
46
|
+
},
|
|
47
|
+
},
|
|
48
|
+
required: ['expression'],
|
|
49
|
+
},
|
|
50
|
+
execute: async (args) => {
|
|
51
|
+
return `Calculating: ${args.expression}`;
|
|
52
|
+
},
|
|
53
|
+
});
|
|
54
|
+
|
|
55
|
+
// 注册无 schema 的工具
|
|
56
|
+
registry.register({
|
|
57
|
+
name: 'echo',
|
|
58
|
+
description: '回声工具',
|
|
59
|
+
execute: async (args) => {
|
|
60
|
+
return args;
|
|
61
|
+
},
|
|
62
|
+
});
|
|
63
|
+
|
|
64
|
+
// 测试1: 有效的 Zod schema 参数
|
|
65
|
+
try {
|
|
66
|
+
const result = await registry.execute('greet', { name: 'Alice', age: 25 });
|
|
67
|
+
console.log('✅ 测试1 通过: 有效的 Zod schema 参数');
|
|
68
|
+
console.log(` 结果: ${result}\n`);
|
|
69
|
+
passed++;
|
|
70
|
+
} catch (err) {
|
|
71
|
+
console.log('❌ 测试1 失败:', err.message, '\n');
|
|
72
|
+
failed++;
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
// 测试2: 缺少必需参数(Zod schema)
|
|
76
|
+
try {
|
|
77
|
+
await registry.execute('greet', { age: 25 });
|
|
78
|
+
console.log('❌ 测试2 失败: 应该抛出验证错误\n');
|
|
79
|
+
failed++;
|
|
80
|
+
} catch (err) {
|
|
81
|
+
if (err.validationErrors) {
|
|
82
|
+
console.log('✅ 测试2 通过: 缺少必需参数正确抛出验证错误');
|
|
83
|
+
console.log(` 错误详情: ${JSON.stringify(err.validationErrors, null, 2)}\n`);
|
|
84
|
+
passed++;
|
|
85
|
+
} else {
|
|
86
|
+
console.log('❌ 测试2 失败: 错误格式不正确\n');
|
|
87
|
+
failed++;
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
// 测试3: 参数类型错误(Zod schema)
|
|
92
|
+
try {
|
|
93
|
+
await registry.execute('greet', { name: 123, age: 'twenty-five' });
|
|
94
|
+
console.log('❌ 测试3 失败: 应该抛出验证错误\n');
|
|
95
|
+
failed++;
|
|
96
|
+
} catch (err) {
|
|
97
|
+
if (err.validationErrors) {
|
|
98
|
+
console.log('✅ 测试3 通过: 参数类型错误正确抛出验证错误');
|
|
99
|
+
console.log(` 错误详情: ${JSON.stringify(err.validationErrors, null, 2)}\n`);
|
|
100
|
+
passed++;
|
|
101
|
+
} else {
|
|
102
|
+
console.log('❌ 测试3 失败: 错误格式不正确\n');
|
|
103
|
+
failed++;
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
// 测试4: 有效的 JSON Schema 参数
|
|
108
|
+
try {
|
|
109
|
+
const result = await registry.execute('calculate', { expression: '2+2', precision: 2 });
|
|
110
|
+
console.log('✅ 测试4 通过: 有效的 JSON Schema 参数');
|
|
111
|
+
console.log(` 结果: ${result}\n`);
|
|
112
|
+
passed++;
|
|
113
|
+
} catch (err) {
|
|
114
|
+
console.log('❌ 测试4 失败:', err.message, '\n');
|
|
115
|
+
failed++;
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
// 测试5: 缺少必需参数(JSON Schema)
|
|
119
|
+
try {
|
|
120
|
+
await registry.execute('calculate', { precision: 2 });
|
|
121
|
+
console.log('❌ 测试5 失败: 应该抛出验证错误\n');
|
|
122
|
+
failed++;
|
|
123
|
+
} catch (err) {
|
|
124
|
+
if (err.validationErrors) {
|
|
125
|
+
console.log('✅ 测试5 通过: JSON Schema 缺少必需参数正确抛出验证错误');
|
|
126
|
+
console.log(` 错误详情: ${JSON.stringify(err.validationErrors, null, 2)}\n`);
|
|
127
|
+
passed++;
|
|
128
|
+
} else {
|
|
129
|
+
console.log('❌ 测试5 失败: 错误格式不正确\n');
|
|
130
|
+
failed++;
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
// 测试6: 超出范围验证(JSON Schema)
|
|
135
|
+
try {
|
|
136
|
+
await registry.execute('calculate', { expression: '2+2', precision: 15 });
|
|
137
|
+
console.log('❌ 测试6 失败: 应该抛出验证错误\n');
|
|
138
|
+
failed++;
|
|
139
|
+
} catch (err) {
|
|
140
|
+
if (err.validationErrors) {
|
|
141
|
+
console.log('✅ 测试6 通过: JSON Schema 范围验证正确');
|
|
142
|
+
console.log(` 错误详情: ${JSON.stringify(err.validationErrors, null, 2)}\n`);
|
|
143
|
+
passed++;
|
|
144
|
+
} else {
|
|
145
|
+
console.log('❌ 测试6 失败: 错误格式不正确\n');
|
|
146
|
+
failed++;
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
// 测试7: 无 schema 工具接受任意参数
|
|
151
|
+
try {
|
|
152
|
+
const result = await registry.execute('echo', { foo: 'bar', num: 42 });
|
|
153
|
+
console.log('✅ 测试7 通过: 无 schema 工具接受任意参数');
|
|
154
|
+
console.log(` 结果: ${JSON.stringify(result)}\n`);
|
|
155
|
+
passed++;
|
|
156
|
+
} catch (err) {
|
|
157
|
+
console.log('❌ 测试7 失败:', err.message, '\n');
|
|
158
|
+
failed++;
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
// 测试8: 不存在的工具
|
|
162
|
+
try {
|
|
163
|
+
await registry.execute('nonexistent', {});
|
|
164
|
+
console.log('❌ 测试8 失败: 应该抛出工具不存在错误\n');
|
|
165
|
+
failed++;
|
|
166
|
+
} catch (err) {
|
|
167
|
+
if (err.message.includes('not found')) {
|
|
168
|
+
console.log('✅ 测试8 通过: 工具不存在正确抛出错误\n');
|
|
169
|
+
passed++;
|
|
170
|
+
} else {
|
|
171
|
+
console.log('❌ 测试8 失败: 错误类型不正确\n');
|
|
172
|
+
failed++;
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
|
|
176
|
+
// 测试9: 可选参数默认值
|
|
177
|
+
try {
|
|
178
|
+
const result = await registry.execute('greet', { name: 'Bob' });
|
|
179
|
+
console.log('✅ 测试9 通过: 可选参数使用默认值');
|
|
180
|
+
console.log(` 结果: ${result}\n`);
|
|
181
|
+
passed++;
|
|
182
|
+
} catch (err) {
|
|
183
|
+
console.log('❌ 测试9 失败:', err.message, '\n');
|
|
184
|
+
failed++;
|
|
185
|
+
}
|
|
186
|
+
|
|
187
|
+
// 测试10: enum 验证
|
|
188
|
+
try {
|
|
189
|
+
await registry.execute('greet', { name: 'Charlie', role: 'hacker' });
|
|
190
|
+
console.log('❌ 测试10 失败: enum 值不正确应抛出错误\n');
|
|
191
|
+
failed++;
|
|
192
|
+
} catch (err) {
|
|
193
|
+
if (err.validationErrors) {
|
|
194
|
+
console.log('✅ 测试10 通过: enum 验证正确');
|
|
195
|
+
console.log(` 错误详情: ${JSON.stringify(err.validationErrors, null, 2)}\n`);
|
|
196
|
+
passed++;
|
|
197
|
+
} else {
|
|
198
|
+
console.log('❌ 测试10 失败: 错误格式不正确\n');
|
|
199
|
+
failed++;
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
|
|
203
|
+
// 输出测试摘要
|
|
204
|
+
console.log('='.repeat(50));
|
|
205
|
+
console.log(`测试摘要: ${passed} 通过, ${failed} 失败`);
|
|
206
|
+
console.log('='.repeat(50));
|
|
207
|
+
|
|
208
|
+
return failed === 0;
|
|
209
|
+
}
|
|
210
|
+
|
|
211
|
+
runTests()
|
|
212
|
+
.then((success) => {
|
|
213
|
+
process.exit(success ? 0 : 1);
|
|
214
|
+
})
|
|
215
|
+
.catch((err) => {
|
|
216
|
+
console.error('测试执行失败:', err);
|
|
217
|
+
process.exit(1);
|
|
218
|
+
});
|