[自动化测试:实践01]:2:(4-1 )元素定位(selenium)在实际场景中的应用2

文章目录

零:实验要求

0 课程实践1-Katalon Recorder和元素定位

0 课程实践1-Katalon Recorder和元素定位

▶ 0 课程实践1-Katalon Recorder和元素定位

实践任务

1 KR数据驱动的自动测试案例1

2 KR数据驱动的自动测试案例2

3-1 元素定位在实际场景中的应用1

3-2 元素定位在实际场景中的应用1-参考代码 (学生端看操作视频和回放)

4-1 元素定位在实际场景中的应用2

4-2 元素定位在实际场景中的应用2-参考代码(学生端看操作视频和回放)

提交2份作业

复制代码
提交作业1:实践任务1和2中任选一个。
提交作业2:实践任务3和4中任选一个。

▶ 0 课程实践1-Katalon Recorder和元素定位

一. KR数据驱动的自动测试案例2

0:实践目的:熟悉元素定位的基本用法。

实践目的

熟悉元素定位的基本用法。

结合ActionChains实现网页上的鼠标自动操作测试。

1:Selenium实验环境构建

实验环境构建

参考第一讲讲义和自动化测试开发实验环境配置指南.MP4视频

打开Pycharm,新建python文件training1-4.py编程实现如下功能。

打开测试网页:http://www.runoob.com/try/try.php?filename=jqueryui-api-droppable。

定位到需要拖拽物体的Frame:iframeResult。

使用元素定位拖拽源和拖拽源目标。

构建ActionChains实现拖拽动作。

2:具体代码实现

python 复制代码
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.common.action_chains import ActionChains

browser = webdriver.Firefox()
url = "http://www.runoob.com/try/try.php?filename=jqueryui-api-droppable"
browser.get(url)
browser.switch_to.frame('iframeResult')
source = browser.find_element(By.CSS_SELECTOR, '#draggble')
target = browser.find_element(By.CSS_SELECTOR, '#droppable')
actions = ActionChains(browser)
actions.drag_and_drop(source, target)
actions.perform()

二:补充知识:ActionChains简单介绍及使用

复制代码
目的
    ActionChains:执行PC端的鼠标点击、双击、右键、拖拽等事件
执行原理
    调用ActionChains的方法时,不会立即执行,而是将所有的操作,按顺序存放在一个队列里,当你调用perform()方法时,队列中的事件会依次执行
基本用法
    生成一个动作 action = ActionChains(driver)
    动作添加方法1 :action.方法1
    动作添加方法2 :action.方法2
    调用perform()方法执行:(action.perform())
具体写法
    链式写法:ActionChains(driver).move_to_element(element).click(element).perform()
    分布写法:
        action = ActionChains(driver)
        action.move_to_element(element)
        action.click(element)
        action.perform()
ActionChains方法列表
    click(on_element=None) ------单击鼠标左键
    click_and_hold(on_element=None) ------点击鼠标左键,不松开
    context_click(on_element=None) ------点击鼠标右键
    double_click(on_element=None) ------双击鼠标左键
    drag_and_drop(source, target) ------拖拽到某个元素然后松开
    drag_and_drop_by_offset(source, xoffset, yoffset) ------拖拽到某个坐标然后松开
    key_down(value, element=None) ------按下某个键盘上的键
    key_up(value, element=None) ------松开某个键
    move_by_offset(xoffset, yoffset) ------鼠标从当前位置移动到某个坐标
    move_to_element(to_element) ------鼠标移动到某个元素
    move_to_element_with_offset(to_element, xoffset, yoffset) ------移动到距某个元素(左上角坐标)多少距离的位置
    perform() ------执行链中的所有动作
    release(on_element=None) ------在某个元素位置松开鼠标左键
    send_keys(*keys_to_send) ------发送某个键到当前焦点的元素
    send_keys_to_element(element, *keys_to_send) ------发送某个键到指定元素
相关推荐
yuanpan9 小时前
Python + PyAutoGUI 实战:Windows 自动化办公脚本开发入门
windows·python·自动化
m0_609160499 小时前
MySQL如何限制触发器递归调用的深度_防止触发器死循环方法
jvm·数据库·python
zhonghaoxincekj9 小时前
轴距可调式元器件双边无损成形钳
经验分享·科技·深度学习·学习·测试工具·创业创新·制造
zjy277779 小时前
Golang bcrypt如何加密密码_Golang密码加密教程【收藏】
jvm·数据库·python
老纪10 小时前
Redis怎样利用Lua为多个Key同步续期
jvm·数据库·python
2403_8832610910 小时前
C#怎么计算两个日期的差值_C#如何处理时间跨度【笔记】
jvm·数据库·python
m0_7406532210 小时前
Golang切片底层原理是怎样的_Golang切片实现原理教程【简明】
jvm·数据库·python
yexuhgu10 小时前
CSS如何处理CSS逻辑属性兼容性_通过PostCSS转译为物理属性
jvm·数据库·python
m0_6245785910 小时前
CSS如何给Bootstrap背景添加半透明层_使用rgba颜色模式与定位
jvm·数据库·python
m0_4708576410 小时前
CSS如何实现等宽表格布局_利用table-layout与盒模型
jvm·数据库·python