Skip to content

Latest commit

 

History

History
87 lines (67 loc) · 2.87 KB

README_CN.md

File metadata and controls

87 lines (67 loc) · 2.87 KB

🎉appium-uiautomator2-server的Python客户端

English | 简体中文

背景

目前Github上只看到一个Python绕开Appium Server单独跟appium-uiautomator2-server交互的项目 appium-uiautomator2-client,但是未能兼容最新appium-uiautomator2-server v5.x API的baseUrl,并且没有发布在pypi,尝试过跟作者接触但是没有回复,于是决定组织自己写一个维护。Java版本的可以看我们组织自己维护的 sonic-driver-core

如何使用

➡️更多文档

  1. 安装uia2 server

你需要先安装 sonic-appium-uiautomator2-server.apksonic-appium-uiautomator2-server-test.apk ,可以从这里下载 这里.

当然你也可以自己构建 前往这里

  1. 启动 uiautomator2 server
adb shell am instrument -w io.appium.uiautomator2.server.test/androidx.test.runner.AndroidJUnitRunner
  1. 转发端口
adb forward tcp:6790 tcp:6790
  1. 安装依赖
pip install -U sonic-uia2-client
  1. 编写你的脚本
from common.models import AndroidSelector
from uia2.driver import AndroidDriver
import os


class TestDriver:

    def __init__(self):
        self.uia_url = "http://localhost:6790"
        self.adb_serial_num = "DAISKnlasido"
        self.package_name = "com.android.settings"

    def test_demo(self):
        # launch App
        os.system(
            "adb -s {} shell monkey -p {} -c android.intent.category.LAUNCHER 1".format(self.adb_serial_num,
                                                                                        self.package_name))
        
        # connect remote uia2 server
        driver = AndroidDriver(self.uia_url)
        p = driver.get_page_source()
        print(p)
        e = driver.find_element(AndroidSelector.XPATH, "//*[@text='设置']")
        if e is not None:
            print(e.get_text())
            e.send_keys("Hello")

致谢

LICENSE

LICENSE