Skip to main content

A Playwright-like CLI for Android automation, built for AI agents.

Project description

AndroidCtl

AndroidCtl is a local Android automation toolkit for developer and agent workflows. It provides a host CLI, a host daemon, shared Python contracts, and an Android device agent that can observe the current UI, expose stable element refs, run actions, wait for screen changes, and collect artifacts such as screenshots.

The usual loop is:

androidctl observe
androidctl tap n3
androidctl wait --until idle
androidctl observe

Repository Layout

  • contracts/: shared Python wire models and command catalog.
  • androidctl/: public CLI, command parsing, daemon discovery, and XML output.
  • androidctld/: host daemon, runtime state, command execution, and device RPC.
  • android/: Kotlin Android device agent with a foreground RPC service and Accessibility service.

Requirements

  • Python 3.10.
  • Android SDK platform tools, especially adb.
  • An Android 11+ device or emulator with USB debugging enabled.

Install From PyPI

Install the released host tools with the single public distribution:

pip install androidctl
androidctl --help

The androidctl distribution includes the CLI, host daemon, and shared Python contracts. Do not install separate androidctld or androidctl-contracts distributions.

Install From Source

Create a local Python environment and install AndroidCtl in editable mode:

conda create -p ./.conda python=3.10
./.conda/bin/python -m pip install -U pip
./.conda/bin/python -m pip install -e ".[dev]"
export PATH="$PWD/.conda/bin:$PATH"

Check the CLI:

androidctl --version
androidctl --help

Build The Android Agent

Released Python packages include the Android agent APK used by setup. When working from source and testing a locally built debug agent, build a debug APK and pass it to setup with --apk:

(cd android && ./gradlew :app:assembleDebug)
androidctl setup --adb --apk android/app/build/outputs/apk/debug/app-debug.apk

The debug APK is created at:

android/app/build/outputs/apk/debug/app-debug.apk

Prepare A Device

Connect a device with USB debugging enabled and confirm that ADB can see it:

adb devices

Run the onboarding helper:

androidctl setup --adb

If more than one device is connected, pass the ADB serial:

androidctl setup --adb --serial <adb-serial>

Setup installs the Android agent, starts its foreground RPC server, provisions a device token, attempts to enable the AndroidCtl Accessibility service, and checks that the daemon can talk to the device. If Android blocks automatic Accessibility enablement, follow the manual instructions printed by the command and rerun setup.

Optional Wireless ADB

Pair and connect from the CLI if you prefer Android wireless debugging:

androidctl adb-pair --pair <host:pair-port> --code <pairing-code>
androidctl adb-connect <host:connect-port>
androidctl setup --adb --serial <host:connect-port>

Basic Usage

Observe the current screen:

androidctl observe

The output is XML intended for scripts and agents. Interactive elements receive refs such as n1, n2, and n3; use those refs in later commands.

Common commands:

androidctl list-apps
androidctl open app:com.android.settings
androidctl open https://example.com
androidctl tap n3
androidctl long-tap n3
androidctl focus n4
androidctl type n4 "hello from androidctl"
androidctl submit n4
androidctl scroll n8 down
androidctl back
androidctl home
androidctl recents
androidctl notifications
androidctl wait --until screen-change
androidctl wait --until gone --ref n3
androidctl wait --until text-present --text "Done"
androidctl wait --until app --app com.android.settings
androidctl screenshot
androidctl close

Commands use the current workspace by default. For a dedicated runtime state directory, pass --workspace-root <path> or set ANDROIDCTL_WORKSPACE_ROOT.

Development

Run the default verification suite from the repository root:

task test
task lint
task quality

Useful focused commands:

task androidctl:test
task androidctld:test
task contracts:test
task android:test
task format
task --list

Source development additionally requires Conda, JDK 17 or newer for Android Gradle builds, and task for repository shortcuts.

Process-level CLI checks are available through:

task test:extended

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

androidctl-0.1.0.tar.gz (1.0 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

androidctl-0.1.0-py3-none-any.whl (1.1 MB view details)

Uploaded Python 3

File details

Details for the file androidctl-0.1.0.tar.gz.

File metadata

  • Download URL: androidctl-0.1.0.tar.gz
  • Upload date:
  • Size: 1.0 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.20

File hashes

Hashes for androidctl-0.1.0.tar.gz
Algorithm Hash digest
SHA256 4e264d3285021defe5bfe10b7731f8441c39ee437d6216621196278550f259c7
MD5 33b5cab812b3ad140c49237e3fd35e14
BLAKE2b-256 044b519ff7328c8d9feca2a1f68a309a27c6270cc3517c02b609ba7c55ea6114

See more details on using hashes here.

File details

Details for the file androidctl-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: androidctl-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 1.1 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.20

File hashes

Hashes for androidctl-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 404d7a0e958b5abf5c7bd9a5c5ca8e61dd6f50820dc826291c35e285459cb596
MD5 47f792e789cbfe78abba3b9efd18b8b4
BLAKE2b-256 ebd1d2063ba62fb63a040aa87491bf0a74b14d60a6d9b2dfb7c5f360243f0fad

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page