Metadata-Version: 2.4
Name: jumpstarter-driver-androidemulator
Version: 0.8.2.dev113+gb19d6327f
Summary: Android emulator driver for Jumpstarter - manages emulator lifecycle with ADB tunneling
Project-URL: Homepage, https://jumpstarter.dev
Project-URL: source_archive, https://github.com/jumpstarter-dev/repo/archive/b19d6327fda749bdd72caf050a458788ab29375f.zip
Author-email: Kirk Brauer <kbrauer@hatci.com>
License-Expression: Apache-2.0
Requires-Python: >=3.11
Requires-Dist: jumpstarter-driver-adb==0.8.2.dev113+gb19d6327f
Requires-Dist: jumpstarter-driver-composite==0.8.2.dev113+gb19d6327f
Requires-Dist: jumpstarter-driver-power==0.8.2.dev113+gb19d6327f
Requires-Dist: jumpstarter==0.8.2.dev113+gb19d6327f
Provides-Extra: python-api
Requires-Dist: adbutils>=2.8.7; extra == 'python-api'
Description-Content-Type: text/markdown

# Android Emulator Driver

`jumpstarter-driver-androidemulator` manages Android emulator lifecycle with
ADB tunneling through Jumpstarter. It provides power control (start/stop) for
the Android emulator and combines it with the ADB driver for device access.

## Installation

```shell
pip3 install --extra-index-url https://pkg.jumpstarter.dev/simple/ jumpstarter-driver-androidemulator
```

For the optional Python ADB API:

```shell
pip3 install --extra-index-url https://pkg.jumpstarter.dev/simple/ "jumpstarter-driver-androidemulator[python-api]"
```

## Configuration

Example exporter configuration:

```yaml
export:
  android:
    type: jumpstarter_driver_androidemulator.driver.AndroidEmulator
    config:
      avd_name: "Pixel_6"
      headless: true
      console_port: 5554
      adb_server_port: 15037
```

### Configuration Parameters

| Parameter       | Description                        | Type | Required | Default    |
| --------------- | ---------------------------------- | ---- | -------- | ---------- |
| avd_name        | Name of the Android Virtual Device | str  | yes      |            |
| emulator_path   | Path to the emulator executable    | str  | no       | "emulator" |
| headless        | Run without a window               | bool | no       | true       |
| console_port    | Emulator console port              | int  | no       | 5554       |
| adb_server_port | Port for the custom ADB server     | int  | no       | 15037      |

## Architecture

This is a composite driver with two children:

- **`adb`** (`AdbServer` from `jumpstarter-driver-adb`): Manages the ADB server
  and provides TCP tunneling for remote ADB access
- **`power`** (`AndroidEmulatorPower`): Controls the emulator process lifecycle
  via the standard `PowerInterface` (on/off/read)

The emulator registers with the custom ADB server on port 15037 (via the
`ANDROID_ADB_SERVER_PORT` environment variable) to avoid conflicts with any
local ADB server on the standard port 5037.

## Usage

### CLI

```bash
# Power on the emulator
j android power on

# Check ADB devices through the tunnel
j android adb devices

# Run ADB commands
j android adb shell getprop ro.product.model

# Create a persistent ADB tunnel
j android adb tunnel

# Power off the emulator
j android power off
```

### Python API

```python
from jumpstarter.common.utils import serve
from jumpstarter_driver_androidemulator.driver import AndroidEmulator

driver = AndroidEmulator(avd_name="Pixel_6")
with serve(driver) as client:
    client.power.on()

    # Wait for boot and get an adbutils device
    with client.adb_device(timeout=180) as device:
        print(device.prop.model)
        print(device.shell("pm list packages"))

    client.power.off()
```

## Prerequisites

- Android SDK with emulator and platform-tools installed
- `emulator` and `adb` available on PATH (or specify `emulator_path`)
- An AVD created via Android Studio or `avdmanager`

### Quick AVD Setup

```bash
# Apple Silicon (arm64)
sdkmanager "system-images;android-35;google_apis;arm64-v8a"
avdmanager create avd -n Pixel_6 -k "system-images;android-35;google_apis;arm64-v8a" -d pixel_6

# Intel/AMD (x86_64)
sdkmanager "system-images;android-35;google_apis;x86_64"
avdmanager create avd -n Pixel_6 -k "system-images;android-35;google_apis;x86_64" -d pixel_6
```

## API Reference

### Driver

```{eval-rst}
.. autoclass:: jumpstarter_driver_androidemulator.driver.AndroidEmulator()
    :members:
```

```{eval-rst}
.. autoclass:: jumpstarter_driver_androidemulator.driver.AndroidEmulatorPower()
    :members: on, off, read
```

### Client

```{eval-rst}
.. autoclass:: jumpstarter_driver_androidemulator.client.AndroidEmulatorClient()
    :members: adb_device
```
