Page Object в 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 = "http://localhost/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.
InitializeBrowser — это инициализирует открытый браузер и делит объект браузера с классами TestPage и TestTextbox.
TestPage — этот класс будет иметь ссылку на объект TestTextbox и содержит метод для захвата скриншота и закрытия браузера.
TestTextbox — этот класс будет иметь методы для открытия URL- адреса страницы, ссылки на текстовое поле, установки данных и запуска события onchange.
Как только вы выполните код, показанный выше, вы можете увидеть вывод, как показано ниже —