python+selenium UI自动化测试环境搭建及使用

638 阅读5分钟

一、什么是Selenium ?

Selenium 是一个浏览器自动化测试框架,它主要用于web应用程序的自动化测试,其主要特点如下:开源、免费;多平台、浏览器、多语言支持;对web页面有良好的支持;API简单灵活易于使用;支持分布式测试用例执行。 Selenium经历了两个版本,Selenium1.0和2.0,Selenium1.0主要由以下几部分构成:

  • Selenium IDE:是一个嵌入到Firefox中的插件,可以实现浏览器的录制于回放功能。

  • Selenium Grid:自动化测试辅助工具,可以很方便地同时在多台机器上并行运行多个测试事例。

  • Selenium RC:是Selenium的核心工具,支持多种不同的语言编写的测试脚本,通过Selenium RC的服务器作为代理服务器去访问应用从而达到测试的目的。主要分为以下两部分:

    1. Client:用来编写测试脚本来控制Selenium server的库。
    2. Server:负责控制浏览器的行为,包含三部分:Launcher;HttpProxy;Core。

明白了Selenium1.0的家族关系,Selenium2.0可以简单的认为是将WebDriver加入到了Selenium RC这一部分中去。那么Selenium RC和WebDriver有什么区别呢? RC和 WebDriver 类似,都可以看做是一套操作web页面的规范。当然,他们的工作原理不一样。

  • Selenium RC 在浏览器中运行 JavaScript 应用,使用浏览器内置的 JavaScript 翻译器来翻译和执行selenese 命令(Selenium 命令集合) 。
  • WebDriver 通过原生浏览器支持或者浏览器扩展直接控制浏览器。WebDriver 针对各个浏览器而开发,取代了嵌入到被测 Web 应用中的 JavaScript。与浏览器的紧密集成支持创建更高级的测试,避免了JavaScript 安全模型导致的限制。除了来自浏览器厂商的支持,WebDriver 还利用操作系统级的调用模拟用户输入。

二、Selenium环境搭建

  1. 安装python

    python的安装此处就不细说,去python官网下载地址,下载对应的python版本安装,注意环境变量的配置。

  2. 安装Selenium

    使用pip 命令安装 selenium pip install selenium , Mac电脑 安装过python3 使用pip3 install selenium 来安装。

  3. 安装浏览器驱动 使用chrome浏览器,需要下载对应版本的chromedriver 下载地址

  4. 安装上述工具后,可以测试下环境是否正常,使用以下这段代码

# -*- coding:utf-8 -*-
from selenium import webdriver
driver = webdriver.Chrome()
driver.get("http://baidu.com")
driver.close()

浏览器能正常打开百度,那么环境安装是正常的

三、WebDriver API

  1. 定位元素
  • 通过id属性来定位元素(id属性在html文档中必须具有唯一性)

    find_element_by_id()方法

  • 通过name属性来定位元素(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定位元素,和link类似,只不过是部分文本信息来进行定位

    find_element_by_partial_link_text()方法

  • find_element_by_xpath()方法

绝对路径来定位:find_element_by_xpath('/html/body/.........')

文本框:find_element_by_xpath("/html/body/div[2]/div[1]/div/div[1]/div/form/span[1]/input")

  • 通过CSS定位元素

    • 通过id属性定位元素

    文本框:find_element_by_css_selector("#kw")

    按钮:find_element_by_css_selector("#su")

    • 通过class属性定位元素

    文本框:find_element_by_css_selector(".s_ipt")

    按钮:find_element_by_css_selector(".bg s_btn")

    • 通过其他属性值来定位元素

    文本框:

    find_element_by_css_selector("[name = 'wd']")

    find_element_by_css_selector("[maxlength = 255]")

    find_element_by_css_selector("[autocomplete = 'off']")

  1. 控制浏览器

    控制浏览器窗口大小:

    driver=webdriver.Firefox()
    #设置窗口大小为x,y
    driver.set_window_size(x,y) 
    #最大化窗口
    driver.maxmize_window() 
    
    
  2. 元素操作

当我们获取了元素之后,还要对其进行操作,如点击按钮、输入文字、提交表单等。大多数页面交互的方法通过WebElement接口提供,常用的有:

  • clear() 清除文本框中的文本
  • send_keys(*value) 模拟按键输入
  • click() 单击元素 这几个方法很简单,很方便使用。 submit() 用于提交表单,例如搜索框中的提交按钮。比如我们可以用如下代码直接输入搜索的关键字后用submit()提交,而不用获取搜索按钮再点击。

driver.find_element_by_css_selector("#kw").send_keys("selenium2").submit()

还有几个常用的方法:

  • size() 获取元素的大小尺寸
  • text()获取元素的文本
  • is_displayed()元素是否可见
  1. 鼠标、键盘事件

模拟鼠标右键、双击、悬停、拖拽等操作,会用到ActionChains类。selenium.webdriver.common.action_chains.ActionChains(driver)当调用ActionChains的方法时,不会立即执行,而是会将所有的操作按顺序存放在一个队列里,当你调用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) ——发送某个键到指定元素
  1. 设置等待时间
  • 显示等待: - 主要使用的类和方法:WebDriverWait、uitil\until_not、Expected Conditions。

  • 隐式等待: - implicitly_wait

  1. 其他操作 还有其他一些操作如:上传下载文件、操作cookie、验证码的处理等等操作还没有用到过,用到的时候再去学习就好了。 熟练使用以上的各部分,可以写出各种常用的脚本,我们算是入门Selenium了