Selenium UI自动化
1、安装
1、安装python3
2、下载selenium:pip install selenium == 3.12.0
3、下载Chrome:66.0.3359.139或Firefox
4、Firefox安装插件:地址栏输入about:addons;分别搜索Firebug和FirePath,并下载
浏览器驱动下载:https://www.seleniumhq.org/download/
chromedriver.exe
复制到python 安装目录~\Python37
HTMLTestRunner.py
复制到~\Python37\Lib
注意:文件名不能用 selenium
新建的名称叫selenium.py,导致Python会先导入这个文件,然后再导入标准库里面的selenium.py。
把当前目录下的文件删除或者重命名之后再run正常。
代码:
```
# coding:utf-8
from selenium import webdriver import time
```
1、设置浏览器的驱动
driver = webdriver.Chrome()
2、去掉Chrome浏览器顶部的“正在受到自动测试软件控制”:
option = webdriver.ChromeOptions() option.addargument('disable-infobars') driver = webdriver.Chrome(chromeoptions=option)
3、打开网址
driver.get("https://www.baidu.com/")
2、UI自动化操作
1、打开浏览器
设置浏览器的驱动
driver = webdriver.Chrome()
1、Chrome浏览器静默模式:不弹出浏览器
option = webdriver.ChromeOptions()
option.addargument('headless') driver = webdriver.Chrome(chromeoptions=option)
2、去掉Chrome浏览器顶部的“正在受到自动测试软件控制”:
option = webdriver.ChromeOptions()
option.addargument('disable-infobars') driver = webdriver.Chrome(chromeoptions=option)
driver = webdriver.Firefox()
2、进入论坛
driver.get("http:// ")
3、登录
1、找到账号和密码输入框
定位输入框的位置
定位元素
1、用id定位:findelementby_id()
2、用classname定位:findelement_byclassname()
3、用链接文本定位:findelementbylinktext()
4、用部分链接文本定位:findelementby_partiallinktext()
5、用标签名定位:findelementbytagname()---从没用过
6、最常用:findelementby_xpath()
7、findelementbycssselector()
定位一组对象
与定位单个对象类似,只是要把element换成elements,如:findelementsbyclassname()【最常用】
2、点击元素:.click()
3、输入账号和密码
文本框输入
1、清空输入框默认文本:.clear()
2、.send_keys("自动化测试")
4、点击登录
登陆后有弹窗,为了确定正确登录,需要断言
1、普通弹出框获取元素属性
1、文本:.text
2、元素尺寸:.size
3、获取其他属性如class:.findelementbyid().getattribute("class")
4、元素是否可见:findelementbyid().isdisplayed()
若元素可见返回True,否则返回False
2、页面弹出alert
alert = driver.switch_to.alert
查看alert中的文字
print alert.text
点击确定
alert.accept()
点击取消(如果有)
alert.dismiss()
3、获取当前网页信息
1、当前网页url:driver.current_url
2、网页标题:driver.title
4、页面跳转
1、如果在当前窗口跳转,则无需其他操作
2、新开窗口则需要切换窗口:点击某个元素以后会新开标签页,这时候需要切换窗口
allhandles = driver.windowhandles
currwindow = driver.currentwindowhandle for k in allhandles: if k != currwindow: driver.switchto.window(k)
5、点击下拉页面
页面上下拉,要用js
1、下拉指定高度
js = 'document.documentElement.scrollTop=1000;'
driver.execute_script(js)
顶部:0
底部:把值写大一点
2、用目标元素做参考去拖动下拉条
targetelement = driver.findelementbyid()
js = 'arguments[0].scrollIntoView();' driver.executescript(js, targetelement)
3、js操作补充
1、去掉新开标签页:target="_blank"属性
js = 'document.getElementsByClassName("")[0].target="";'
driver.execute_script(js)
2、去掉只读readonly属性
js = 'document.getElementById("").removeAttribute("readonly")'
driver.execute_script(js)
6、鼠标移动到发帖后会弹出发帖选项
鼠标操作
导入鼠标操作库:from selenium.webdriver.common.action_chains import ActionChains
1、右键单击:context_click()
2、双击:double_click()
3、拖动:draganddrop()
4、鼠标悬停:movetoelement()
5、按下左键不松手:clickandhold()
键盘事件
导入键盘操作库:from selenium.webdriver.common.keys import Keys
1、删除backspace键:findelementby_id().sendkeys(Keys.BACKSPACE)
2、Ctrl+a:.send_keys(Keys.CONTROL, 'a')
3、回车:.send_keys(Keys.ENTER)
7、输入帖子信息
1、定位iframe
iframe = driver.findelementby_xpath()
切换到iframe
driver.switch_to.frame(iframe) ...
跳出iframe
driver.switchto.defaultcontent()