MCPcopy
hub / github.com/appium/python-client

github.com/appium/python-client @v5.3.1 sqlite

repository ↗ · DeepWiki ↗ · release v5.3.1 ↗
1,004 symbols 5,507 edges 389 files 408 documented · 41%
README

Appium Python Client

PyPI version Downloads

Functional Tests

An extension library for adding WebDriver Protocol and Appium commands to the Selenium Python language binding for use with the mobile testing framework Appium.

Getting the Appium Python client

There are three ways to install and use the Appium Python client.

  1. Install from PyPi, as 'Appium-Python-Client'.

    shell pip install Appium-Python-Client

    You can see the history from here

  2. Install from source, via PyPi. From 'Appium-Python-Client', download and unarchive the source tarball (Appium-Python-Client-X.X.tar.gz).

    shell tar -xvf Appium-Python-Client-X.X.tar.gz cd Appium-Python-Client-X.X python setup.py install

  3. Install from source via GitHub.

    shell git clone git@github.com:appium/python-client.git cd python-client python setup.py install

Compatibility Matrix

Appium Python Client Selenium binding Python version
5.1.1+ 4.26.0+ 3.9+
4.5.0 - 5.1.0 4.26.0 - 4.31.0 3.9+
4.3.0 - 4.4.0 4.26.0 - 4.31.0 3.8+
3.0.0 - 4.2.1 4.12.0 - 4.25.0 3.8+
2.10.0 - 2.11.1 4.1.0 - 4.11.2 3.7+
2.2.0 - 2.9.0 4.1.0 - 4.9.0 3.7+
2.0.0 - 2.1.4 4.0.0 3.7+
1.0.0 - 1.3.0 3.x 3.7+
0.52 and below 3.x 2.7, 3.4 - 3.7

The Appium Python Client depends on Selenium Python binding, thus the Selenium Python binding update might affect the Appium Python Client behavior. For example, some changes in the Selenium binding could break the Appium client.

Note We strongly recommend you manage dependencies with version management tools such as uv to keep compatible version combinations.

Quick migration guide from v4 to v5

  • This change affects only for users who specify keep_alive, direct_connection and strict_ssl arguments for webdriver.Remote:
    • Please use AppiumClientConfig as client_config argument similar to how it is specified below: ```python SERVER_URL_BASE = 'http://127.0.0.1:4723' # before driver = webdriver.Remote( SERVER_URL_BASE, options=UiAutomator2Options().load_capabilities(desired_caps), direct_connection=True, keep_alive=False, strict_ssl=False )

      after

      from appium.webdriver.client_config import AppiumClientConfig client_config = AppiumClientConfig( remote_server_addr=SERVER_URL_BASE, direct_connection=True, keep_alive=False, ignore_certificates=True, ) driver = webdriver.Remote( options=UiAutomator2Options().load_capabilities(desired_caps), client_config=client_config ) `` - Note that you can keep usingwebdriver.Remote(url, options=options, client_config=client_config)format as well. In such case theremote_server_addrargument ofAppiumClientConfigconstructor would have priority over theurlargument ofwebdriver.Remoteconstructor. - Usehttp://127.0.0.1:4723as the default server url instead ofhttp://127.0.0.1:4444/wd/hub`

Quick migration guide from v3 to v4

  • Removal
    • MultiAction and TouchAction are removed. Please use W3C WebDriver actions or mobile: extensions
      • appium/webdriver/extensions/action_helpers.py
      • https://www.selenium.dev/documentation/webdriver/actions_api/
      • https://www.youtube.com/watch?v=oAJ7jwMNFVU
      • https://appiumpro.com/editions/30-ios-specific-touch-action-methods
      • https://appiumpro.com/editions/29-automating-complex-gestures-with-the-w3c-actions-api
    • Deprecated AppiumBy.WINDOWS_UI_AUTOMATION, which has no usage right now.

Quick migration guide from v2 to v3

  • options keyword argument in the webdriver.Remote constructor such as XCUITestOptions instead of desired_capabilities
    • Available options are https://github.com/appium/python-client/tree/master/appium/options
      • Please check the Usage below as an example.
    • Not a "new" change, but the desired_capabilities argument has been removed since v3.
  • Replacement
    • start_activity method: Please use mobile: startActivity
    • launch_app, close_app and reset methods: Please refer to https://github.com/appium/appium/issues/15807
    • available_ime_engines, is_ime_active, activate_ime_engine, deactivate_ime_engine and active_ime_engine methods: Please use mobile: shell
    • set_value and set_text methods: Please use element.send_keys or send_keys by W3C Actions
  • Removal
    • end_test_coverage method is no longer available
    • session property is no longer available
    • all_sessions property is no longer available

