Repository URL to install this package:
|
Version:
3.1.1 ▾
|
| Appium_Python_Client.egg-info |
| appium |
| docs |
| LICENSE |
| MANIFEST.in |
| PKG-INFO |
| README.md |
| setup.cfg |
| setup.py |
An extension library for adding WebDriver Protocol and Appium commands to the Selenium Python language binding for use with the mobile testing framework Appium.
There are three ways to install and use the Appium Python client.
Install from PyPi, as 'Appium-Python-Client'.
pip install Appium-Python-Client
You can see the history from here
Install from source, via PyPi. From 'Appium-Python-Client', download and unarchive the source tarball (Appium-Python-Client-X.X.tar.gz).
tar -xvf Appium-Python-Client-X.X.tar.gz cd Appium-Python-Client-X.X python setup.py install
Install from source via GitHub.
git clone git@github.com:appium/python-client.git cd python-client python setup.py install
| Appium Python Client | Selenium binding | Python version |
|---|---|---|
3.0.0+ |
4.12.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.1.0 |
3.x |
3.7, 3.8 |
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 Pipenv and requirements.txt to keep compatible version combinations.
options keyword argument in the webdriver.Remote constructor such as XCUITestOptions instead of desired_capabilities
desired_capabilities argument has been removed since v3.start_activity method: Please use mobile: startActivitylaunch_app, close_app and reset methods: Please refer to https://github.com/appium/appium/issues/15807available_ime_engines, is_ime_active, activate_ime_engine, deactivate_ime_engine and active_ime_engine methods: Please use mobile: shellset_value and set_text methods: Please use element.send_keys or send_keys by W3C Actionsend_test_coverage method is no longer availablesession property is no longer availableall_sessions property is no longer availableforceMjsonwp since Selenium v4 and Appium Python client v2 expect only W3C WebDriver protocolActionHelpers#scroll, ActionHelpers#drag_and_drop, ActionHelpers#tap, ActionHelpers#swipe and ActionHelpers#flick now call W3C actions as its backend
strict_ssl to relax SSL errors such as self-signed onesMultiAction and TouchAction are deprecated. Please use W3C WebDriver actions.
launch_app, close_app, and reset are deprecated. Please read issues#15807 for more detailsOn UIA2, 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.common.actions import interaction from selenium.webdriver.common.actions.action_builder import ActionBuilder 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()
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()
If your Selenium/Appium server decorates the new session capabilities response with the following keys:
directConnectProtocoldirectConnectHostdirectConnectPortdirectConnectPathThen 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 # 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', }) driver = webdriver.Remote( # Appium1 points to http://127.0.0.1:4723/wd/hub by default 'http://127.0.0.1:4723', options=options, direct_connection=True )
strict_ssl option allows you to send commands to an invalid certificate host like a self-signed one.
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.common import AppiumOptions options = AppiumOptions() options.platform_name = 'mac' options.automation_name = 'safari' # set_capability API allows to provide any custom option # calls to it could be chained options.set_capability('browser_name', 'safari') # Appium1 points to http://127.0.0.1:4723/wd/hub by default driver = webdriver.Remote('http://127.0.0.1:4723', options=options, strict_ssl=False)
AppiumConnectionThe first argument of webdriver.Remote can set an arbitrary command executor for you.
from appium import webdriver from appium.options.ios import XCUITestOptions import urllib3 from appium.webdriver.appium_connection import AppiumConnection # Retry connection error up to 3 times. init_args_for_pool_manage = { 'retries': urllib3.util.retry.Retry(total=3, connect=3, read=False) } appium_executor = AppiumConnection( remote_server_addr='http://127.0.0.1:4723', init_args_for_pool_manage=init_args_for_pool_manage ) options = XCUITestOptions() options.platformVersion = '13.4' options.udid = '123456789ABC' options.app = '/full/path/to/app/UICatalog.app.zip' driver = webdriver.Remote(appium_executor, options=options)
AppiumConnectionfrom appium import webdriver from appium.options.ios import XCUITestOptions from appium.webdriver.appium_connection import AppiumConnection class CustomAppiumConnection(AppiumConnection): # Can add your own methods for the custom class pass custom_executor = CustomAppiumConnection(remote_server_addr='http://127.0.0.1:4723') options = XCUITestOptions().load_capabilities({ 'platformVersion': '13.4', 'deviceName': 'iPhone Simulator', 'app': '/full/path/to/app/UICatalog.app.zip', }) driver = webdriver.Remote(custom_executor, options=options)
black, isort and mypy as pre commit hookmake command for development. See make help output for detailsgitchangelog generates CHANGELOG.rstpip install --user pipenvpython -m pipenv lock --clear
Locking Failed! unknown locale: UTF-8 error, then refer pypa/pipenv#187 to solve it.python -m pipenv install --dev --systempre-commit installYou can run all of the tests running on CI via tox in your local.
$ tox
You also can run particular tests like below.
$ pytest test/unit
Run with pytest-xdist
$ pytest -n 2 test/unit
$ pytest test/functional/ios/search_context/find_by_ios_class_chain_tests.py
pip install pytest pytest-xdist$ pytest -n 2 test/functional/ios/search_context/find_by_ios_class_chain_tests.py
Follow the below steps.
$ pip install twine $ pip install git+git://github.com/vaab/gitchangelog.git # Getting via GitHub repository is necessary for Python 3.7 # Type the new version number and 'yes' if you can publish it # You can test the command with DRY_RUN $ DRY_RUN=1 ./release.sh $ ./release.sh # release
Apache License v2