
- Watir 教程
- Watir - 首頁
- Watir - 概述
- Watir - 簡介
- Watir - 環境設定
- Watir - 安裝瀏覽器驅動
- Watir - 使用瀏覽器
- Watir - 網頁元素
- Watir - 定位網頁元素
- Watir - 使用 Iframes
- Watir - 自動等待
- Watir - 無頭測試
- Watir - 移動測試
- Watir - 捕獲螢幕截圖
- Watir - 頁面物件
- Watir - 頁面效能
- Watir - Cookies
- Watir - 代理
- Watir - 警報
- Watir - 下載
- Watir - 瀏覽器視窗
- Watir 有用資源
- Watir - 快速指南
- Watir - 有用資源
- Watir - 討論
Watir - 頁面物件
Watir 中的頁面物件幫助我們以類的形式重用程式碼。使用頁面物件功能,我們可以自動化我們的應用程式,而無需複製任何程式碼,並且使程式碼更易於管理。
在測試時,我們可以為我們要測試的每個頁面建立頁面物件。然後,我們將使用頁面物件訪問方法和屬性。
使用頁面物件的原因:
如果頁面在以後進行了更改,則無需重寫程式碼。
避免程式碼冗餘。
我們將使用 RSpec 在 Watir 中使用頁面物件。如果您不熟悉 RSpec,這裡有一個完整的教程可供您學習 RSpec。
我們將要執行測試的頁面如下所示:
textbox.html
<html> <head> <title>Testing UI using Watir</title> </head> <body> <script type = "text/javascript"> function wsentered() { console.log("inside wsentered"); var firstname = document.getElementById("firstname"); if (firstname.value != "") { document.getElementById("displayfirstname").innerHTML = "The name entered is : " + firstname.value; document.getElementById("displayfirstname").style.display = ""; } } </script> <div id = "divfirstname"> Enter First Name : <input type = "text" id = "firstname" name = "firstname" onchange = "wsentered()" /> </div> <br/> <br/> <div style = "display:none;" id = "displayfirstname"></div> </body> </html>
輸出

我們現在將為上述頁面建立頁面物件,如下所示:
pageobjecttest.rb
class InitializeBrowser def initialize(browser) @browser = browser end end class TestPage lt; InitializeBrowser def textbox @textbox = TestTextbox.new(@browser) end def close @browser.screenshot.save 'usingpageobject.png' @browser.close end end # TestPage class TestTextbox < InitializeBrowser URL = "https:///uitesting/textbox.html" def open @browser.goto URL self end def enterdata_as(name) name_field.set name name_field.fire_event('onchange') end private def name_field @browser.text_field(:id > "firstname") end end # TestTextbox
定義了三個類 - InitializeBrowser、TestPage 和 TestTextbox:
InitializeBrowser - 這將初始化開啟的瀏覽器,並將瀏覽器物件共享給 TestPage 和 TestTextbox 類。
TestPage - 此類將擁有對 TestTextbox 的物件引用,幷包含捕獲螢幕截圖和關閉瀏覽器的的方法。
TestTextbox - 此類將包含開啟頁面 URL、引用文字欄位、設定資料和觸發 onchange 事件的方法。
執行上面顯示的程式碼後,您可以看到如下所示的輸出:

廣告