简介
在移动端应用中,基于简便的原因,用户通常会倾向于使用滑动操作来达到与应用程序中的控件进行交互的,这使得滑动成为自动化测试中频繁使用的关键动作。在 Appium 中提供了多种方式来实现模拟用户的滑动屏幕动作。
滑动操作的场景
移动端应用中的滑动场景,大致有如下几种类型:
- 触摸事件模拟:滑动操作的基本原理是模拟用户触摸屏幕的行为。通过发送一系列的触摸事件,模拟用户按住、滑动和释放的动作,可以实现在屏幕上滑动的效果。
- 坐标计算:滑动操作通常涉及到起始点和终点的坐标计算,起始点表示滑动的起始位置,终点表示滑动的结束位置。这些坐标可以是相对于屏幕或特定元素的坐标。
- 惯性滑动:有些滑动操作在用户释放手指后还会继续滑动一段距离,模拟惯性滑动的效果,这通常需要在滑动过程中模拟逐渐减速的过程。
滑动的方式
swipe 方法
从一个点滑动到另一个点,可选择持续时间,具有滑动的惯性。需要的参数如下:
- start_x:开始坐标 x。
- start_y:开始坐标 y。
- end_x:结束坐标 x。
- end_y:结束坐标 y。
- duration(可选):滑动持续的时间,默认为 0。
Python 实现
def test_swipe_views(self):
# 从一个点滑动到另一个点,可选择持续时间
'''
start_x: 开始坐标 x
start_y: 开始坐标 y
end_x: 结束坐标 x
end_y: 结束坐标 y
duration: 持续时间
'''
# 点击进入 Views 界面
self.driver.find_element(AppiumBy.ACCESSIBILITY_ID, 'Views').click()
# 获取窗口的宽和高
height = self.driver.get_window_size().get('height')
weight = self.driver.get_window_size().get('width')
# 执行滑动操作
self.driver.swipe(start_x=weight * 0.5,
start_y=height * 0.8,
end_x=weight * 0.5,
end_y=height * 0.2, duration=2000)
ele = self.driver.find_element(AppiumBy.ACCESSIBILITY_ID, 'Picker')
# 断言滑动成功 找到元素
assert ele.text == 'Picker'
scroll 方法
从一个元素滑动到另一个元素,具有滑动的惯性。需要的参数如下:
- origin_el:滑动的起始元素。
- destination_el:滑动的结束元素。
Python 实现
def test_scroll_ele(self):
'''
从一个元素滑动到另一个元素
:return:
'''
# 点击进入 Views 界面
self.driver.find_element(AppiumBy.ACCESSIBILITY_ID, 'Views').click()
# 滑动起始元素
image_btn = self.driver.find_element(AppiumBy.ACCESSIBILITY_ID, 'ImageButton')
# 滑动结束元素
button = self.driver.find_element(AppiumBy.ACCESSIBILITY_ID, 'Buttons')
# 执行滑动操作
self.driver.scroll(image_btn, button, duration=2000)
list_ele = self.driver.find_element(AppiumBy.ACCESSIBILITY_ID, 'Picker')
assert list_ele.text == 'Picker'
总结
- 滑动操作的场景
- 使用 swip 方法滑动
- 使用 scroll 方法滑动