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 定位方式,很轻松的可以定位到。
消息提示Toast获取方法就讲完了,大家学会了么?我们下一期为大家讲解app自动化中的属性获取与断言,有兴趣的小伙伴可以关注一下哦!