一、前言
在做App自動化測試時,我們會遇到如上圖所示的列表資料頁面左滑刪除場景,一般可以通過location、rect方法獲取對應列表的元素座標,然後使用TouchAction或者swipe滑動需要的元素,這種通過座標滑動的方式只能適用於原生App環境,webview環境獲取的座標與螢幕畫素點不一致,具體介紹可以看我部落格的上一篇文章。
Webview環境處理這種問題,可以使用TouchActions裡面的flick_element()方法。
二、用到的方法
TouchActions裡面的flick_element()方法是先找到元素,然後以元素中心為原點沿著X、Y軸移動畫素點,不需要獲取元素的座標。
1、 flick_element(on_element, xoffset, yoffset, speed)
從 on_element 開始輕彈,然後以指定的速度移動 xoffset 和 yoffset。
引數:
- on_element: Flick 將從元素的中心開始。
- xoffset: X 軸偏移量
- yoffset: Y 軸偏移量
- speed: 每秒偏移的畫素
上面的引數中on_element為定位到的元素物件。
xoffset、yoffset為偏移的畫素點,原點是元素的中心,向右和向下偏移為正數、向左和向上偏移為負數。如下圖:
Speed為每秒偏移的畫素,也就是移動的速度,可以根據手機的效能來設定。
三、 示例
執行的程式碼:
from selenium.webdriver.common.touch_actions import TouchActions # 獲取螢幕的寬度
width = driver.get_window_size()['width']
# 拖拽的元素
ele_str = driver.find_element(By.XPATH, "//span[text()='張三']/../following-sibling::div[@class='edit']")
# X負方向左滑寬度的40%,以每秒1000個畫素點的速度移動
TouchActions(driver).flick_element(ele_str, -width * 0.4, 0, 1000).perform()