当前位置:   article > 正文

web自动化测试之Selenium基础_selenium web自动化基础知识

selenium web自动化基础知识

一、Selenium简介

1、定义:

Selenium是一款web应用的自动化测试工具,主要用于UI测试;

它的特点有如下几点:

1).支持多语言:java,python,ruby,PHP

2).多浏览器支持:IE、Chrome、Mozila-FireFox

3).开源,免费

4).多平台支持:windows、MAC、Linux

2、框架

框架(framework)是一个框子——指其约束性,也是一个架子——指其支撑性。是一个基本概念上的结构,用于去解决或者处理复杂的问题。          

框架是整个或部分系统的可重用设计,表现为一组抽象构件及构件实例间交互的方法;另一种定义认为,框架是可被应用开发者定制的应用骨架。前者是从应用方面而后者是从目的方面给出的定义。          

框架,其实就是某种应用的半成品,就是一组组件,供你选用完成你自己的系统。简单说就是使用别人搭好的舞台,你来做表演。

3、使用框架原因

1)自己从头实现太复杂   

 2)使用框架能够更专注于业务逻辑,加快开发速度     

3)框架的使用能够处理更多细节问题   

4)使用人数多,稳定性,扩展性好

4、Selenium工作原理

 

5、selenium环境搭建

1)python3.7     2)Firefox35(大于43)     3)selenium2框架         稳定版 2.48.0    (pip install selenium==2.48.0)   

 4)浏览器驱动                 chrome         ie

二、Selenium IDE

1、Selenium-IDE:Selenium的IDE(集成开发环境)是一个易于使用的Firefox插件,用于开发Selenium测试案例。它提供了一个图形用户界面,用于记录使用Firefox浏览器,用来学习和使用Selenium用户操作,但它只能用于只用Firefox浏览器不支持其它浏览器。

2、IDE功能简介

1).文件:创建、打开和保存测试案例和测试案例集。编辑:复制、粘贴、删除、撤销和选择测试案例中的所有命令。Options : 用于设置seleniunm IDE。

2).用来填写被测网站的地址。

3).速度控制:控制案例的运行速度。

4).运行所有:运行一个测试案例集中的所有案例。

5).运行:运行当前选定的测试案例。

6).暂停/恢复:暂停和恢复测试案例执行。

7).单步:可以运行一个案例中的一行命令。

8).录制:点击之后,开始记录你对浏览器的操作。

9).案例集列表。

10).测试脚本;table标签:用表格形式展现命令及参数。source标签:用原始方式展现,默认是HTML语言格式,也可以用其他语言展示。

11).查看脚本运行通过/失败的个数。

12).当选中前命令对应参数。

13).日志/参考/UI元素/Rollup

 

三、Selenium IDE使用基础

1.浏览器驱动对象          

1)库的导入         from selenium import  webdriver          

2)创建浏览器对象                  

driver = webdriver.xxx()                   使用dir(driver)查看方法   

案例:

  1. from selenium import webdriver
  2. driver=webdriver.Firefox()
  3. # 使用dir(driver)查看方法
  4. print(dir(driver))

 结果:

3)浏览器尺寸相关操作                

 maximize_window()        最大化                  

get_window_size()        获取浏览器尺寸         

set_window_size()        设置浏览器尺寸

案例:

  1. from selenium import webdriver
  2. driver=webdriver.Firefox()
  3. # 最大
  4. driver.maximize_window()
  5. # 获取界面尺寸
  6. print(driver.get_window_size())
  7. # 设置尺寸
  8. driver.set_window_size(200,100)
  9. print(driver.get_window_size())

结果:

 

 

4)浏览器位置相关操作                          

get_window_position()        获取浏览器位置         

set_window_position(x,y)        设置浏览器位置       

案例:

  1. from selenium import webdriver
  2. driver=webdriver.Firefox()
  3. url="https://www.baidu.com"
  4. driver.get(url)
  5. print(driver.get_window_position())
  6. driver.set_window_position(200,100)
  7. print(driver.get_window_position())

      结果:

 注:显示器以左上角为(0,0),所有的位置操作都是相对于显示器左上角展开的位移操作,单位是像素。   

