Skip to main content
Glama

android_list_emulators

List available Android emulators to manage virtual devices for development and testing.

Instructions

List available Android emulators

Input Schema

TableJSON Schema
NameRequiredDescriptionDefault

No arguments

Implementation Reference

  • The main handler function for 'android_list_emulators' tool. Executes 'emulator -list-avds' to list available AVDs, parses the output, checks which are running using the global runningEmulators map, and returns structured data with emulator list, counts, and status.
    handler: async () => { const result = await processExecutor.execute('emulator', ['-list-avds']); if (result.exitCode !== 0) { throw new Error(`Emulator listing failed: ${result.stderr}`); } const emulators = result.stdout .split('\n') .map(line => line.trim()) .filter(line => line.length > 0) .map(name => ({ name, isRunning: runningEmulators.has(name), pid: runningEmulators.get(name) || null, })); return { success: true, data: { emulators, totalCount: emulators.length, runningCount: emulators.filter(e => e.isRunning).length, }, }; }
  • Registration of the 'android_list_emulators' tool within the createAndroidTools factory function. Defines name, description, empty inputSchema (no parameters required), and attaches the handler.
    tools.set('android_list_emulators', { name: 'android_list_emulators', description: 'List available Android emulators', inputSchema: { type: 'object', properties: {}, required: [] }, handler: async () => { const result = await processExecutor.execute('emulator', ['-list-avds']); if (result.exitCode !== 0) { throw new Error(`Emulator listing failed: ${result.stderr}`); } const emulators = result.stdout .split('\n') .map(line => line.trim()) .filter(line => line.length > 0) .map(name => ({ name, isRunning: runningEmulators.has(name), pid: runningEmulators.get(name) || null, })); return { success: true, data: { emulators, totalCount: emulators.length, runningCount: emulators.filter(e => e.isRunning).length, }, }; } });
  • Global runningEmulators map used by the handler to determine if an emulator is running and its PID. Initialized and used within createAndroidTools.
    * Maps AVD names to process IDs. * * @type {Map<string, number>} */ let runningEmulators: Map<string, number>;
  • Metadata registration in TOOL_REGISTRY for categorization, requirements (requires 'emulator' tool), performance expectations, and testing safety.
    'android_list_emulators': { name: 'android_list_emulators', category: ToolCategory.ESSENTIAL, platform: 'android', requiredTools: [RequiredTool.EMULATOR], description: 'List available Android emulators', safeForTesting: true, performance: { expectedDuration: 1000, timeout: 15000 } },

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/cristianoaredes/mcp-mobile-server'

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