"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.testSceneTools = testSceneTools;
exports.testAssetTools = testAssetTools;
exports.testProjectTools = testProjectTools;
exports.runAllTests = runAllTests;
/**
* 手动测试脚本
* 可以在 Cocos Creator 控制台中执行测试
*/
async function testSceneTools() {
console.log('=== Testing Scene Tools ===');
try {
// 1. 获取场景信息
console.log('1. Getting scene info...');
const sceneInfo = await Editor.Message.request('scene', 'get-scene-info');
console.log('Scene info:', sceneInfo);
// 2. 创建节点
console.log('\n2. Creating test node...');
const createResult = await Editor.Message.request('scene', 'create-node', {
name: 'TestNode_' + Date.now(),
type: 'cc.Node'
});
console.log('Create result:', createResult);
if (createResult && createResult.uuid) {
const nodeUuid = createResult.uuid;
// 3. 查询节点
console.log('\n3. Querying node...');
const nodeInfo = await Editor.Message.request('scene', 'query-node', {
uuid: nodeUuid
});
console.log('Node info:', nodeInfo);
// 4. 设置节点属性
console.log('\n4. Setting node position...');
await Editor.Message.request('scene', 'set-node-property', {
uuid: nodeUuid,
path: 'position',
value: { x: 100, y: 200, z: 0 }
});
console.log('Position set successfully');
// 5. 添加组件
console.log('\n5. Adding Sprite component...');
const addCompResult = await Editor.Message.request('scene', 'add-component', {
uuid: nodeUuid,
component: 'cc.Sprite'
});
console.log('Component added:', addCompResult);
// 6. 查询组件
console.log('\n6. Querying component...');
const compInfo = await Editor.Message.request('scene', 'query-node-component', {
uuid: nodeUuid,
component: 'cc.Sprite'
});
console.log('Component info:', compInfo);
// 7. 删除节点
console.log('\n7. Removing test node...');
await Editor.Message.request('scene', 'remove-node', {
uuid: nodeUuid
});
console.log('Node removed successfully');
}
}
catch (error) {
console.error('Test failed:', error);
}
}
async function testAssetTools() {
console.log('\n=== Testing Asset Tools ===');
try {
// 1. 查询资源
console.log('1. Querying image assets...');
const assets = await Editor.Message.request('asset-db', 'query-assets', {
pattern: '**/*.png',
ccType: 'cc.ImageAsset'
});
console.log('Found assets:', (assets === null || assets === void 0 ? void 0 : assets.length) || 0);
// 2. 获取资源信息
console.log('\n2. Getting asset database info...');
const assetInfo = await Editor.Message.request('asset-db', 'query-asset-info', {
uuid: 'db://assets'
});
console.log('Asset info:', assetInfo);
}
catch (error) {
console.error('Test failed:', error);
}
}
async function testProjectTools() {
console.log('\n=== Testing Project Tools ===');
try {
// 1. 获取项目信息
console.log('1. Getting project info...');
const projectInfo = await Editor.Message.request('project', 'query-info');
console.log('Project info:', projectInfo);
// 2. 检查构建能力
console.log('\n2. Checking build capability...');
const canBuild = await Editor.Message.request('project', 'can-build');
console.log('Can build:', canBuild);
}
catch (error) {
console.error('Test failed:', error);
}
}
async function runAllTests() {
console.log('Starting MCP Server Tools Test...\n');
await testSceneTools();
await testAssetTools();
await testProjectTools();
console.log('\n=== All tests completed ===');
}
// 导出到全局,方便在控制台调用
global.MCPTest = {
testSceneTools,
testAssetTools,
testProjectTools,
runAllTests
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"manual-test.js","sourceRoot":"","sources":["../../source/test/manual-test.ts"],"names":[],"mappings":"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","sourcesContent":["declare const Editor: any;\n\n/**\n * 手动测试脚本\n * 可以在 Cocos Creator 控制台中执行测试\n */\n\nexport async function testSceneTools() {\n    console.log('=== Testing Scene Tools ===');\n    \n    try {\n        // 1. 获取场景信息\n        console.log('1. Getting scene info...');\n        const sceneInfo = await Editor.Message.request('scene', 'get-scene-info');\n        console.log('Scene info:', sceneInfo);\n        \n        // 2. 创建节点\n        console.log('\\n2. Creating test node...');\n        const createResult = await Editor.Message.request('scene', 'create-node', {\n            name: 'TestNode_' + Date.now(),\n            type: 'cc.Node'\n        });\n        console.log('Create result:', createResult);\n        \n        if (createResult && createResult.uuid) {\n            const nodeUuid = createResult.uuid;\n            \n            // 3. 查询节点\n            console.log('\\n3. Querying node...');\n            const nodeInfo = await Editor.Message.request('scene', 'query-node', {\n                uuid: nodeUuid\n            });\n            console.log('Node info:', nodeInfo);\n            \n            // 4. 设置节点属性\n            console.log('\\n4. Setting node position...');\n            await Editor.Message.request('scene', 'set-node-property', {\n                uuid: nodeUuid,\n                path: 'position',\n                value: { x: 100, y: 200, z: 0 }\n            });\n            console.log('Position set successfully');\n            \n            // 5. 添加组件\n            console.log('\\n5. Adding Sprite component...');\n            const addCompResult = await Editor.Message.request('scene', 'add-component', {\n                uuid: nodeUuid,\n                component: 'cc.Sprite'\n            });\n            console.log('Component added:', addCompResult);\n            \n            // 6. 查询组件\n            console.log('\\n6. Querying component...');\n            const compInfo = await Editor.Message.request('scene', 'query-node-component', {\n                uuid: nodeUuid,\n                component: 'cc.Sprite'\n            });\n            console.log('Component info:', compInfo);\n            \n            // 7. 删除节点\n            console.log('\\n7. Removing test node...');\n            await Editor.Message.request('scene', 'remove-node', {\n                uuid: nodeUuid\n            });\n            console.log('Node removed successfully');\n        }\n        \n    } catch (error) {\n        console.error('Test failed:', error);\n    }\n}\n\nexport async function testAssetTools() {\n    console.log('\\n=== Testing Asset Tools ===');\n    \n    try {\n        // 1. 查询资源\n        console.log('1. Querying image assets...');\n        const assets = await Editor.Message.request('asset-db', 'query-assets', {\n            pattern: '**/*.png',\n            ccType: 'cc.ImageAsset'\n        });\n        console.log('Found assets:', assets?.length || 0);\n        \n        // 2. 获取资源信息\n        console.log('\\n2. Getting asset database info...');\n        const assetInfo = await Editor.Message.request('asset-db', 'query-asset-info', {\n            uuid: 'db://assets'\n        });\n        console.log('Asset info:', assetInfo);\n        \n    } catch (error) {\n        console.error('Test failed:', error);\n    }\n}\n\nexport async function testProjectTools() {\n    console.log('\\n=== Testing Project Tools ===');\n    \n    try {\n        // 1. 获取项目信息\n        console.log('1. Getting project info...');\n        const projectInfo = await Editor.Message.request('project', 'query-info');\n        console.log('Project info:', projectInfo);\n        \n        // 2. 检查构建能力\n        console.log('\\n2. Checking build capability...');\n        const canBuild = await Editor.Message.request('project', 'can-build');\n        console.log('Can build:', canBuild);\n        \n    } catch (error) {\n        console.error('Test failed:', error);\n    }\n}\n\nexport async function runAllTests() {\n    console.log('Starting MCP Server Tools Test...\\n');\n    \n    await testSceneTools();\n    await testAssetTools();\n    await testProjectTools();\n    \n    console.log('\\n=== All tests completed ===');\n}\n\n// 导出到全局，方便在控制台调用\n(global as any).MCPTest = {\n    testSceneTools,\n    testAssetTools,\n    testProjectTools,\n    runAllTests\n};"]}