Python+Selenium UI自动化测试环境搭建及使用

什么是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定位元素

1.通过id属性定位元素

文本框:

find_element_by_css_selector("#kw")

  按钮:find_element_by_css_selector("#su")

       2.通过class属性定位元素

  文本框:

find_element_by_css_selector(".s_ipt")

  按钮:find_element_by_css_selector(".bg s_btn")

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

  文本框:

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()元素是否可见

  鼠标、键盘事件

  模拟鼠标右键、双击、悬停、拖拽等操作,会用到ActionChains类。

  selenium.webdriver.common.action_chains.ActionChains(driver)当调用ActionChains的方法时,不会立即执行,而是会将所有的操作按顺序存放在一个队列里,当你调用perform()方法时,队列中的时间会依次执行。

  ActionChains方法列表:

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) ——发送某个键到指定元素

设置等待时间

  • 显示等待:主要使用的类和方法:WebDriverWait、uitil\until_not、Expected Conditions。

  • 隐式等待: implicitly_wait

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

猜你喜欢

转载自www.cnblogs.com/chenlimei/p/10456693.html