多种方法实现Appium屏幕滑动:让用户仿真动作更简单
【摘要】 简介在移动端应用中,基于简便的原因,用户通常会倾向于使用滑动操作来达到与应用程序中的控件进行交互的,这使得滑动成为自动化测试中频繁使用的关键动作。在 Appium 中提供了多种方式来实现模拟用户的滑动屏幕动作。 滑动操作的场景移动端应用中的滑动场景,大致有如下几种类型:触摸事件模拟:滑动操作的基本原理是模拟用户触摸屏幕的行为。通过发送一系列的触摸事件,模拟用户按住、滑动和释放的动作,可以实...
简介
在移动端应用中,基于简便的原因,用户通常会倾向于使用滑动操作来达到与应用程序中的控件进行交互的,这使得滑动成为自动化测试中频繁使用的关键动作。在 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 方法滑动
【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)