python+selenium做ui自动化测试用法必会
一、前言
大家都知道,基于Web端的测试的基础框架是需要Selenium做主要支撑的,这里边给大家介绍下Web测试核心之基于 Python 的 Selenium
Selenium 是用于测试 Web 应用程序用户界面 (UI) 的常用框架。它是一款用于运行端到端功能测试的超强工具。您可以使用多个编程语言编写测试,并且 Selenium 能够在一个或多个浏览器中执行这些测试。
二、环境安装
-
安装 python,这个。。。忽略,建议 python3.7。
-
安装基于 python 的 selenium 依赖包,命令:
pip install selenium
-
安装浏览器驱动包,推荐使用 chrome 浏览器的
chromedriver.exe
,对应 chrome 版本一定要对哦,不然运行不起来的,安装在哪?想放哪放哪,不过一般是放在 python 的根目录下。下载地址:chromedriver.storage.googleapis.com/index.html -
安装 PyCharm ,这个无脑安装~然后可自定义界面 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 如果你对软件测试、接口测试、自动化测试、面试经验交流感兴趣欢迎加入:软件测试技术群:603401995,群里的免费资料都是笔者十多年测试生涯的精华。还有同行大神一起交流技术哦。
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 定位一波
3. 操作测试对象
4. 鼠标键盘事件
5. 等待时间
6. 组对象定位及层级定位,呃,忽略
7. 多窗口处理
8. 提示窗口处理
9. 控制浏览器滚动条,这个运用之前提示的jq语句即可实现
10. cookie处理,主要用途在于处理验证码问题
四、小结
如果你对软件测试、接口测试、自动化测试、面试经验交流感兴趣欢迎加入:软件测试技术群:603401995,群里的免费资料都是笔者十多年测试生涯的精华。还有同行大神一起交流技术哦。
在熟悉了selenium常见的API基本操作后,这里便可以开展实际测试用例的设计了,一个良好的自动化测试用例起码符合一下五个条件:
1、一个脚本是一个完整的场景,从用户登陆操作到用户退出系统关闭浏览器。
2、一个脚本脚本只验证一个功能点,不要试图用户登陆系统后把所有的功能都进行验证再退出系统
3、尽量只做功能中正向逻辑的验证,不要考虑太多逆向逻辑的验证,逆向逻辑的情况很多(例如手 号输错有很多种情况),验证一方面比较复杂,需要编写大量的脚本,另一方面自动化脚本本身比较脆弱, 很多非正常的逻辑的验证能力不强。(我们尽量遵循用户正常使用原则编写脚本即可)
4、脚本之间不要产生关联性,也就是说编写的每一个脚本都是独立的,不能依赖或影响其他脚本。
5、如果对数据进行了修改,需要对数据进行还原。 6、在整个脚本中只对验证点进行验证,不要对整个脚本每一步都做验证。
最后配合unittest或者testNG单元测试框架,实现分层、数据驱动、断言、截图、日志等全方位功能,得心应手的开展自动化测试工作。