Quick migration guide from v1 to v2

  • Enhancement
    • Updated base Selenium Python binding version to v4
      • Removed forceMjsonwp since Selenium v4 and Appium Python client v2 expect only W3C WebDriver protocol
    • Methods ActionHelpers#scroll, ActionHelpers#drag_and_drop, ActionHelpers#tap, ActionHelpers#swipe and ActionHelpers#flick now call W3C actions as its backend
      • Please check each behavior. Their behaviors could slightly differ.
    • Added strict_ssl to relax SSL errors such as self-signed ones
  • Deprecated
    • MultiAction and TouchAction are deprecated. Please use W3C WebDriver actions or mobile: extensions
    • launch_app, close_app, and reset are deprecated. Please read issues#15807 for more details

MultiAction/TouchAction to W3C actions

Some elements can be handled with touch pointer action instead of the default mouse pointer action in the Selenium Python client. For example, the below action builder is to replace the default one with the touch pointer action.

from selenium.webdriver import ActionChains
from selenium.webdriver.common.actions import interaction
from selenium.webdriver.common.actions.action_builder import ActionBuilder
from selenium.webdriver.common.actions.pointer_input import PointerInput

actions = ActionChains(driver)
# override as 'touch' pointer action
actions.w3c_actions = ActionBuilder(driver, mouse=PointerInput(interaction.POINTER_TOUCH, "touch"))
actions.w3c_actions.pointer_action.move_to_location(start_x, start_y)
actions.w3c_actions.pointer_action.pointer_down()
actions.w3c_actions.pointer_action.pause(2)
actions.w3c_actions.pointer_action.move_to_location(end_x, end_y)
actions.w3c_actions.pointer_action.release()
actions.perform()

Usage

The Appium Python Client is fully compliant with the WebDriver Protocol including several helpers to make mobile testing in Python easier.

To use the new functionality now, and to use the superset of functions, instead of including the Selenium webdriver module in your test code, use that from Appium instead.

from appium import webdriver

From there much of your test code will work with no change.

As a base for the following code examples, the following set up the UnitTest environment:

# Python/Pytest
import pytest

from appium import webdriver
# Options are only available since client version 2.3.0
# If you use an older client then switch to desired_capabilities
# instead: https://github.com/appium/python-client/pull/720
from appium.options.android import UiAutomator2Options
from appium.options.ios import XCUITestOptions
from appium.webdriver.appium_service import AppiumService
from appium.webdriver.common.appiumby import AppiumBy

APPIUM_PORT = 4723
APPIUM_HOST = '127.0.0.1'


# HINT: fixtures below could be extracted into conftest.py
# HINT: and shared across all tests in the suite
@pytest.fixture(scope='session')
def appium_service():
    service = AppiumService()
    service.start(
        # Check the output of `appium server --help` for the complete list of
        # server command line arguments
        args=['--address', APPIUM_HOST, '-p', str(APPIUM_PORT)],
        timeout_ms=20000,
    )
    yield service
    service.stop()


def create_ios_driver(custom_opts = None):
    options = XCUITestOptions()
    options.platformVersion = '13.4'
    options.udid = '123456789ABC'
    if custom_opts is not None:
        options.load_capabilities(custom_opts)
    # Appium1 points to http://127.0.0.1:4723/wd/hub by default
    return webdriver.Remote(f'http://{APPIUM_HOST}:{APPIUM_PORT}', options=options)


def create_android_driver(custom_opts = None):
    options = UiAutomator2Options()
    options.platformVersion = '10'
    options.udid = '123456789ABC'
    if custom_opts is not None:
        options.load_capabilities(custom_opts)
    # Appium1 points to http://127.0.0.1:4723/wd/hub by default
    return webdriver.Remote(f'http://{APPIUM_HOST}:{APPIUM_PORT}', options=options)


@pytest.fixture
def ios_driver_factory():
    return create_ios_driver


@pytest.fixture
def ios_driver():
    # prefer this fixture if there is no need to customize driver options in tests
    driver = create_ios_driver()
    yield driver
    driver.quit()


@pytest.fixture
def android_driver_factory():
    return create_android_driver


@pytest.fixture
def android_driver():
    # prefer this fixture if there is no need to customize driver options in tests
    driver = create_android_driver()
    yield driver
    driver.quit()


