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