干货|APP自动化Android特殊控件Toast识别

Toast 是 Android 系统中的一种消息框类型,它属于一种轻量级的消息提示,常常以小弹框的形式出现,一般出现 1 到 2 秒会自动消失,可以出现在屏幕上中下任意位置。它不同于 Dialog,它没有焦点。Toast 的设计思想是尽可能的不引人注意,同时还向用户显示信息希望他们看到。
测试 APP 下载地址:
首先将上面地址的 apk 包下载到本地,并安装到模拟器中;在模拟器中打开 API Demos,依次点击“Views”-“Popup Menu”-"Make a Popup"-"Search",就会弹出消息提示框,如图:

干货|APP自动化Android特殊控件Toast识别_第1张图片

上图中 “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 定位方式,很轻松的可以定位到。

消息提示Toast获取方法就讲完了,大家学会了么?我们下一期为大家讲解app自动化中的属性获取与断言,有兴趣的小伙伴可以关注一下哦!

你可能感兴趣的:(软件测试)