2021-04-09 Selenium与页面的交互

  1. WebDriver浏览器的属性

WebDriver 提供了很多属性来支持对浏览器的操作,例如,获取测试地址、多窗口的处理、获取浏览器名称等,具体介绍如下

1.1 获取测试的地址
获取测试的地址用到的方法是current_url,也就是获取当前测试的具体URL。以百度首页为例,获取的地址就是百度首页的地址,实现的测试代码如下:

from selenium import webdriver
driver=webdriver.Firefox()
driver.maximize_window()
driver.get('https://wwww.baidu.com/')
driver.implicitly_wait(30)
print('测试地址为:{0}'.format(driver.current_url))
driver.quit()

显示:

D:\python3\python.exe C:/Users/Administrator/Desktop/testpy/baidu.py
测试地址为:https://www.baidu.com/
Process finished with exit code 0



1.2 获取当前页面代码
获取当前测试页面的代码用到的方法是 page_source。以百度首页为例,要想获取百度首页的页面代码,实现的代码如下

from selenium import webdriver
driver=webdriver.Firefox()
driver.maximize_window()
driver.get('https://wwww.baidu.com/')
driver.implicitly_wait(30)
print('页面代码如下:{0}'.format(driver.page_source))
driver.quit()

显示:

D:\python3\python.exe C:/Users/Administrator/Desktop/testpy/baidu.py
页面代码如下:<html><head><script type="text/javascript" charset="utf-8" src="https://dss0.bdstatic.com/5aV1bjqh_Q23odCf/static/superman/js/components/qrcode-7c53a95a4e.js"></script><script type="text/javascript" charset="utf-8"
...(此处省略1万字...)
Process finished with exit code 0



1.3 获取当前的Title
获取当前的Title,即获取当前测试页面的标题。例如,百度首页的Title 是“百度一下,你就知道”。获取Title的测试代码为:

from selenium import webdriver
driver=webdriver.Firefox()
driver.maximize_window()
driver.get('https://wwww.baidu.com/')
driver.implicitly_wait(30)
print('百度首页的Title为:{0}'.format(driver.title))
driver.quit()

显示:

D:\python3\python.exe C:/Users/Administrator/Desktop/testpy/baidu.py
百度首页的Title为:百度一下,你就知道
Process finished with exit code 0



1.4 页面的前进和后退
前进用到的方法是forward,后退用到的方法是back。以百度首页搜索首页为例,要实现先打开百度首页,再搜索python,点击,再后退到百度首页,然后再搜索python,点击。实现的测试代码为:

from selenium import webdriver
import time
driver=webdriver.Firefox()
driver.maximize_window()
driver.get('https://wwww.baidu.com/')
print('测试地址为:{0}'.format(driver.current_url))
driver.find_element_by_id("kw").send_keys("python")
driver.find_element_by_id("su").click()
time.sleep(2)
print('测试地址为:{0}'.format(driver.current_url))
driver.back()
print('测试地址为:{0}'.format(driver.current_url))
time.sleep(2)
driver.forward()
print('测试地址为:{0}'.format(driver.current_url))
driver.quit()

D:\python3\python.exe C:/Users/Administrator/Desktop/testpy/baidu.py
测试地址为:https://www.baidu.com/
测试地址为:https://www.baidu.com/s?ie=utf-8&f=8&rsv_bp=1&rsv_idx=1&tn=baidu&wd=python&fenlei=256&rsv_pq=dec74e9600001e47&rsv_t=8f2d4SuWy%2FMiUdZ4C5d%2FHMJONsHAi2WHUU4CBacxV95sOc%2FiN8f0Tr%2B9xvU&rqlang=cn&rsv_dl=tb&rsv_enter=0&rsv_sug3=6&rsv_btype=i&inputT=182&rsv_sug4=182
测试地址为:https://www.baidu.com/
测试地址为:https://www.baidu.com/s?ie=utf-8&f=8&rsv_bp=1&rsv_idx=1&tn=baidu&wd=python&fenlei=256&rsv_pq=dec74e9600001e47&rsv_t=8f2d4SuWy%2FMiUdZ4C5d%2FHMJONsHAi2WHUU4CBacxV95sOc%2FiN8f0Tr%2B9xvU&rqlang=cn&rsv_dl=tb&rsv_enter=0&rsv_sug3=6&rsv_btype=i&inputT=182&rsv_sug4=182
Process finished with exit code 0



1.5 关闭程序
在Selenium中,quit 方法用来退出驱动程序(Driver)并关闭执行的浏览器;而close方法用来关闭执行的浏览器,所以关闭程序建议使用quit方法。