5)浏览器的关闭操作            

     close()            关闭当前标签/窗口       

 quit()            关闭所有标签/窗口

6)页面请求操作                  

driver.get(url)        请求某个url对应的响应         

refresh()                刷新页面操作       

 back()                回退到之前的页面       

 forward()                前进到之后的页面

2、获取断言信息

定义:断言是编程术语,表示为一些布尔表达式,程序员相信在程序中的某个特定点该表达式值为真,可以在任何时候启用和禁用断言验证,因此可以在测试时启用断言而在部署时禁用断言。

获取断言信息的操作

current_url                获取当前访问页面url         

title                获取当前浏览器标题       

 get_screenshot_as_png()           保存图片         

get_screenshot_as_file(file)       直接保存                  

page_source                  网页源码

案例:

  1. from selenium import webdriver
  2. driver=webdriver.Firefox()
  3. url="https://www.baidu.com"
  4. driver.get(url)
  5. # 获取当前访问页面url
  6. print(driver.current_url)
  7. # 获取当前浏览器标题
  8. print(driver.title)
  9. #保存图片
  10. data=driver.get_screenshot_as_png()
  11. with open("123.png","wb")as f:
  12. f.write(data)

结果:

四、元素定位

1、元素定位方法的分类(调用方式):                  

1).直接调用型(推荐方式)             driver.find_element_by_xxx(value)                

 2).使用By类型(需要导入By)             from selenium.webdriver.common.by import By             driver.find_element(By.xxx,value)

2、元素定位方法的分类(按定位方式):

3、八种定位方式的示例:

案例1:driver.find_element_by_xpath(value)

  1. from selenium import webdriver
  2. from selenium.webdriver.common.by import By
  3. driver=webdriver.Firefox()
  4. url="https://www.baidu.com"
  5. driver.get(url)
  6. # xpath
  7. ss=driver.find_element_by_xpath("//*[@id='kw']")
  8. ss.send_keys("java")

  1. from selenium import webdriver
  2. from selenium.webdriver.common.by import By
  3. driver=webdriver.Firefox()
  4. url="https://www.baidu.com"
  5. driver.get(url)
  6. # xpath
  7. ss=driver.find_element(By.XPATH,"//*[@id='kw']")
  8. ss.send_keys("java")

结果:

案例2:driver.find_element_by_css_selector(value)

  1. from selenium import webdriver
  2. from selenium.webdriver.common.by import By
  3. driver=webdriver.Firefox()
  4. url="https://www.baidu.com"
  5. driver.get(url)
  6. # css
  7. ss=driver.find_element_by_css_selector("#kw")
  8. ss.send_keys("sql")

  1. from selenium import webdriver
  2. from selenium.webdriver.common.by import By
  3. driver=webdriver.Firefox()
  4. url="https://www.baidu.com"
  5. driver.get(url)
  6. # css
  7. ss=driver.find_element(By.CSS_SELECTOR,"#kw")
  8. ss.send_keys("sql")

结果:

案例3:driver.find_element_by_id(value)

  1. from selenium import webdriver
  2. driver=webdriver.Firefox()
  3. url="https://www.baidu.com"
  4. driver.get(url)
  5. # id
  6. ss=driver.find_element_by_id("kw")
  7. ss.send_keys("python")

或:

  1. from selenium import webdriver
  2. from selenium.webdriver.common.by import By
  3. driver=webdriver.Firefox()
  4. url="https://www.baidu.com"
  5. driver.get(url)
  6. # id
  7. ss=driver.find_element(By.ID,"kw")
  8. ss.send_keys("python")

结果:

案例4:driver.find_element_by_name(value)

  1. from selenium import webdriver
  2. from selenium.webdriver.common.by import By
  3. driver=webdriver.Firefox()
  4. url="https://www.baidu.com"
  5. driver.get(url)
  6. # name
  7. ss=driver.find_element_by_name("wd")
  8. ss.send_keys("html")

