Skip to main content
Glama
DaxianLee

Cocos Creator MCP Server Plugin

by DaxianLee
mcp-tool-tester.js32.7 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.MCPToolTester = void 0; /** * MCP 工具测试器 - 直接测试通过 WebSocket 的 MCP 工具 */ class MCPToolTester { constructor() { this.ws = null; this.messageId = 0; this.responseHandlers = new Map(); } async connect(port) { return new Promise((resolve) => { try { this.ws = new WebSocket(`ws://localhost:${port}`); this.ws.onopen = () => { console.log('WebSocket 连接成功'); resolve(true); }; this.ws.onerror = (error) => { console.error('WebSocket 连接错误:', error); resolve(false); }; this.ws.onmessage = (event) => { try { const response = JSON.parse(event.data); if (response.id && this.responseHandlers.has(response.id)) { const handler = this.responseHandlers.get(response.id); this.responseHandlers.delete(response.id); handler === null || handler === void 0 ? void 0 : handler(response); } } catch (error) { console.error('处理响应时出错:', error); } }; } catch (error) { console.error('创建 WebSocket 时出错:', error); resolve(false); } }); } async callTool(tool, args = {}) { if (!this.ws || this.ws.readyState !== WebSocket.OPEN) { throw new Error('WebSocket 未连接'); } return new Promise((resolve, reject) => { const id = ++this.messageId; const request = { jsonrpc: '2.0', id, method: 'tools/call', params: { name: tool, arguments: args } }; const timeout = setTimeout(() => { this.responseHandlers.delete(id); reject(new Error('请求超时')); }, 10000); this.responseHandlers.set(id, (response) => { clearTimeout(timeout); if (response.error) { reject(new Error(response.error.message)); } else { resolve(response.result); } }); this.ws.send(JSON.stringify(request)); }); } async listTools() { if (!this.ws || this.ws.readyState !== WebSocket.OPEN) { throw new Error('WebSocket 未连接'); } return new Promise((resolve, reject) => { const id = ++this.messageId; const request = { jsonrpc: '2.0', id, method: 'tools/list' }; const timeout = setTimeout(() => { this.responseHandlers.delete(id); reject(new Error('请求超时')); }, 10000); this.responseHandlers.set(id, (response) => { clearTimeout(timeout); if (response.error) { reject(new Error(response.error.message)); } else { resolve(response.result); } }); this.ws.send(JSON.stringify(request)); }); } async testMCPTools() { var _a, _b; console.log('\n=== 测试 MCP 工具(通过 WebSocket)==='); try { // 0. 获取工具列表 console.log('\n0. 获取工具列表...'); const toolsList = await this.listTools(); console.log(`找到 ${((_a = toolsList.tools) === null || _a === void 0 ? void 0 : _a.length) || 0} 个工具:`); if (toolsList.tools) { for (const tool of toolsList.tools.slice(0, 10)) { // 只显示前10个 console.log(` - ${tool.name}: ${tool.description}`); } if (toolsList.tools.length > 10) { console.log(` ... 还有 ${toolsList.tools.length - 10} 个工具`); } } // 1. 测试场景工具 console.log('\n1. 测试当前场景信息...'); const sceneInfo = await this.callTool('scene_get_current_scene'); console.log('场景信息:', JSON.stringify(sceneInfo).substring(0, 100) + '...'); // 2. 测试场景列表 console.log('\n2. 测试场景列表...'); const sceneList = await this.callTool('scene_get_scene_list'); console.log('场景列表:', JSON.stringify(sceneList).substring(0, 100) + '...'); // 3. 测试节点创建 console.log('\n3. 测试创建节点...'); const createResult = await this.callTool('node_create_node', { name: 'MCPTestNode_' + Date.now(), nodeType: 'cc.Node', position: { x: 0, y: 0, z: 0 } }); console.log('创建节点结果:', createResult); // 解析创建节点的结果 let nodeUuid = null; if (createResult.content && createResult.content[0] && createResult.content[0].text) { try { const resultData = JSON.parse(createResult.content[0].text); if (resultData.success && resultData.data && resultData.data.uuid) { nodeUuid = resultData.data.uuid; console.log('成功获取节点UUID:', nodeUuid); } } catch (e) { } } if (nodeUuid) { // 4. 测试查询节点 console.log('\n4. 测试查询节点...'); const queryResult = await this.callTool('node_get_node_info', { uuid: nodeUuid }); console.log('节点信息:', JSON.stringify(queryResult).substring(0, 100) + '...'); // 5. 测试删除节点 console.log('\n5. 测试删除节点...'); const removeResult = await this.callTool('node_delete_node', { uuid: nodeUuid }); console.log('删除结果:', removeResult); } else { console.log('无法从创建结果获取节点UUID,尝试通过名称查找...'); // 备用方案:通过名称查找刚创建的节点 const findResult = await this.callTool('node_find_node_by_name', { name: 'MCPTestNode_' + Date.now() }); if (findResult.content && findResult.content[0] && findResult.content[0].text) { try { const findData = JSON.parse(findResult.content[0].text); if (findData.success && findData.data && findData.data.uuid) { nodeUuid = findData.data.uuid; console.log('通过名称查找成功获取UUID:', nodeUuid); } } catch (e) { } } if (!nodeUuid) { console.log('所有方式都无法获取节点UUID,跳过后续节点操作测试'); } } // 6. 测试项目工具 console.log('\n6. 测试项目信息...'); const projectInfo = await this.callTool('project_get_project_info'); console.log('项目信息:', JSON.stringify(projectInfo).substring(0, 100) + '...'); // 7. 测试预制体工具 console.log('\n7. 测试预制体列表...'); const prefabResult = await this.callTool('prefab_get_prefab_list', { folder: 'db://assets' }); console.log('找到预制体:', ((_b = prefabResult.data) === null || _b === void 0 ? void 0 : _b.length) || 0); // 8. 测试组件工具 console.log('\n8. 测试可用组件...'); const componentsResult = await this.callTool('component_get_available_components'); console.log('可用组件:', JSON.stringify(componentsResult).substring(0, 100) + '...'); // 9. 测试调试工具 console.log('\n9. 测试编辑器信息...'); const editorInfo = await this.callTool('debug_get_editor_info'); console.log('编辑器信息:', JSON.stringify(editorInfo).substring(0, 100) + '...'); } catch (error) { console.error('MCP 工具测试失败:', error); } } disconnect() { if (this.ws) { this.ws.close(); this.ws = null; } this.responseHandlers.clear(); } } exports.MCPToolTester = MCPToolTester; // 导出到全局方便测试 global.MCPToolTester = MCPToolTester; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mcp-tool-tester.js","sourceRoot":"","sources":["../../source/test/mcp-tool-tester.ts"],"names":[],"mappings":"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","sourcesContent":["declare const Editor: any;\n\n/**\n * MCP 工具测试器 - 直接测试通过 WebSocket 的 MCP 工具\n */\nexport class MCPToolTester {\n    private ws: WebSocket | null = null;\n    private messageId = 0;\n    private responseHandlers = new Map<number, (response: any) => void>();\n\n    async connect(port: number): Promise<boolean> {\n        return new Promise((resolve) => {\n            try {\n                this.ws = new WebSocket(`ws://localhost:${port}`);\n                \n                this.ws.onopen = () => {\n                    console.log('WebSocket 连接成功');\n                    resolve(true);\n                };\n                \n                this.ws.onerror = (error) => {\n                    console.error('WebSocket 连接错误:', error);\n                    resolve(false);\n                };\n                \n                this.ws.onmessage = (event) => {\n                    try {\n                        const response = JSON.parse(event.data);\n                        if (response.id && this.responseHandlers.has(response.id)) {\n                            const handler = this.responseHandlers.get(response.id);\n                            this.responseHandlers.delete(response.id);\n                            handler?.(response);\n                        }\n                    } catch (error) {\n                        console.error('处理响应时出错:', error);\n                    }\n                };\n            } catch (error) {\n                console.error('创建 WebSocket 时出错:', error);\n                resolve(false);\n            }\n        });\n    }\n\n    async callTool(tool: string, args: any = {}): Promise<any> {\n        if (!this.ws || this.ws.readyState !== WebSocket.OPEN) {\n            throw new Error('WebSocket 未连接');\n        }\n\n        return new Promise((resolve, reject) => {\n            const id = ++this.messageId;\n            const request = {\n                jsonrpc: '2.0',\n                id,\n                method: 'tools/call',\n                params: {\n                    name: tool,\n                    arguments: args\n                }\n            };\n\n            const timeout = setTimeout(() => {\n                this.responseHandlers.delete(id);\n                reject(new Error('请求超时'));\n            }, 10000);\n\n            this.responseHandlers.set(id, (response) => {\n                clearTimeout(timeout);\n                if (response.error) {\n                    reject(new Error(response.error.message));\n                } else {\n                    resolve(response.result);\n                }\n            });\n\n            this.ws!.send(JSON.stringify(request));\n        });\n    }\n\n    async listTools(): Promise<any> {\n        if (!this.ws || this.ws.readyState !== WebSocket.OPEN) {\n            throw new Error('WebSocket 未连接');\n        }\n\n        return new Promise((resolve, reject) => {\n            const id = ++this.messageId;\n            const request = {\n                jsonrpc: '2.0',\n                id,\n                method: 'tools/list'\n            };\n\n            const timeout = setTimeout(() => {\n                this.responseHandlers.delete(id);\n                reject(new Error('请求超时'));\n            }, 10000);\n\n            this.responseHandlers.set(id, (response) => {\n                clearTimeout(timeout);\n                if (response.error) {\n                    reject(new Error(response.error.message));\n                } else {\n                    resolve(response.result);\n                }\n            });\n\n            this.ws!.send(JSON.stringify(request));\n        });\n    }\n\n    async testMCPTools() {\n        console.log('\\n=== 测试 MCP 工具（通过 WebSocket）===');\n        \n        try {\n            // 0. 获取工具列表\n            console.log('\\n0. 获取工具列表...');\n            const toolsList = await this.listTools();\n            console.log(`找到 ${toolsList.tools?.length || 0} 个工具:`);\n            if (toolsList.tools) {\n                for (const tool of toolsList.tools.slice(0, 10)) { // 只显示前10个\n                    console.log(`  - ${tool.name}: ${tool.description}`);\n                }\n                if (toolsList.tools.length > 10) {\n                    console.log(`  ... 还有 ${toolsList.tools.length - 10} 个工具`);\n                }\n            }\n            \n            // 1. 测试场景工具\n            console.log('\\n1. 测试当前场景信息...');\n            const sceneInfo = await this.callTool('scene_get_current_scene');\n            console.log('场景信息:', JSON.stringify(sceneInfo).substring(0, 100) + '...');\n            \n            // 2. 测试场景列表\n            console.log('\\n2. 测试场景列表...');\n            const sceneList = await this.callTool('scene_get_scene_list');\n            console.log('场景列表:', JSON.stringify(sceneList).substring(0, 100) + '...');\n            \n            // 3. 测试节点创建\n            console.log('\\n3. 测试创建节点...');\n            const createResult = await this.callTool('node_create_node', {\n                name: 'MCPTestNode_' + Date.now(),\n                nodeType: 'cc.Node',\n                position: { x: 0, y: 0, z: 0 }\n            });\n            console.log('创建节点结果:', createResult);\n            \n            // 解析创建节点的结果\n            let nodeUuid: string | null = null;\n            if (createResult.content && createResult.content[0] && createResult.content[0].text) {\n                try {\n                    const resultData = JSON.parse(createResult.content[0].text);\n                    if (resultData.success && resultData.data && resultData.data.uuid) {\n                        nodeUuid = resultData.data.uuid;\n                        console.log('成功获取节点UUID:', nodeUuid);\n                    }\n                } catch (e) {\n                }\n            }\n            \n            if (nodeUuid) {\n                // 4. 测试查询节点\n                console.log('\\n4. 测试查询节点...');\n                const queryResult = await this.callTool('node_get_node_info', {\n                    uuid: nodeUuid\n                });\n                console.log('节点信息:', JSON.stringify(queryResult).substring(0, 100) + '...');\n                \n                // 5. 测试删除节点\n                console.log('\\n5. 测试删除节点...');\n                const removeResult = await this.callTool('node_delete_node', {\n                    uuid: nodeUuid\n                });\n                console.log('删除结果:', removeResult);\n            } else {\n                console.log('无法从创建结果获取节点UUID，尝试通过名称查找...');\n                \n                // 备用方案：通过名称查找刚创建的节点\n                const findResult = await this.callTool('node_find_node_by_name', {\n                    name: 'MCPTestNode_' + Date.now()\n                });\n                \n                if (findResult.content && findResult.content[0] && findResult.content[0].text) {\n                    try {\n                        const findData = JSON.parse(findResult.content[0].text);\n                        if (findData.success && findData.data && findData.data.uuid) {\n                            nodeUuid = findData.data.uuid;\n                            console.log('通过名称查找成功获取UUID:', nodeUuid);\n                        }\n                    } catch (e) {\n                    }\n                }\n                \n                if (!nodeUuid) {\n                    console.log('所有方式都无法获取节点UUID，跳过后续节点操作测试');\n                }\n            }\n            \n            // 6. 测试项目工具\n            console.log('\\n6. 测试项目信息...');\n            const projectInfo = await this.callTool('project_get_project_info');\n            console.log('项目信息:', JSON.stringify(projectInfo).substring(0, 100) + '...');\n            \n            // 7. 测试预制体工具\n            console.log('\\n7. 测试预制体列表...');\n            const prefabResult = await this.callTool('prefab_get_prefab_list', {\n                folder: 'db://assets'\n            });\n            console.log('找到预制体:', prefabResult.data?.length || 0);\n            \n            // 8. 测试组件工具\n            console.log('\\n8. 测试可用组件...');\n            const componentsResult = await this.callTool('component_get_available_components');\n            console.log('可用组件:', JSON.stringify(componentsResult).substring(0, 100) + '...');\n            \n            // 9. 测试调试工具\n            console.log('\\n9. 测试编辑器信息...');\n            const editorInfo = await this.callTool('debug_get_editor_info');\n            console.log('编辑器信息:', JSON.stringify(editorInfo).substring(0, 100) + '...');\n            \n        } catch (error) {\n            console.error('MCP 工具测试失败:', error);\n        }\n    }\n\n    disconnect() {\n        if (this.ws) {\n            this.ws.close();\n            this.ws = null;\n        }\n        this.responseHandlers.clear();\n    }\n}\n\n// 导出到全局方便测试\n(global as any).MCPToolTester = MCPToolTester;"]}

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/DaxianLee/cocos-mcp-server'

If you have feedback or need assistance with the MCP directory API, please join our Discord server