1.6 加载测试地址
在UI自动化测试中,打开测试地址用到的方法是get方法,它的参数是要打开的测试页面的地址。例如,要测试打开新浪邮箱的地址(https://mail.sina.com.cn/),测试代码如下:

from selenium import webdriver
driver=webdriver.Firefox()
driver.maximize_window()
driver.get('https://mail.sina.com.cn/')
driver.implicitly_wait(30)
driver.quit()



1.7 多窗口实战
在新浪邮箱的登录页面(简称新浪登录页面,或登录页面)点击“注册”按钮,如何在打开的注册页面输入框中输入注册信息呢?这里会用到窗口处理的方法。current_window_handle用来获取当前浏览器的窗口句柄,window_handles用来获取浏览器的所有窗口句柄。要实现在新浪登录页面点击注册,在注册页面邮箱地址输入框中输入邮箱地址,再次跳转到登录页面,代码如下:

from selenium import webdriver
import time
driver=webdriver.Firefox()
driver.maximize_window()
driver.get('https://mail.sina.com.cn/')
driver.implicitly_wait(30)
#获取当前窗口句柄
now_handle=driver.current_window_handle
time.sleep(2)
print("当前窗口句柄:",now_handle)
#点击注册链接
driver.find_element_by_link_text("注册").click()
time.sleep(2)
#获取所有窗口句柄
handles=driver.window_handles
print("所有窗口句柄:",handles)
for handle in handles:
   #判断hand不是当前窗口句柄
   if handle !=now_handle:
       driver.switch_to.window(handle)
       time.sleep(2)
       driver.find_element_by_name("email").send_keys('hcc')#在mail注册框框中输入hcc
       time.sleep(2)
       #关闭注册页面
       driver.close()
#切换到登录页面
driver.switch_to.window(now_handle)
time.sleep(3)
#在账号输入框输入邮箱
driver.find_element_by_id('freename').send_keys('hcc')
time.sleep(4)
driver.quit()

D:\python3\python.exe C:/Users/Administrator/Desktop/testpy/baidu.py
当前窗口句柄: 15
所有窗口句柄: ['15', '35']
Process finished with exit code 0



1.8 浏览器最大化
使浏览器最大化的方法是 maximize_window。一般打开浏览器时,界面并不是最大化的,这对 UI 自动化测试的影响比较大,所以建议在打开浏览器后,调用该方法让浏览器最大化,实现的测试代码如下:

driver.maximize_window()



1.9 刷新
刷新用到的方法是refresh方法。在UI自动化测试中,某些场景需要用到页面的刷新。例如,打开百度首页后,输入搜索关键字,然后刷新页面查看效果,实现的代码如下:

from selenium import webdriver
import time
driver=webdriver.Firefox()
#浏览器最大化
driver.maximize_window()
driver.get('https://wwww.baidu.com/')
driver.implicitly_wait(30)
driver.find_element_by_id("kw").send_keys('selenium')
time.sleep(2)
#对页面进行刷新
driver.refresh()
time.sleep(3)
driver.quit()



1.10 获取执行的浏览器
获取执行的浏览器名称用到的是name方法,实现的代码如下:

from selenium import webdriver
driver=webdriver.Firefox()
driver.maximize_window()
driver.get('https://wwww.baidu.com/')
driver.implicitly_wait(30)
print('测试执行的浏览器为:{0}'.format(driver.name))
driver.quit()

D:\python3\python.exe C:/Users/Administrator/Desktop/testpy/baidu.py
测试执行的浏览器为:firefox
Process finished with exit code 0


  1. WebElement类的方法

WebElement 类中有很多方法可以应用在UI 自动化测试中。例如,get_attribute方法用以获取输入框中的Value值,is_enabled方法用来判断文本是否可编辑。下面具体介绍这些方法在UI自动化测试中的应用。

2.1 清空
在Selenium 中,实现清空用到的方法是 clear。例如,在百度搜索输入框中输入搜索关键字 Selenium,然后再调用 clear 方法清空输入的关键字

2.2 获取元素属性值
get_attribute 方法可用来获取元素属性的值。在测试中,经常需要获取输入框中的值,或者获取输入框中的提示信息,仍以新浪邮箱的登录页页为例,实现的代码如下

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<center>
    <div>
        <p>
            用户名: <input type="text" name="username" placeholder="请输入用户名">
        </p>
        <p>
            密码: <input type="password" placeholder="请输入密码" >
        </p>
    </div>
</center>
</body>
</html>

实际显示:


image.png

接下来测试用户名输入框是否显示“请输入用户名”的提示信息。“请输入用户名”的元素属性是placeholder,实现的代码如下:

from selenium import webdriver
import time
driver=webdriver.Firefox()
driver.maximize_window()
driver.get('file:///E:/test01/attribute.html')
name=driver.find_element_by_name("username")
print('用户名输入框中提示信息为:{0}'.format(name.get_attribute('placeholder')))
time.sleep(2)
driver.quit()

E:\test01\venv\Scripts\python.exe E:/test01/sel.py
用户名输入框中提示信息为:请输入用户名

在输入框中输入的值一般都在Value属性中,例如,在百度搜索输入框中输入的搜索关键字存放在百度搜索 input的Value属性中。要想获取该关键字,实现的代码如下:

from selenium import webdriver
import time
driver=webdriver.Firefox()
driver.maximize_window()
driver.get('https://www.baidu.com/')
so=driver.find_element_by_id("kw")
so.send_keys('selenium webdriver')
print('百度搜索输入框中填写的关键字为:{0}'.format(so.get_attribute('value')))
time.sleep(2)
driver.quit()

E:\test01\venv\Scripts\python.exe E:/test01/sel.py
百度搜索输入框中填写的关键字为:selenium webdriver



2.3 检查元素是否可见
is_displayed 方法用于测试该属性对用户是否可见,返回结果为布尔类型。如果可见,返回的结果为 True;如果不可见,返回的结果为 False。这里以百度首页为例,测试“关于百度”是否可见,实现的测试代码如下:

from selenium import webdriver
driver=webdriver.Firefox()
driver.maximize_window()
driver.get('https://wwww.baidu.com/')
about=driver.find_element_by_link_text('关于百度')
print('关于百度是否可见:{0}'.format(about.is_displayed()))
driver.quit()

注解:由于“关于百度”在页面上是可见的,那么运行代码后返回的结果应该是True,如图所示。

D:\python3\python.exe C:/Users/Administrator/Desktop/testpy/baidu.py
关于百度是否可见:True
Process finished with exit code 0



2.4 检查元素是否可编辑
is_enabled 方法用于测试文本是否可编辑,返回的结果是布尔类型。如果可编辑,返回的结果是 True;如果不可编辑,返回的结果是 False。以百度搜索输入框为例,因为它是可编辑的,所以返回的结果是 True,实现的测试代码如下:

from selenium import webdriver
driver=webdriver.Firefox()
driver.maximize_window()
driver.get('https://wwww.baidu.com/')
so=driver.find_element_by_id('kw')
print('搜素输入框是否可编辑:{0}'.format(so.is_enabled()))
driver.quit()

D:\python3\python.exe C:/Users/Administrator/Desktop/testpy/baidu.py
搜素输入框是否可编辑:True



2.5 是否已选中
is_selected 方法主要针对单选按钮或者复选按钮,判断它们是否已被选中,返回结果是布尔类型。如果选中,返回的结果是True;如果未选中,返回的结果是 False。这里以新浪邮箱的登录为例,验证登录页面是否默认选中了自动登录,实现的代码如下:

from selenium import webdriver
import time
driver=webdriver.Firefox()
driver.maximize_window()
driver.get('https://mail.sina.com.cn/')
autoLogin=driver.find_element_by_id('store1')
print('新浪登录页面自动登录是否已默认选中:{0}'.format(autoLogin.is_selected()))
driver.quit()

注解:新浪登录页面的自动登录已默认选中,所以运行以上代码成功后,会返回True

D:\python3\python.exe C:/Users/Administrator/Desktop/testpy/baidu.py
新浪登录页面自动登录是否已默认选中:True



2.6 提交表单
提交表单用到的方法是submit。例如,在输入框中输入“昵称”,点击“提交”按钮,跳转到另外一个页面,Form表单的HTML代码如下:
form.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<center>
    <form action="index.html" method="get">
        <p>
            昵称: <input type="text" name="username">
        </p>
        <p>
            <input type="submit" name="form" value="提交">
        </p>
    </form>
</center>
</body>
</html>

index.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<center>
    <h1>
        hello hcc!
    </h1>
</center>
</body>
</html>

实现以上交互的代码如下:

from selenium import webdriver
import time
driver=webdriver.Firefox()
driver.maximize_window()
driver.get('file:///C:/Users/Administrator/Desktop/testpy/form.html')
driver.find_element_by_name('username').send_keys('hcc')
time.sleep(2)
driver.find_element_by_name('form').submit()
time.sleep(2)
driver.quit()

未完待续。。。第三节...NEXT

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,776评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,527评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,361评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,430评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,511评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,544评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,561评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,315评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,763评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,070评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,235评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,911评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,554评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,173评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,424评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,106评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,103评论 2 352

推荐阅读更多精彩内容