1. 程式人生 > >selenium IDE(五)selenium 命令之定位頁面元素

selenium IDE(五)selenium 命令之定位頁面元素

nbsp 代碼 依賴 超鏈接 種類型 菜鳥 rip 工具 設計

定位頁面元素

對於很多selenium命令,target域是必須的。Target在web頁面範圍內識別UI元素,它使用locatorType=location的格式。在很多情況下,locatorType可以省略,下面舉例方式來描述各種類型的locatorType.

假如,有如下一段HTML代碼:

技術分享圖片
 html>

<body>

<form id= "loginForm" >

<input name= "username" type= "text" />

<input name= "password" type= "password" />

<input name= "continue" type= "submit" value= "Login" />

<input name= "continue" type= "button" value= "Clear" />

<a href= "continue.html" >Continue</a>

</form>

</body>

</html>
技術分享圖片

我們看看selenium提供了那些定位方式:

1. identifier定位

這是最普遍的一種定位方式,當不能識別為其它定位方式後,默認為dientifier定位,在這種策略下,第一個使用id的頁面元素將被識別出來,如果沒有使用指定id的元素,那麽將識別第一個名字與指定條件相符的元素。

identifier識別html各項元素的定位策略如下:

identifier=loginForm //定位頁面元素為from

identifier=username //定位頁面元素為username

identifier=Continue //定位頁面元素為Continue

因為identifier定位是默認方式,因此“identifier=” 可以不寫。

Continue //同樣表示定位頁面元素為Continue

2. id定位

這種定位方式比identifier定位範圍更窄,當然也更具體,如果你知道元素id特征,就使用這種方式:

id=loginFrom //定位頁面元素from

3. name定位

名稱定位方式將會識別第一個匹配名稱屬性的UI元素。如果多個元素擁有相同的名稱屬性,可以使用過濾器來進一步優化你的定位策略。默認的過濾器是Value (匹配value特征):

name=username //定位頁面元素為username

name=Continue value=Clear //定位頁面元素為Continue ,值為Clear

name=Continue type=button //定位頁面元素為Continue ,類型為button

提示:

上述三種定位器使得selenium可以不依賴於UI元素在頁面上的位置而進行測試。所以,當頁面結構發生變化時,測試依然可以通過。有時候,設計人員頻繁改動頁面的情況,通過id和name特征定位元素就變的非常重要。

4. XPath定位

XPath是一種在XML文檔中定位元素的語言。因為HTML可以看做XML的一種實現,所以selenium用戶可是使用這種強大語言在web應用中定位元素。

XPath擴展了上面id和name定位方式,提供了很多種可能性,比如定位頁面上的第三個多選框。

xpath=/html/body/form[1] //絕對路徑(html的任何輕微改變都會導致失敗)

//form[1] //HTML中的第三個form元素

xpath=//form[@id=‘loginForm‘] //id為loginFrom的元素

//input[@name=‘username‘] //input元素且其name為‘username’

//form[@id=‘loginForm‘]/input[1] //針對id為‘loginForm’的form,定位它的第一個input元素

//input[@name=‘continue‘][@type=‘button‘] //name為‘continue’且type為‘button’的input

//form[@id=‘loginForm‘]/input[4] //id為‘loingForm’的form,定位它的第四個input元素。

擴展閱讀:

W3C XPath Recommendation: http://www.w3.org/TR/xpath/

XPath Tutorial: http://www.zvon.org/xxl/XPathTutorial/General/examples.html

http://www.w3.org/TR/xpath/

Firefox插件,可以幫助你獲取頁面元素的XPath:

XPath Checker Firebug

5. 通過超鏈接定位

可以通過連接文字來定位超鏈,如果兩個鏈接文字相同,那麽第一個匹配的將被識別出來。

link=continue //定位頁面元素連接文字為continue

6. DOM定位

Document Object Model 被用於描述HTML文檔,可以使用javaScript來訪問。

這一定位策略通過javaScript評估頁面上的元素,可以使用分級符號來簡化元素定位。

因為DOM定位以“document”開始,所以“dom=”標簽並不是必須的。

dom=document.getElementById(‘loginForm‘) // 定位頁面元素form

dom=document.forms[‘loginForm‘] // 定位頁面元素form

dom=document.forms[0] // 定位頁面元素form

document.forms[0] .usernam //定位頁面元素username

document.forms[0] .elements[3] //定位頁面元素continue,它是form的第四個元素

7。 CSS定位

CSS(Cascading Style Sheets)是一種語言,它被用來描述HTML和XML文檔的表現。CSS使用選擇器來為頁面元素綁定屬性。這些選擇器可以被selenium用作另外的定位策略。

css=form#loginForm //定位頁面元素form

css=input[name="username"] //定位頁面元素username

css=input.required[type="text"] //定位頁面元素,其類型為text

css=input.passfield //定位頁面元素,其類型為password

css=#loginForm input[type="button"] //定位頁面元素,其類型為button

css=#loginForm input:nth-child(2) //定位頁面元素passfield,且它為from的第二個input子元素

擴展閱讀:

http://www.w3.org/TR/css3-selectors/

提示:很多有經驗的selenium用戶推薦CSS定位方式,因為它比XPath更快。而且可以在HTML文件中找到更復雜的對象。

------------------------------------------------------------------------------

菜鳥提示:

講了這麽多頁面定位的方式,還是不明白幹啥用的?

自動化測試,我們通過工具來完成手工操作,如果我們要點擊一個按鈕,我們認得那是一個按鈕,如何讓自動化工具也認得那是一個按鈕呢?如何讓工具認得是“確定”按鈕,而不是“取消”按鈕呢。那每個按鈕都有不同的屬性,也許屬性完全相同但位置不同。我們要通過他們的特征描述它們,然後自動化工具才能根據我們的描述去找到它們。

那麽,轉換到我們的自動化測試代碼是什麽樣子呢?

//下面是在java代碼的實現
selenium.click("元素屬性的描述");
selenium.click("id=loginForm");
selemiun.click("name=Continue  value=Clear");
......

-----------------------轉

selenium IDE(五)selenium 命令之定位頁面元素