或:

  1. from selenium import webdriver
  2. from selenium.webdriver.common.by import By
  3. driver=webdriver.Firefox()
  4. url="https://www.baidu.com"
  5. driver.get(url)
  6. # name
  7. ss=driver.find_element(By.NAME,"wd")
  8. ss.send_keys("html")

结果:

案例5: driver.find_element_by_class_name(value)

  1. from selenium import webdriver
  2. from selenium.webdriver.common.by import By
  3. driver=webdriver.Firefox()
  4. url="https://www.baidu.com"
  5. driver.get(url)
  6. # 伪类名定位
  7. ss=driver.find_element_by_class_name("s_ipt")
  8. ss.send_keys("天天音乐")

  1. from selenium import webdriver
  2. from selenium.webdriver.common.by import By
  3. driver=webdriver.Firefox()
  4. url="https://www.baidu.com"
  5. driver.get(url)
  6. # 伪类名定位
  7. ss=driver.find_element(By.CLASS_NAME,"s_ipt")
  8. ss.send_keys("天天音乐")

结果:

案例6:driver.find_element_by_tag_name(value)

  1. from selenium import webdriver
  2. from selenium.webdriver.common.by import By
  3. driver=webdriver.Firefox()
  4. # url="https://www.baidu.com"
  5. # 必应搜索
  6. url="https://cn.bing.com/"
  7. driver.get(url)
  8. # 标签名定位
  9. ss=driver.find_element_by_tag_name("input")
  10. ss.send_keys("python")

  1. from selenium import webdriver
  2. from selenium.webdriver.common.by import By
  3. driver=webdriver.Firefox()
  4. # url="https://www.baidu.com"
  5. # 必应搜索
  6. url="https://cn.bing.com/"
  7. driver.get(url)
  8. # 标签名定位
  9. ss=driver.find_element(By.TAG_NAME,"input")
  10. ss.send_keys("python")

结果:

案例7:driver.find_element_by_link_text(value)

  1. from selenium import webdriver
  2. from selenium.webdriver.common.by import By
  3. driver=webdriver.Firefox()
  4. url="https://www.baidu.com"
  5. # 必应搜索
  6. # url="https://cn.bing.com/"
  7. driver.get(url)
  8. # 链接文本定位
  9. ss=driver.find_element_by_link_text("hao123")
  10. ss.click()

  1. from selenium import webdriver
  2. from selenium.webdriver.common.by import By
  3. driver=webdriver.Firefox()
  4. url="https://www.baidu.com"
  5. # 必应搜索
  6. # url="https://cn.bing.com/"
  7. driver.get(url)
  8. # 链接文本定位
  9. ss=driver.find_element(By.LINK_TEXT,"hao123")
  10. ss.click()

结果:

案例8:driver.find_element_by_partial_link_text(value)

  1. from selenium import webdriver
  2. from selenium.webdriver.common.by import By
  3. driver=webdriver.Firefox()
  4. url="https://www.baidu.com"
  5. # 必应搜索
  6. # url="https://cn.bing.com/"
  7. driver.get(url)
  8. # 部分链接文本
  9. ss=driver.find_element_by_partial_link_text("hao")
  10. ss.click()

或:

  1. from selenium import webdriver
  2. from selenium.webdriver.common.by import By
  3. driver=webdriver.Firefox()
  4. url="https://www.baidu.com"
  5. # 必应搜索
  6. # url="https://cn.bing.com/"
  7. driver.get(url)
  8. # 部分链接文本
  9. ss=driver.find_element(By.PARTIAL_LINK_TEXT,"123")
  10. ss.click()

结果:

五、元素的操作            

1、对元素的相关操作,一般要先获取到元素,再调用相关方法   

 element = driver.find_element_by_xxx(value)        

 2、点击和输入         

点击操作             element.click()                  

清空/输入操作(只能操作可以输入文本的元素)             

element.clear()           清空输入框             

element.send_keys(data)        输入数据         

 

 

声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号