Skip to main content
Glama
DaxianLee

Cocos Creator MCP Server Plugin

by DaxianLee
tool-tester.js16.9 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.ToolTester = void 0; class ToolTester { constructor() { this.results = []; } async runTest(tool, method, params) { const startTime = Date.now(); const result = { tool, method, success: false, time: 0 }; try { const response = await Editor.Message.request(tool, method, params); result.success = true; result.result = response; } catch (error) { result.success = false; result.error = error instanceof Error ? error.message : String(error); } result.time = Date.now() - startTime; this.results.push(result); return result; } async testSceneOperations() { console.log('Testing Scene Operations...'); // Test node creation (this is the main scene operation that works) const createResult = await this.runTest('scene', 'create-node', { name: 'TestNode', type: 'cc.Node' }); if (createResult.success && createResult.result) { const nodeUuid = createResult.result; // Test query node info await this.runTest('scene', 'query-node-info', nodeUuid); // Test remove node await this.runTest('scene', 'remove-node', nodeUuid); } // Test execute scene script await this.runTest('scene', 'execute-scene-script', { name: 'cocos-mcp-server', method: 'test-method', args: [] }); } async testNodeOperations() { console.log('Testing Node Operations...'); // Create a test node first const createResult = await this.runTest('scene', 'create-node', { name: 'TestNodeForOps', type: 'cc.Node' }); if (createResult.success && createResult.result) { const nodeUuid = createResult.result; // Test set property await this.runTest('scene', 'set-property', { uuid: nodeUuid, path: 'position', dump: { type: 'cc.Vec3', value: { x: 100, y: 200, z: 0 } } }); // Test add component await this.runTest('scene', 'add-component', { uuid: nodeUuid, component: 'cc.Sprite' }); // Clean up await this.runTest('scene', 'remove-node', nodeUuid); } } async testAssetOperations() { console.log('Testing Asset Operations...'); // Test asset list await this.runTest('asset-db', 'query-assets', { pattern: '**/*.png', ccType: 'cc.ImageAsset' }); // Test query asset by path await this.runTest('asset-db', 'query-path', 'db://assets'); // Test query asset by uuid (using a valid uuid format) await this.runTest('asset-db', 'query-uuid', 'db://assets'); } async testProjectOperations() { console.log('Testing Project Operations...'); // Test open project settings await this.runTest('project', 'open-settings', {}); // Test query project settings const projectName = await this.runTest('project', 'query-setting', 'name'); if (projectName.success) { console.log('Project name:', projectName.result); } } async runAllTests() { this.results = []; await this.testSceneOperations(); await this.testNodeOperations(); await this.testAssetOperations(); await this.testProjectOperations(); return this.getTestReport(); } getTestReport() { const total = this.results.length; const passed = this.results.filter(r => r.success).length; const failed = total - passed; return { summary: { total, passed, failed, passRate: total > 0 ? (passed / total * 100).toFixed(2) + '%' : '0%' }, results: this.results, grouped: this.groupResultsByTool() }; } groupResultsByTool() { const grouped = {}; for (const result of this.results) { if (!grouped[result.tool]) { grouped[result.tool] = []; } grouped[result.tool].push(result); } return grouped; } } exports.ToolTester = ToolTester; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tool-tester.js","sourceRoot":"","sources":["../../source/test/tool-tester.ts"],"names":[],"mappings":"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","sourcesContent":["declare const Editor: any;\n\ninterface TestResult {\n    tool: string;\n    method: string;\n    success: boolean;\n    result?: any;\n    error?: string;\n    time: number;\n}\n\nexport class ToolTester {\n    private results: TestResult[] = [];\n\n    async runTest(tool: string, method: string, params: any): Promise<TestResult> {\n        const startTime = Date.now();\n        const result: TestResult = {\n            tool,\n            method,\n            success: false,\n            time: 0\n        };\n\n        try {\n            const response = await Editor.Message.request(tool, method, params);\n            result.success = true;\n            result.result = response;\n        } catch (error) {\n            result.success = false;\n            result.error = error instanceof Error ? error.message : String(error);\n        }\n\n        result.time = Date.now() - startTime;\n        this.results.push(result);\n        return result;\n    }\n\n    async testSceneOperations() {\n        console.log('Testing Scene Operations...');\n        \n        // Test node creation (this is the main scene operation that works)\n        const createResult = await this.runTest('scene', 'create-node', {\n            name: 'TestNode',\n            type: 'cc.Node'\n        });\n        \n        if (createResult.success && createResult.result) {\n            const nodeUuid = createResult.result;\n            \n            // Test query node info\n            await this.runTest('scene', 'query-node-info', nodeUuid);\n            \n            // Test remove node\n            await this.runTest('scene', 'remove-node', nodeUuid);\n        }\n        \n        // Test execute scene script\n        await this.runTest('scene', 'execute-scene-script', {\n            name: 'cocos-mcp-server',\n            method: 'test-method',\n            args: []\n        });\n    }\n\n    async testNodeOperations() {\n        console.log('Testing Node Operations...');\n        \n        // Create a test node first\n        const createResult = await this.runTest('scene', 'create-node', {\n            name: 'TestNodeForOps',\n            type: 'cc.Node'\n        });\n        \n        if (createResult.success && createResult.result) {\n            const nodeUuid = createResult.result;\n            \n            // Test set property\n            await this.runTest('scene', 'set-property', {\n                uuid: nodeUuid,\n                path: 'position',\n                dump: {\n                    type: 'cc.Vec3',\n                    value: { x: 100, y: 200, z: 0 }\n                }\n            });\n            \n            // Test add component\n            await this.runTest('scene', 'add-component', {\n                uuid: nodeUuid,\n                component: 'cc.Sprite'\n            });\n            \n            // Clean up\n            await this.runTest('scene', 'remove-node', nodeUuid);\n        }\n    }\n\n    async testAssetOperations() {\n        console.log('Testing Asset Operations...');\n        \n        // Test asset list\n        await this.runTest('asset-db', 'query-assets', {\n            pattern: '**/*.png',\n            ccType: 'cc.ImageAsset'\n        });\n        \n        // Test query asset by path\n        await this.runTest('asset-db', 'query-path', 'db://assets');\n        \n        // Test query asset by uuid (using a valid uuid format)\n        await this.runTest('asset-db', 'query-uuid', 'db://assets');\n    }\n\n    async testProjectOperations() {\n        console.log('Testing Project Operations...');\n        \n        // Test open project settings\n        await this.runTest('project', 'open-settings', {});\n        \n        // Test query project settings\n        const projectName = await this.runTest('project', 'query-setting', 'name');\n        \n        if (projectName.success) {\n            console.log('Project name:', projectName.result);\n        }\n    }\n\n    async runAllTests() {\n        this.results = [];\n        \n        await this.testSceneOperations();\n        await this.testNodeOperations();\n        await this.testAssetOperations();\n        await this.testProjectOperations();\n        \n        return this.getTestReport();\n    }\n\n    getTestReport() {\n        const total = this.results.length;\n        const passed = this.results.filter(r => r.success).length;\n        const failed = total - passed;\n        \n        return {\n            summary: {\n                total,\n                passed,\n                failed,\n                passRate: total > 0 ? (passed / total * 100).toFixed(2) + '%' : '0%'\n            },\n            results: this.results,\n            grouped: this.groupResultsByTool()\n        };\n    }\n\n    private groupResultsByTool() {\n        const grouped: Record<string, TestResult[]> = {};\n        \n        for (const result of this.results) {\n            if (!grouped[result.tool]) {\n                grouped[result.tool] = [];\n            }\n            grouped[result.tool].push(result);\n        }\n        \n        return grouped;\n    }\n}"]}

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