自动化测试:Selenium的高级操作
Selenium-Switch_toswitch_to适用场景:
● 处理JS弹框
● 切换frame
● 切换浏览器窗口
Switch_to处理JS弹框
JavaScript简称JS,应用于HTML网页,通过操纵网页窗口及网页元素,从而实现动态效果。
▲ JS弹框类型:警告框alert、确认框confirm、提示框prompt
浏览器窗口中如果有JavaScript的弹出框,需要通过switch_to语句处理。
相关方法:
alert = driver.switch_to.alert # 切换焦点到弹框
alert.accept() # 对弹框点击确定按钮
alert.dismiss() # 对弹框点击取消
alert.text # 获取弹框文本内容
alert.send_keys(keysToSend) # 往弹框输入框输入内容Switch_to切换窗口
浏览器中有多个窗口时,如果想切换到其他窗口操作,需要调用switch_to方法
切换到目标窗口:
相关方法:
driver.switch_to.window(window_name) # 切换焦点到指定窗口
driver.current_window_handle #获取当前窗口的handle
driver.window_handles #获取当前浏览器所有窗口的handle
示例:
handels = driver.window_handles; // 获取当前浏览器所有窗口
for handle in handles:
driver.switch_to.window(handle)
if self.driver.title=="Python 基础教程 | 菜鸟教程":
breakSwitch_to切换frame
如果元素在html的frame或iframe中,则无法直接定位到元素。需要先切换到该frame中,再进行定位及其他操作。
相关方法:
driver.switch_to.frame(frame_reference); #参数为frame的id或name
driver.switch_to.frame(0); #按索引值切换frame
driver.switch_to.parent_frame(); #切换到上级frame
driver.switch_to.default_content(); #切换到默认内容ActionChains模拟鼠标操作
一般来说我们与页面的交互可以使用WebElement的方法来进行点击等操作。但是有时候我们需要一些更复杂的动作,就需要用到我们的Action Chains了。
通过action对象模拟鼠标操作,如双击,右击,拖拽,悬停等操作:
actions = ActionChains(driver);
action.click(on_element);// 鼠标左键点击指定的元素ele
action.click();// 鼠标左键点击当前元素
action.content_click();//右键点击
action.doubleClick(on_element); //双击ele元素
action.clickAndHold(on_element);// 鼠标点击不释放
action.moveToElement(on_element);//鼠标悬停
action.dragAndDrop(source,target);//鼠标拖拽操作
action.perform(); # 执行存储在任务列表中的操作
action.reset_actions() # 清除存储在任务列表中的操作普通键:
▲有名按键:
TAB 、ENTER、SPACE、BACKSPACE
F1~F12 、PAGE_UP/PAGE_DOWN 等等▲ 无名按键:a-z,0-9
如:输入:zhangsan_001修饰键:
修饰键单独使用没有意义,一般和别的按键配合使用。
ALT 、SHIFT、CONTROL
如:全选快捷键 control+a
<div> ▲ Actions操作:</div><div> action = ActionChains(driver);</div>
使用示例:
action.send_keys(*keys_to_send,Keys.ENTER ); #回车键提交
action.key_down(Keys.CONTROL,input).send_keys(“a”) # 复制
action.key_down(Keys.CONTROL).send_keys("c") # 复制
action.key_down(Keys.CONTROL,input).send_keys("v") # 粘贴输入大写或按键上方的字符:
action.key_down(element,Keys.SHIFT).send_keys("222").key_up(Keys.SHIFT).send_keys("222")
Selenium执行JS代码
JS,JavaScript的简称,广泛用于HTML网页,通过操纵网页窗口及网页元素,从而实现动态效果。
webdriver无法完成的操作,可以由JS配合完成。
示例:
driver.execute_script("return document.title"); //获取title
driver.execute_script("arguments.setAttribute('style',
arguments);",
element, "color: orange; border: 4px solid orange;") #设置橘色边框参考JS:
● 获取标题:document.title
● 弹出提示框:alert('我是一个弹框');
● 改变元素属性:q=document.getElementById('kw');q.style.display='block';
Selenium-JS处理滚动条
通过js实现滚动条拖动效果:
· 移动元素到窗口顶部:
driver.execute_script("arguments.scrollIntoView();", target);· 移动元素到窗口底部:
driver.execute_script("arguments.scrollIntoView(false);", target);· 窗口移动指定距离:
driver.execute_script("window.scrollBy(0, 300)");· 移动窗口到某位置:
driver.execute_script("window.scrollTo(200,0)");Selenium-文件上传
· input标签上传:借用input元素的sendkeys方法实现
示例:
driver.find_element_by_css_selector("#test")).sendKeys(filename);· 非input标签上传---借用其他工具如autoIt:
· 用于Windows GUI自动化操作
· 通过它可以组合使用模拟键击、鼠标移动和窗口/控件操作等来实现自动化任务。
· 它使用类似BASIC的脚本语言。
· 可以通过转换工具把脚本转换为exe文件
Selenium-验证码处理
应用程序从安全考虑,都在登录或某操作节点使用验证码。
验证码是一种区分用户是计算机还是人的公共全自动程序。
自动化时验证码处理方式:
· 去掉验证码
· 设置万能码
· 破解验证码
· 通过cookie跳过验证码登录
cookie的操作:
· get_cookie(name):先正常登录,获取登录后的cookie
· add_cookie(cookie_dict):把获取到的cookie添加到当前会话
· delete_all_cookies:删除所有cookie
Selenium-截图操作
代码执行过程中出错的话,可以在报出异常时检测,然后进行截图保存当时情况。
截图:
time1 = time.strftime("%Y%m%d%H%M%S")
driver.get_screenshot_as_file("d:\\pic"+time1+".png") # 截屏后保存为图片
driver.get_screenshot_as_png() # 获取当前截屏对应的二进制数据
driver.get_screenshot_as_base64() #获取当前截屏对应的base64编码字符串
页:
[1]