一、前言

在做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()