Toast 是 Android 系统中的一种消息框类型,它属于一种轻量级的消息提示,常常以小弹框的形式出现,一般出现 1 到 2 秒会自动消失,可以出现在屏幕上中下任意位置。它不同于 Dialog,它没有焦点。Toast 的设计思想是尽可能的不引人注意,同时还向用户显示信息希望他们看到。
测试 APP 下载地址:
首先将上面地址的 apk 包下载到本地,并安装到模拟器中;在模拟器中打开 API Demos,依次点击“Views”-“Popup Menu”-"Make a Popup"-"Search",就会弹出消息提示框,如图:
上图中 “Clicked Popup menu item Search” 就是 Toast,但它通常在页面上停留的时间只有 2 秒左右,通过 Appium Inspector 一般不容易获取到这个元素。
获取Toast
在模拟器中打开 API Demos 应用,依次点击 “Views”-“Popup Menu”-"Make a Popup"-"Search",查看页面 Toast 元素。
设置capabilities
caps = {}
caps["platformName"] = "android"
caps["deviceName"] = "TestToast"
caps["appPackage"] = "io.appium.android.apis"
caps["appActivity"] = ".ApiDemos"
#必须使用uiautomator2框架
caps["automationName"] = "uiautomator2"
caps["udid"] = "192.168.56.101:5555"
driver = webdriver.Remote("http://localhost:4723/wd/hub", caps)
# 点击 Views
driver.find_element_by_accessibility_id("Views").click()
time.sleep(2)
# 滑动页面
TouchAction(driver).long_press(380, 1150)
.move_to(380, 150).release().perform()
# 点击 `Popup Menu` 项目
driver.find_element_by_xpath(
"//*[@content-desc='Popup Menu']").click()
sleep(2)
# 点击 `Make a Popup`
driver.find_element_by_xpath(
"//*[@content-desc='Make a Popup!']").click()
sleep(2)
# 点击 'Search'
driver.find_element_by_xpath("//*[contains(@text,'Search')]").click()
toastXPath = "//*[@class='android.widget.Toast']"
#打印 toastXPath
print(driver.find_element_by_xpath(toastXPath))
#打印 toastXPath 获取的 text
print(driver.find_element_by_xpath(toastXPath).text)
这里定位 Toast 使用了 Xpath 表达式进行定位,因为 Toast 的 class 属性比较特殊,在当前页面上一般会出现一次class="android.widget.Toast" 的元素,所以使用 Xpath 定位方式,很轻松的可以定位到。