多测师是一家拥有先进的教学理念,强大的师资团队,业内好评甚多的接口自动化测试培训机构!

17727591462

联系电话

您现在所在位置:接口自动化测试培训 > 新闻资讯

Web端的测试Selenium用法必备-自动化测试

更新时间:2022-03-28 09:17:05 作者:多测师 浏览:250

  大家都知道,基于Web端的测试的基础框架是需要Selenium做主要支撑的,这里边给大家介绍下Web测试核心之基于 Python 的 Selenium。

Web端的测试Selenium用法必备-自动化测试

  一、简单介绍

  Selenium 是用于测试 Web 应用程序用户界面 (UI) 的常用框架。它是一款用于运行端到端功能测试的超强工具。您可以使用多个编程语言编写测试,并且 Selenium 能够在一个或多个浏览器中执行这些测试。

  二、环境安装

  安装 python,这个。。。忽略,建议 python2.7。

  安装基于 python 的 selenium 依赖包,命令:pip install selenium==2.53.6,你懂的。

  安装浏览器驱动包,推荐使用 chrome 浏览器的 chromedriver.exe,对应 chrome 版本一定要对哦,不然运行不起来的,安装在哪?想放哪放哪,不过一般是放在 python 的根目录下。下载地址:chromedriver.storage.googleapis.com/index.html

  安装 PyCharm 2.7 左右版本,这个无脑安装~然后可自定义界面 UI 及编码风格,这个。。。忽略

  三、牛刀小试

  1. 控制浏览器

  #coding=utf-8

  from selenium import webdriver

  driver = webdriver.Chrome()

  driver.get("http://www.baidu.com")

  driver.maximize_window() #将浏览器最大化显示

  driver.set_window_size(480, 800) #设置浏览器宽480、高800显示"

  driver.back() #后退

  driver.forward() #前进

  driver.close() #关闭chrome

  driver.quit() # 退出chrome

  2. 对象的定位

  通过 id 定位:find_element_by_id()

  通过 name 定位:find_element_by_name()

  通过 class 定位:find_element_by_class_name()

  通过 tag 定位:find_element_by_tag_name()

  通过 link 定位:find_element_by_link_text()

  通过 partial_link 定位:find_element_by_partial_link_text()

  通过 xpath 定位:find_element_by_xpath()

  通过 css 定位:find_element_by_css_selector()

  以上几种定位是常规操作,应该就基本够用了,但是有的时候就是会出现一些诡异的定位失效或者定位到了点击失效的问题,这个时候如果用js进行直接执行该事件,接下来介绍下非常规操作:

  id 定位:document.getElementById()

  name 定位:document.getElementsByName()

  tag 定位:document.getElementsByTagName()

  class 定位:document.getElementsByClassName()

  css 定位:document.querySelectorAll()

  search_js = "document.getElementsByName('wd')[0].value='selenium';"# 通过name定位,然后赋值“selenium”

  search_js2 = "document.querySelectorAll('.s_ipt')[0].value='selenium';"# 通过css定位,然后赋值“selenium”

  button_js = "document.getElementById('su').click();"# 通过id定位,然后执行单击操作

  button_js2 = "document.getElementsByClassName('s_btn')[0].click()"# 通过className定位,然后执行单击操作 driver.execute_script(search_js2)#执行,execute_script(script, *args)

  以上几种定位是可以再度升级,可以利用 jQuery 定位一波,这里可参看之前总结的 JQ 选择器中的思维导图知识点(www.cnblogs.com/aoaoao/arti… JS,便忽略

  3. 操作测试对象

  #coding=utf-8

  from selenium import webdriver

  driver = webdriver.Chrome()

  driver.get("http://passport.kuaibo.com/login/")

  driver.find_element_by_id("user_name").clear() #清除输入框的默认内容

  driver.find_element_by_id("user_name").send_keys("username")

  driver.find_element_by_id("user_pwd").clear()

  driver.find_element_by_id("user_pwd").send_keys("password") #输入输入框的内容为“password”

  driver.find_element_by_id("dl_an_submit").click() #通过 submit() 来提交操作

  driver.find_element_by_id("dl_an_submit").submit()

  size=driver.find_element_by_id("kw").size #返回百度输入框的宽高 text=driver.find_element_by_id("cp").text #返回百度页面底部备案信息

  #返回元素的属性值,可以是 id、name、type 或元素拥有的其它任意属性

  attribute=driver.find_element_by_id("kw").get_attribute('type') #返回元素的结果是否可见,返回结果为 True 或 False

  result=driver.find_element_by_id("kw").is_displayed()

  driver.quit() #退出

  4. 鼠标键盘事件

  from selenium import webdriver #引入 Keys 类包

  from selenium.webdriver.common.keys import Keys #引入 ActionChains 类

  from selenium.webdriver.common.action_chains import ActionChains

  ... #鼠标事件 #定位到要操作的元素

  right =driver.find_element_by_xpath("xx") #对定位到的元素执行鼠标右键操作

  ActionChains(driver).context_click(right).perform() #对定位到的元素执行鼠标双击操作

  ActionChains(driver).double_click(right).perform() #对定位到的元素执行鼠标移动到上面的操作

  ActionChains(driver).move_to_element(right).perform() #对定位到的元素执行鼠标左键按下的操作

  ActionChains(driver).click_and_hold(right).perform() #定位元素的原位置

  element = driver.find_element_by_name("xxx") #定位元素要移动到的目标位置

  target = driver.find_element_by_name("xxx") #执行元素的移动操作

  ActionChains(driver).drag_and_drop(element, target).perform() #键盘事件 #删除多输入的一个 值

  driver.find_element_by_id("kw").send_keys(Keys.BACK_SPACE) #输入空格键+“教程”

  driver.find_element_by_id("kw").send_keys(Keys.SPACE)

  driver.find_element_by_id("kw").send_keys(u"教程") #ctrl+x 剪切输入框内容

  driver.find_element_by_id("kw").send_keys(Keys.CONTROL,'x') #其余的键盘操作类似

  5. 等待时间

  #coding=utf-8

  from selenium import webdriver #导入 WebDriverWait 包

  from selenium.webdriver.support.ui import WebDriverWait

  from selenium.webdriver.support import expected_conditions as EC #导入 time 包

  import time

  driver = webdriver.Chrome()

  driver.get("http://www.baidu.com") #WebDriverWait()方法使用,显示等待,WebDriverWait(driver,超时时长,调用频率,忽略异常).until(可执行方法,超时返回的信息),这里可以调用EC来实现可执行方法

  is_disappeared = WebDriverWait(driver, 30, 1, (ElementNotVisibleException)).until_not(lambda x: x.find_element_by_id(“kw”).is_displayed()) #until(method, message=’ ’),调用该方法提供的驱动程序作为一个参数,直到返回值不为 False

  element.send_keys("selenium") #添加智能等待,隐时等待

  driver.implicitly_wait(30)

  driver.find_element_by_id("su").click() #添加固定休眠时间,强制等待

  time.sleep(5)

  driver.quit()

  6. 组对象定位及层级定位,呃,忽略

  7. 多窗口处理

  #coding=utf-8

  from selenium import webdriver import time

  driver = webdriver.Chrome()

  driver.get("http://www.baidu.com/") #获得当前窗口

  nowhandle=driver.current_window_handle #打开注册新窗口

  driver.find_element_by_name("tj_reg").click()

  allhandles=driver.window_handles #循环判断窗口是否为当前窗口

  for handle in allhandles: if handle != nowhandle:

  driver.switch_to_window(handle) print 'now register window!'

  #切换到邮箱注册标签

  driver.find_element_by_id("mailRegTab").click()

  time.sleep(5)

  driver.close() #回到原先的窗口

  driver.switch_to_window(nowhandle)

  driver.find_element_by_id("kw").send_keys(u"注册成功!")

  time.sleep(3) #ifrome处理 #这里会自动识别id,name,如果没有则可以将元素通过选择器找到,然后输入该元素即可

  driver.switch_to_frame("f1")

  element = driver.find_element_by_id("kw")

  driver.switch_to_frame(element)

  driver.quit() 

  8. 提示窗口处理

  #coding=utf-8

  from selenium import webdriver import time

  driver = webdriver.Chrome()

  driver.get("http://www.baidu.com/") #点击打开搜索设置

  driver.find_element_by_name("tj_setting").click()

  driver.find_element_by_id("SL_1").click() #点击保存设置

  driver.find_element_by_xpath("//div[@id='gxszButton']/input").click() #获取网页上的警告信息

  alert=driver.switch_to_alert() #接收警告信息

  alert.accept() #取消对话框(如果有的话)

  alert.dismiss() #输入值(如果有的话)

  alert.send_keys(“xxx”)

  9. 控制浏览器滚动条,这个运用之前提示的jq语句即可实现

  10. cookie处理,主要用途在于处理验证码问题

  #coding=utf-8

  from selenium import webdriver import time

  driver = webdriver.Chrome()

  driver.get("http://www.youdao.com") #向 cookie 的 name 和 value 添加会话信息。

  driver.add_cookie({'name':'key-aaaaaaa', 'value':'value-bbbb'}) #遍历 cookies 中的 name 和 value 信息打印,当然还有上面添加的信息

  for cookie in driver.get_cookies(): print "%s -> %s" % (cookie['name'], cookie['value']) ##### 下面可以通过两种方式删除 cookie ##### # 删除一个特定的 cookie

  driver.delete_cookie("CookieName") # 删除所有 cookie

  driver.delete_all_cookies()

  time.sleep(2)

  driver.close()

  以上内容为大家介绍了自动化测试中的Web端的测试Selenium用法必备,本文由多测师亲自撰写,希望对大家有所帮助。了解更多自动化测试相关知识:https://www.aichudan.com/xwzx/

联系电话

17727591462

返回顶部