lsekfe 发表于 2022-4-28 10:26:37

自动化测试:Selenium的高级操作

Selenium-Switch_to
  switch_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]
查看完整版本: 自动化测试:Selenium的高级操作