【Selenium11】获取测试对象的内容、属性、及状态

1、获取测试对象的内容和属性

  使用element.attribute()方法获取dom元素的内容

  获取测试对象的属性能够更好的定位对象,比如页面上有很多class都是'btn'的div,而目标是其中1个有具有title属性的div,由于selenium-webdriver不支持直接使用title来定位对象,所以只能先把所有class是btn的div都找到,然后遍历这些div,获取这些div的title属性,一旦发现具体title属性的div,那么返回这个div。在webdriver中,使用element.text()方法返回dom节点的内容(text)。

用到的HTML文档
    <html>
        <head>
            <meta http-equiv="content-type" content="text/html;charset=utf-8" />
            <title>attribute</title>        
            <script type="text/javascript" async="" src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
            <link href="http://netdna.bootstrapcdn.com/twitter-bootstrap/2.3.2/css/bootstrap-combined.min.css" rel="stylesheet" />      
            <script type="text/javascript">
                $(document).ready(function(){
                    $('#tooltip').tooltip({"placement": "right"});
                });
            </script>
        </head>

        <body>
            <h3>attribute</h3>
            <div class="row-fluid">
                <div class="span6">     
                    <a id="tooltip" href="#" data-toggle="tooltip" title="watir-webdriver better than selenium-webdriver">hover to see tooltip</a>
                </div>      
            </div>      
        </body>
        <script src="http://netdna.bootstrapcdn.com/twitter-bootstrap/2.3.2/js/bootstrap.min.js"></script>
    </html>

代码
from selenium import webdriver
import time
import os
dr=webdriver.Firefox()
file_path='file:///'+os.path.abspath('attribute.html')
dr.get(file_path)
time.sleep(2)
link=dr.find_element_by_id('tooltip')
print link.get_attribute('data-original-title') #获取tooltip的内容
print link.text #获取该链接的text
time.sleep(2)
dr.quit()

2、获取测试对象的CSS属性

用到的HTML文档
    <html>
        <head>
            <meta http-equiv="content-type" content="text/html;charset=utf-8" />
            <title>attribute</title>        
            <script type="text/javascript" async="" src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
            <link href="http://netdna.bootstrapcdn.com/twitter-bootstrap/2.3.2/css/bootstrap-combined.min.css" rel="stylesheet" />      
            <script type="text/javascript">
                $(document).ready(function(){
                    $('#tooltip').tooltip({"placement": "right"});
                });
            </script>
        </head>

        <body>
            <h3>attribute</h3>
            <div class="row-fluid">
                <div class="span6">     
                    <a id="tooltip" href="#" data-toggle="tooltip" title="watir-webdriver better than selenium-webdriver">hover to see tooltip</a>
                </div>      
            </div>      
        </body>
        <script src="http://netdna.bootstrapcdn.com/twitter-bootstrap/2.3.2/js/bootstrap.min.js"></script>
    </html>

代码
from selenium import webdriver
import time
import os
dr=webdriver.Firefox()
file_path='file:///'+os.path.abspath('css.html')
dr.get(file_path)
time.sleep(2)
link=dr.find_element_by_id('tooltip')
print link.value_of_css_property('color') #获取tooltip的CSS属性color的属性值
print dr.find_element_by_tag_name('h3').value_of_css_property('font') #获取h3的CSS属性font的属性值
time.sleep(2)
dr.quit()
 
 

3、获取测试对象的状态

  需要获取测试对象的四种状态

  是否显示:使用element.is_displayed()方法

  是否存在:使用find_element_by_xxx()方法,捕获其抛出的异常, 如果存在异常的话则可以确定该元素不存在

  是否被选中:一般判断表单元素,如radio或checkbox是否被选中,使用element.is_selected()方法

  是否有效:即是否为灰化状态,使用element.is_enabled()状态

 
 
用到的HTML文档
 
 
    <html>
        <head>
            <meta http-equiv="content-type" content="text/html;charset=utf-8" />
            <title>status</title>       
            <script type="text/javascript" async="" src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
            <link href="http://netdna.bootstrapcdn.com/twitter-bootstrap/2.3.2/css/bootstrap-combined.min.css" rel="stylesheet" />      
            <script type="text/javascript">
                $(document).ready(function(){
                    $('#tooltip').tooltip({"placement": "right"});
                });
            </script>
        </head>

        <body>
            <h3>status</h3>
            <div class="row-fluid">
                <div class="span3">     
                    <input name="user" placeholder="Disabled TextField" disabled  />                
                </div>      
                <div class="span3">
                    <a class="btn disabled">Disabled Button</a>
                </div>
                <div class="span3">
                    <input name="radio" type="radio" />
                </div>
            </div>      
        </body>
        <script src="http://netdna.bootstrapcdn.com/twitter-bootstrap/2.3.2/js/bootstrap.min.js"></script>
    </html>

代码

 

from selenium import webdriver
import time
import os
dr=webdriver.Firefox()
file_path='file:///'+os.path.abspath('status.html')
dr.get(file_path)
time.sleep(2)
text_field=dr.find_element_by_name('user')
print text_field.is_enabled() #判断元素是否有效
#直接用element.is_enabled()方法判断button,返回值为true,因为button是使用CSS方法判断是否有效
#这并不是真正的方法,需要判断其class中是否有值为disabled来判断是否真正处于disabled的状态
print dr.find_element_by_class_name('btn').is_enabled()
dr.execute_script('$(arguments[0]).hide()',text_field)  #隐藏掉text_field
print text_field.is_displayed() #判断是否显示
radio=dr.find_element_by_name('radio')
radio.click() #使用click()方法选择radio
print radio.is_selected() #判断是否被选中
try:
dr.find_element_by_id('none')
except:
print 'element does not exist'
dr.quit()

转载于:https://www.cnblogs.com/june2014/p/3651178.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值