def test_ios_click(appium_service, ios_driver_factory):
    # Usage of the context manager ensures the driver session is closed properly
    # after the test completes. Otherwise, make sure to call `driver.quit()` on teardown.
    with ios_driver_factory({
        'appium:app': '/path/to/app/UICatalog.app.zip'
    }) as driver:
        el = driver.find_element(by=AppiumBy.ACCESSIBILITY_ID, value='item')
        el.click()


def test_android_click(appium_service, android_driver_factory):
    # Usage of the context manager ensures the driver session is closed properly
    # after the test completes. Otherwise, make sure to call `driver.quit()` on teardown.
    with android_driver_factory({
        'appium:app': '/path/to/app/test-app.apk',
        'appium:udid': '567890',
    }) as driver:
        el = driver.find_element(by=AppiumBy.ACCESSIBILITY_ID, value='item')
        el.click()

Available options

Appium Python Client has a common options class named AppiumOptions but the available commands are minimal. It does not have driver/automationName specific commands unless adding commands with add_command method.

Available options for each automation name below will help to check what options are already defined. Please use proper options for your automaiton usage.

automationName | Package path |:---|:-----| any | appium.options.common.base.AppiumOptions uiautomator2 | appium.options.android.Uiautomator2Options espresso | appium.options.android.EspressoOptions xcuitest | appium.options.ios.XCUITestOptions safari | appium.options.ios.SafariOptions mac2 | appium.options.mac.Mac2Options windows | appium.options.WindowsOptions gecko | appium.options.GeckoOptions flutterintegration | appium.options.flutter_integration.FlutterOptions

Direct Connect URLs

If your Selenium/Appium server decorates the new session capabilities response with the following keys:

  • directConnectProtocol
  • directConnectHost
  • directConnectPort
  • directConnectPath

Then python client will switch its endpoint to the one specified by the values of those keys.

from appium import webdriver
# Options are only available since client version 2.3.0
# If you use an older client then switch to desired_capabilities
# instead: https://github.com/appium/python-client/pull/720
from appium.options.ios import XCUITestOptions
from appium.webdriver.client_config import AppiumClientConfig

# load_capabilities API could be used to
# load options mapping stored in a dictionary
options = XCUITestOptions().load_capabilities({
    'platformVersion': '13.4',
    'deviceName': 'iPhone Simulator',
    'app': '/full/path/to/app/UICatalog.app.zip',
})

client_config = AppiumClientConfig(
    remote_server_addr='http://127.0.0.1:4723',
    direct_connection=True
)

driver = webdriver.Remote(
    # Appium1 points to http://127.0.0.1:4723/wd/hub by default
    'http://127.0.0.1:4723',
    options=options,
    client_config=client_config
)

Relax SSL validation

strict_ssl option allows you to send commands to an invalid certificate host like a self-signed one.

```python from appium import webdriver

Options are only available since client version 2.3.0

If you use an older client then switch to desired_capabilities

instead: https://g

Core symbols most depended-on inside this repo

set_capability
called by 225
appium/options/common/base.py
get_capability
called by 220
appium/options/common/base.py
add_command
called by 70
appium/webdriver/webdriver.py
execute
called by 69
appium/webdriver/webdriver.py
execute_script
called by 51
appium/protocols/webdriver/can_execute_scripts.py
find_element
called by 41
appium/webdriver/webdriver.py
assert_extension_exists
called by 41
appium/webdriver/webdriver.py
mark_extension_absence
called by 41
appium/webdriver/webdriver.py

Shape

Method 584
Class 337
Function 79
Route 4

Languages

Python100%

Modules by API surface

test/unit/webdriver/webdriver_test.py34 symbols
appium/webdriver/appium_service.py21 symbols
appium/webdriver/webdriver.py20 symbols
test/unit/webdriver/device/lock_test.py14 symbols
test/unit/webdriver/device/keyboard_test.py13 symbols
appium/webdriver/extensions/flutter_integration/flutter_commands.py13 symbols
test/unit/webdriver/flutter_integration/flutter_search_context_test.py11 symbols
test/unit/webdriver/search_context/android_test.py10 symbols
test/unit/webdriver/app_test.py10 symbols
appium/webdriver/extensions/applications.py10 symbols
appium/options/common/base.py10 symbols
test/functional/test_helper.py9 symbols

Dependencies from manifests, versioned

typing-extensions4.13 · 1×

For agents

$ claude mcp add python-client \
  -- python -m otcore.mcp_server <graph>

⬇ download graph artifact