Watir - Краткое руководство

Watir (Тестирование веб-приложений на Ruby), произносится как «Вода» - это инструмент с открытым исходным кодом, разработанный с использованием Ruby, который помогает в автоматизации веб-приложений, подходящих для приложений, разработанных на любом языке программирования. Браузеры, поддерживаемые для установки Watir: Internet Explorer, Firefox, Chrome, Safari и Edge. Watir доступен для установки как Rubygems.

Watir подключится к указанному браузеру и будет следовать инструкциям по открытию URL-адреса, щелчку по кнопке и вводу данных в текстовое поле, как это сделает любой реальный человек. Watir чаще всего используется для поддержки браузеров с такими платформами тестирования, как RSpec, Cucumber и т. Д.

Особенности Watir

Watir богат функциями, как описано ниже -

Location web elements- Существуют различные способы поиска веб-элементов, отображаемых внутри браузера. Чаще всего используются идентификаторы, класс, имя тега, настраиваемые атрибуты, метка и т. Д.

Taking Screenshots- Watir позволяет делать снимки экрана с результатами тестирования по мере необходимости. Это помогает отслеживать промежуточное тестирование.

Page Performance- Вы можете легко измерить производительность страницы с помощью объекта производительности, который имеет такие свойства, как performance.navigation, performance.timing, performance.memory и performance.timeOrigin . Эти данные получаются при подключении к браузеру.

Page Objects- Объект страницы в Watir поможет нам повторно использовать код в виде классов. Используя эту функцию, мы можем автоматизировать наше приложение без дублирования кода, а также сделать его управляемым.

Downloads - С Watir легко протестировать загрузку файла для пользовательского интерфейса или веб-сайта.

Alerts - Watir предоставляет простые в использовании API для тестирования всплывающих предупреждений в пользовательском интерфейсе или на веб-сайте.

Headless Testing- Используя автономное тестирование, подробности получаются в командной строке без необходимости открывать браузер. Это помогает выполнять тестовые примеры пользовательского интерфейса в командной строке.

Преимущества использования Watir

Watir предлагает следующие преимущества -

  • Watir - это инструмент с открытым исходным кодом, который очень прост в использовании.

  • Watir разработан на Ruby, и любое веб-приложение, работающее в браузере, можно легко автоматизировать с помощью watir.

  • В Watir поддерживаются все последние версии браузеров, что упрощает тестирование.

  • Watir имеет встроенные библиотеки для проверки производительности страниц, предупреждений, теста iframe, окон браузера, создания снимков экрана и т. Д.

Недостатки Watir

Как и любое другое программное обеспечение, Watir также имеет свои ограничения.

  • Watir поддерживается только для среды тестирования Ruby и не может использоваться с другими средами тестирования.

  • Мобильное тестирование с использованием Watir не улучшается, и настольные браузеры имитируют поведение мобильных браузеров, а не устройства реального времени.

Watir (Web Application Testing in Ruby)произносится как «Вода» - это инструмент с открытым исходным кодом, разработанный с использованием Ruby, который помогает автоматизировать веб-приложения независимо от того, на каком языке оно написано. Watir поставляется с богатым набором API-интерфейсов, которые помогают нам взаимодействовать с браузером, находить элементы страницы, делать снимки экрана, работать с предупреждениями, загрузкой файлов, открывать всплывающие окна window.open , проводить тестирование без подключения к Интернету и т. Д.

Поддерживаемые браузеры -

  • Internet Explorer
  • Firefox
  • Chrome
  • Safari
  • Edge

Note - Watir доступен для установки как гем Rubygems.

Используя Watir webdriver, вы можете тестировать свои веб-сайты и приложения пользовательского интерфейса. Поскольку Watir полностью сосредоточен на материалах, связанных с браузером, вы можете использовать Watir вместе с другой тестовой средой, такой как -

  • RSpec
  • Cucumber

Основной код тестирования будет написан с использованием тестовой среды, а взаимодействие с браузером будет осуществляться с помощью Watir.

Поток тестовой среды вместе с Watir показан ниже -

RSpec или Cucumber участвуют в тестовом средстве выполнения и тестовом коде. Подробная информация о веб-сайте или тестировании пользовательского интерфейса может быть разбита на объект страницы, который будет иметь ссылку на Watir, где он получит указатели страниц, которые будут использоваться для тестирования. Watir вместе со своим веб-драйвером помогает подключиться к браузеру и выполнить автоматизацию тестирования.

Для работы с Watir нам необходимо установить следующее -

  • Установить Ruby
  • Установить Watir
  • Рубиновая шахта (IDE)

Поскольку Watir построен с использованием Ruby, нам нужно установить Ruby и gem (менеджер пакетов для Ruby).

Установка Ruby в Windows

Чтобы установить Ruby в Windows, перейдите по ссылке - https://rubyinstaller.org/downloads/

Установите рубиновую версию для вашей 32- или 64-битной операционной системы. Здесь мы установили выделенный, как показано на скриншоте. После того, как вы загрузите его, следуйте инструкциям и установите соответственно.

Когда вы закончите установку, проверьте, установлен ли ruby, проверив версию в командной строке, как показано ниже -

C:\> ruby -v

Если Ruby успешно установлен, вы увидите результат, как показано ниже -

Установленная версия - 2.6.3. Мы успешно установили Ruby в нашей системе. Вместе с установочным гемом Ruby также устанавливается менеджер пакетов Ruby. Вы можете проверить версию установленного гема следующим образом -

Мы закончили установку Ruby и Gem в Windows.

Установка Ruby в Linux

Для установки Ruby в Linux выполните следующие команды в терминале Linux:

wget -O ruby-install-0.6.0.tar.gz https://github.com/postmodern/ruby-install/archive/v0.6.0.tar.gz
tar -xzvf ruby-install-0.6.0.tar.gz
cd ruby-install-0.6.0/
sudo make install
ruby-install ruby 2.5.3

Установка Ruby для Mac

Для установки Ruby в Linux выполните следующие команды в терминале Mac -

Установить xcode

xcode-select --install

Установить HomeBrew

/usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"

Установить rbenv

brew install rbenv
rbenv init
touch ~/.bash_profile
echo 'eval "$(rbenv init -)"' >> ~/.bash_profile
source ~/.bash_profile
rbenv install 2.5.3
rbenv local 2.5.3

Установка Watir

Команда для установки watir -

gem install watir

gem install watir

Затем вы можете увидеть экран вывода, как показано ниже -

RubyMine IDE

Мы будем использовать RubyMine IDE для написания и выполнения наших тестовых примеров. Официальный сайт RubyMine IDE: www.jetbrains.com/ruby .

RubyMine - это платная IDE с 30-дневной бесплатной пробной версией. Нажмите кнопку бесплатной пробной версии, чтобы загрузить. Вы также можете использовать любую другую IDE по вашему выбору для написания тестовых примеров.

При нажатии на кнопку бесплатной пробной версии начнется загрузка. После завершения загрузки установите его в своей системе.

Нажмите Далее и продолжите установку. После завершения установки откройте среду IDE, и она попросит вас создать проект, как показано ниже -

Нажмите Create New Project, мы ввели имя проекта как Watir, и вот отображение в IDE -

Запишем наши тест-кейсы в папку watir / и выполним.

В этой главе мы собираемся установить драйверы браузера, которые нам нужны для тестирования нашего проекта с помощью Watir. До Watir 6 нам приходилось включать watir-webdriver для использования драйверов браузера. С выпуском Watir 6 watir-webdriver доступен как часть пакета Watir, и пользователям не нужно добавлять watir-webdriver отдельно.

Такие браузеры, как Chrome, Firefox и Safari, доступны по умолчанию, и вам не нужно добавлять их извне. Если во время тестирования вы обнаружите, что драйвер для браузера недоступен, вы всегда можете загрузить их, как указано ниже.

Мы собираемся установить драйверы для следующих браузеров -

  • Драйвер для браузеров - Chrome
  • Драйвер для браузеров - Firefox
  • Драйвер для браузеров - Edge
  • Драйвер для браузеров - Internet Explorer
  • Драйвер для браузеров - Safari

Драйвер для браузера - Chrome

Чтобы получить драйвер для браузера Chrome, перейдите по ссылке - https://sites.google.com/a/chromium.org/chromedriver/downloads.

Проверьте версию своего браузера и, соответственно, загрузите драйвер Chrome. Чтобы проверить версию вашего браузера Chrome, сделайте, как показано здесь -

Нажмите О Google Chrome, и он предоставит вам версию для Chrome, как показано ниже -

Итак, наша версия - 74. Итак, скачайте версию драйвера Chrome 74.

Затем загрузите драйвер Chrome в зависимости от вашей операционной системы. Мы загрузим chromedriver_win32.zip, он предназначен как для 32-битных, так и для 64-битных машин. Если вы планируете использовать загруженный драйвер, добавьте местоположение где-нибудь в переменной PATH.

Драйвер для браузера - Firefox

Для драйвера Firefox перейдите по ссылке - https://github.com/mozilla/geckodriver/releases как показано на скриншоте ниже -

В соответствии с вашей операционной системой загрузите драйвер, как показано выше. Если вы планируете использовать загруженный драйвер, добавьте местоположение где-нибудь в переменной PATH.

Драйвер для браузера - Edge

Для драйвера Firefox перейдите по ссылке - https://developer.microsoft.com/en-us/microsoft-edge/tools/webdriver/ как показано на скриншоте ниже -

Нажмите на версию Microsoft Edge, которая у вас есть, как показано ниже -

Нажмите на ссылку Release, и она перенаправит вас на -

Здесь вы можете найти версию для загрузки, доступную для Windows. Если вы планируете использовать загруженный драйвер, добавьте местоположение где-нибудь в переменной PATH.

Драйвер для браузера - Internet Explorer

Чтобы установить драйвер для Internet Explorer, перейдите по ссылке - https://docs.seleniumhq.org/download/ как показано ниже -

Подробности для раздела загрузки в IE показаны здесь -

В зависимости от вашей ОС загрузите 32- или 64-разрядный IE для Windows. Также добавьте местоположение к переменной PATH, чтобы использовать драйвер.

Драйверы для браузеров - Safari

Драйверы для сафари не требуется загружать извне для сафари версии 10 и выше. Они загружаются вместе с пакетом gem при установке Watir.

Обратите внимание, что драйверы для Chrome, Firefox, Internet Explorer также доступны при установке Watir. Но если у вас возникнут какие-либо проблемы и вам понадобится конкретная версия для тестирования, вы можете загрузить их в соответствии с вашим браузером и обновить местоположение в PATH, чтобы использовать его при тестировании вашего приложения.

По умолчанию Watir открывает браузер Chrome, если имя браузера не указано. Необходимые драйверы браузера устанавливаются вместе с установкой Watir. Если у вас возникнут какие-либо проблемы при работе с браузерами, установите драйвер, как показано в главе «Драйверы для браузеров», и обновите его местоположение в переменной PATH.

В этой главе мы поймем, как открыть браузер с помощью Watir.

Шаги по открытию браузера с помощью Watir

Откройте IDE RubyMine и создайте новый файл: test1.rb

Выберите ОК и щелкните шаблон файла как рубин, как показано ниже -

Нажмите ОК, чтобы создать файл.

Теперь мы напишем простой код, который откроет браузер, как показано ниже -

test1.rb

require 'watir'
Watir::Browser.new

Нажмите кнопку "Выполнить", выделенную в среде IDE, как показано выше. При нажатии кнопки «Выполнить» откроется браузер, как показано ниже -

Браузер откроется и закроется автоматически. Давайте теперь добавим еще немного кода в test1.rb.

Мы можем указать имя браузера, как показано ниже -

Пример для Chrome

require 'watir'
Watir::Browser.new :chrome

Теперь давайте откроем URL-адрес страницы в нашем тестовом примере.

пример

require 'watir'
browser = Watir::Browser.new
browser.goto("https://www.google.com")

Нажмите Run, чтобы увидеть результат, как показано ниже -

Точно так же вы можете открыть браузер Firefox, Safari, Internet Explorer.

Пример для Firefox

require 'watir'
Watir::Browser.new :firefox

Пример для Internet Explorer

Watir Code

require 'watir'
browser = Watir::Browser.new :ie
browser.goto("https://www.google.com")

Когда мы запускаем код, отображается следующая ошибка -

Unable to find IEDriverServer. Please download the server from
(Selenium::WebDriver::Error::WebDriverError)

http://selenium-release.storage.googleapis.com/index.html and place it
somewhere on your PATH.

More info at
https://github.com/SeleniumHQ/selenium/wiki/InternetExplorerDriver.

Это означает, что в пакете watir нет драйвера InternetExplorer. Мы скачали то же самое отсюда -https://docs.seleniumhq.org/download/ и обновляется в переменной PATH.

Теперь запустите его еще раз, чтобы увидеть, как открывается браузер Internet Explorer, как показано ниже -

Код Watir для открытия браузера Safari

require 'watir'
browser = Watir::Browser.new :safari
browser.goto("https://www.google.com")

Код Watir для браузера Microsoft Edge

require 'watir'
browser = Watir::Browser.new :edge
browser.goto("https://www.google.com")

В этой главе мы обсудим, как работать с подписчиками в Watir -

  • Работа с текстовыми полями
  • Работа с комбо
  • Работа с радио-кнопками
  • Работа с флажками
  • Работа с кнопками
  • Работа со ссылками
  • Работа с Div

Работа с текстовыми полями

Синтаксис

browser.text_field id: 'firstname' // will get the reference of the textbox

Здесь постараюсь понять, как работать с текстовыми полями в пользовательском интерфейсе.

Рассмотрим страницу 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>

Соответствующий вывод показан ниже -

У нас есть текстовое поле, когда вы вводите имя, событие onchange запускается, и имя отображается ниже.

Теперь давайте напишем код, в котором мы найдем текстовое поле, введем имя и запустим событие onchange.

Кодекс Ватира

require 'watir'
b = Watir::Browser.new :chrome
b.goto('http://localhost/uitesting/textbox.html')
t = b.text_field id: 'firstname'
t.exists?
t.set 'Riya Kapoor'
t.value
t.fire_event('onchange')

Мы используем браузер Chrome и задаем pageurl как http://localhost/uitesting/textbox.html.

Использование goto api browser откроет pageurl, и мы найдем text_field с id: firstname. Если он существует, мы установим значение как Riya Kapoor и будем использовать fire_event api для запуска события onchange.

Теперь давайте запустим код, чтобы отобразить результат, как показано ниже -

Работа с комбо

Синтаксис

browser.select_list id: 'months' // will get the reference of the dropdown

Тестовая страница, которую мы собираемся протестировать сейчас, показана здесь -

<html>
   <head>
      <title>Dropdown</title>
   </head>
   
   <body>
      <script type = "text/javascript">
         function wsselected() {
            var months = document.getElementById("months");
            
            if (months.value != "") {
               document.getElementById("displayselectedmonth").innerHTML = 
                  "The month selected is : " + months.value;
               
               document.getElementById("displayselectedmonth").style.display = "";
            }
         }
      </script>
      <form name = "myform" method = "POST">
         <div>
            Month is :
            <select name = "months" id = "months" onchange = "wsselected()">
               <option value = "">Select Month</option>
               <option value = "Jan">January</option>
               <option value = "Feb">February</option>
               <option value = "Mar">March</option>
               <option value = "Apr">April</option>
               <option value = "May">May</option>
               <option value = "Jun">June</option>
               <option value = "Jul">July</option>
               <option value = "Aug">August</option>
               <option value = "Sept">September</option>
               <option value = "Oct">October</option>
               <option value = "Nov">November</option>
               <option value = "Dec">December</option>
            </select>
         </div>
         <br/>
         <br/>
         
         <div style = "display:none;" id = "displayselectedmonth">
         </div>
   </body>
</html>

Вывод

Когда вы выбираете месяц из раскрывающегося списка, то же самое отображается ниже.

Давайте теперь протестируем то же самое с помощью Watir.

Код Watir для выбора комбо

require 'watir'
b = Watir::Browser.new :chrome
b.goto('http://localhost/uitesting/combos.html')
t = b.select_list id: 'months'
t.exists?
t.select 'September'
t.selected_options
t.fire_event('onchange')

Чтобы работать с комбо, вам нужно найти элемент выбора с помощью API b.select_list, за которым следует идентификатор раскрывающегося списка. Чтобы выбрать значение из раскрывающегося списка, вам нужно использовать t.select и желаемое значение.

Результат выполнения выглядит следующим образом -

Работа с радио-кнопками

Синтаксис

browser.radio value: 'female' 
// will get the reference of the radio button with value “female”

Вот тестовая страница, которую мы будем использовать для работы с переключателями -

<html>
   <head>
      <title>Testing UI using Watir</title>
   </head>
   
   <body>
      <form name = "myform" method = "POST">
         <b>Select Gender?</b>
         <div>
            <br/>
            <input type = "radio" name = "gender" value = "male" checked> Male
            <br/>
            <input type = "radio" name = "gender" value = "female"> Female
            <br/>
         </div>
      </form>
   </body>
   
</html>

Мы выберем переключатель со значением Female, как показано в коде Watir -

require 'watir'
b = Watir::Browser.new
b.goto('http://localhost/uitesting/radiobutton.html')
t = b.radio value: 'female'
t.exists?
t.set
b.screenshot.save 'radiobutton.png'

Для работы с радио-кнопкой нам нужно сообщить браузеру о выбранном нами значении, т.е. b.radio value:”female”

Мы также делаем снимок экрана и сохранили его как radiobutton.png, и то же самое показано ниже -

Работа с флажками

Синтаксис

browser. checkbox value: 'Train' 
// will get the reference of the checkbox with value “Train”

Вот тестовая страница для флажков -

<html>
   <head>
      <title>Testing UI using Watir</title>
   </head>
   
   <body>
      <form name = "myform" method = "POST">
         <b>How would you like to travel?</b>
         <div>
            <br>
            <input type = "checkbox" name = "option1" value = "Car"> Car<br>
            <input type = "checkbox" name = "option2" value = "Bus"> Bus<br>
            <input type = "checkbox" name = "option3" value = "Train"> Train<br>
            <input type = "checkbox" name = "option4" value = "Air"> Airways<br>
            <br>
         </div>
      </form>
   </body>
   
</html>

Теперь давайте используем Watir, чтобы установить флажок в браузере, как показано ниже -

require 'watir'
b = Watir::Browser.new
b.goto('http://localhost/uitesting/checkbox.html')
t = b.checkbox value: 'Train'
t.exists?
t.set
b.screenshot.save 'checkbox.png'

Чтобы установить флажок в браузере, используйте флажок b со значением, которое вы хотите выбрать.

Работа с кнопками

Синтаксис

browser.button(:name => "btnsubmit").click
// will get the reference to the button element with has name “btnsubmit”

Вот тестовая страница для кнопки -

<html>
   <head>
      <title>Testing UI using Watir</title>
   </head>
   
   <body>
      <script type = "text/javascript">
         function wsclick() {
            document.getElementById("buttondisplay").innerHTML = "Button is clicked";
            document.getElementById("buttondisplay").style.display = "";
         }
      </script>
      
      <form name = "myform" method = "POST">
         <div>
            <br>
            <input type = "button" id = "btnsubmit" name = "btnsubmit"
               value = "submit" onclick = "wsclick()"/>
            <br>
         </div>
      </form>
      <br/>
      
      <div style = "display:none;" id = "buttondisplay"></div>
   </body>
   
</html>

Вот код watir, чтобы найти кнопку на данной странице -

require 'watir'
b = Watir::Browser.new
b.goto('http://localhost/uitesting/button.html')
b.button(:name => "btnsubmit").click
b.screenshot.save 'button.png'

Вот скриншот button.png

Работа со ссылками

Синтаксис

browser.link text: 'Click Here' 
// will get the reference to the a tag with text ‘Click Here’

Мы собираемся использовать следующую тестовую страницу для проверки ссылок -

<html>
   <head>
      <title>Testing UI using Watir</title>
   </head>
   <body>
      <br/>
      <br/>
      <a href = "https://www.google.com">Click Here</a>
      <br/>
   </body>
</html>

Детали Watir, необходимые для проверки ссылок, приведены ниже -

require 'watir'
b = Watir::Browser.new
b.goto('http://localhost/uitesting/links.html')
l = b.link text: 'Click Here'
l.click
b.screenshot.save 'links.png'

Вывод

Работа с Div

Синтаксис

browser.div class: 'divtag' 
// will get the reference to div with class “divtag”

Тестовая страница, на которой мы можем протестировать div.

<html>
   <head>
      <title>Testing UI using Watir</title>
      <style>
         .divtag {
            color: blue;
            font-size: 25px;
         }
      </style>
   </head>
   
   <body>
      <br/>
      <br/>
      <div class = "divtag"> UI Testing using Watir </div>
      <br/>
   </body>
</html>

Вывод

Код Watir для проверки div показан здесь -

require 'watir'
b = Watir::Browser.new
b.goto('http://localhost/uitesting/div.html')
l = b.div class: 'divtag'
l.exists?
l.text
b.screenshot.save 'divtag.png'

Вывод

В Watir для тестирования вам нужно найти элементы, и это можно сделать по-разному - используя идентификатор, класс или текст элемента.

В этой главе мы увидим несколько примеров, показывающих различные способы расположения элементов.

Использование ID элемента

Тестовая страница

<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>

пример

require 'watir'
b = Watir::Browser.new :chrome
b.goto('http://localhost/uitesting/textbox.html')
t = b.text_field(id: 'firstname') // using the id of the textbox to locate the textbox
t.exists?
t.set 'Riya Kapoor'
b.screenshot.save 'textboxbefore.png'
t.value
t.fire_event('onchange')
b.screenshot.save 'textboxafter.png'

В этом примере мы используем идентификатор элемента текстового поля, чтобы найти его и установить значение.

t = b.text_field(id: 'firstname')

Вывод

Если вам нужно найти div, span или любой другой тег html, вы можете сделать то же самое, используя идентификатор следующим образом:

Для div

browser.div(id: "divid")
browser.div(id: /divid/)

Для пролета

browser.span(id: "spanid")
browser.span(id: /spanid/)

Использование НАЗВАНИЯ элемента

Тестовая страница

<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>

пример

require 'watir'
b = Watir::Browser.new :chrome
b.goto('http://localhost/uitesting/textbox.html')
t = b.text_field(name: 'firstname') // name is used to locate the textbox element
t.exists?
t.set 'Riya Kapoor'
b.screenshot.save 'textboxbefore.png'
t.value
t.fire_event('onchange')
b.screenshot.save 'textboxafter.png'

Вывод

Использование имени тега

Вы можете найти любые элементы html, которые хотите, напрямую используя тег html, как показано ниже.

Для div

browser.div(id: "divid")
browser.div(id: /divid/)

Для пролета

browser.span(id: "spanid")
browser.span(id: /spanid/)

Для тега p

browser.p(id: "ptag")
browser.p(id: /ptag/)

Для кнопки

browser.button(id: "btnid")
browser.button(id: /btnid/)

Использование имени класса

Вы можете найти элемент, используя его имя класса. Это можно сделать, как показано ниже -

Для div

browser.div(class: "divclassname")
browser.div(class: /divclassname/)

Для пролета

browser.span(class: "spanclassname”)
browser.span(class: /spanclassname/)

Для тега p

browser.p(class: "pclassname")
browser.p(class: /pclassname/)

Для кнопки

browser.button(class: "btnclassname")
browser.button(class: /btnclassname/)

Для текстового поля

browser.text_field(class: 'txtclassname')
browser.text_field(class: /txtclassname/)

Вы также можете передать несколько классов, как показано ниже -

Для div

browser.div(class: ["class1", "class2"])

Использование текста

Это еще один способ поиска элементов с помощью элементов с текстом. Например -

browser.button(text: "button text")
browser.button(text: /button text/)

Использование метки

Вы можете использовать метку элемента, чтобы найти его, как показано ниже -

browser.text_field(label: "text here"))
browser.text_field(label: /text here/))

Использование атрибутов данных

Если у вас есть атрибуты данных для ваших html-тегов, вы можете найти элементы, используя их, как показано ниже -

Например, вы можете найти тег, как показано ниже -

<div data-type = "test1"></div>

Вы можете найти div следующим образом -

browser.div(data-type: 'test1'))
browser.div(data-type: /test1/))

Использование настраиваемых атрибутов

Вы также можете найти элементы с помощью настраиваемых атрибутов, как показано ниже -

Пример элемента html

<div itemprop = ”content”>
   ….
</div>

Вы можете найти div следующим образом -

browser.div(itemprop: ‘content'))
browser.div(itemprop: /content/))

Использование видимого атрибута

Элемент, использующий атрибут visible, может быть расположен, как показано ниже -

browser.div(visible: true)
browser.div(visible: false)

Watir предлагает простой в использовании синтаксис для работы с фреймами.

Синтаксис

browser.iframe(id: 'myiframe') 
// will get the reference of the iframe where we want to input details.

Чтобы понять, как работать с iframe и размещать элементы внутри iframe, в этой главе мы рассмотрим пример.

пример

main.html

<html>
   <head>
      <title>Testing using Watir</title>
   </head>
   <body>
      <iframe src = "test1.html" id = "myiframe" width = "500" height = "100"></iframe>
   </body>
</html>

test1.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>

Вывод

В приведенном выше примере форма ввода определяется внутри iframe. Код Watir, который поможет нам найти его и протестировать форму, приведен ниже -

Кодекс Ватира

require 'watir'
b = Watir::Browser.new :chrome
b.goto('http://localhost/uitesting/main.html')
t = b.iframe(id: 'myiframe').text_field
t.set 'Riya Kapoor'
b.screenshot.save 'iframetestbefore.png'
t.fire_event('onchange')
b.screenshot.save 'iframetestafter.png'

Код Watir для поиска iframe в указанном здесь URL -

t = b.iframe(id: 'myiframe').text_field

Мы использовали имя тега iframe и идентификатор iframe, как показано выше.

Скриншоты приведенного выше кода показаны ниже -

iframetestbefore.png

iframetestafter.png

В этой главе давайте подробно разберемся с ожиданием. Чтобы понять автоматическое ожидание, мы создали простую тестовую страницу. Когда пользователь вводит текст в текстовое поле, запускается событие onchange, и через 3 секунды кнопка активируется.

У Watir есть вызов api wait_unit, который ожидает определенного события или свойства. Мы проверим то же самое для тестовой страницы, как показано ниже -

Синтаксис

browser.button(id: 'btnsubmit').wait_until(&:enabled?)
//here the wait is on the button with id : btnsubmit to be enabled.

testwait.html

<html>
   <head>
      <title>Testing UI using Watir</title>
   </head>
   
   <body>
      <script type = "text/javascript">
         function wsentered() {
            setTimeout(function() {
            document.getElementById("btnsubmit").disabled = false; }, 3000);
         }
         function wsformsubmitted() {
            document.getElementById("showmessage").style.display = "";
         }
      </script>
      
      <div id = "divfirstname">
         Enter First Name : 
         <input type = "text" id = "firstname" name = "firstname" onchange = "wsentered()" />
      </div>
      <br/>
      <br/>
      <button id = "btnsubmit" disabled onclick = "wsformsubmitted();">Submit</button>
      <br/<
      <br/<
      
      <div id = "showmessage" style = "display:none;color:green;font-size:25px;"&gtl;
         Button is clicked
      </div>
   </body>
</html>

Вывод

Когда вы вводите текст в текстовое поле, вам придется подождать 3 секунды, чтобы кнопка была активирована.

Когда вы нажимаете кнопку «Отправить», отображается следующий текст -

Теперь, когда мы добавили задержку для включения кнопки, автоматизации сложно обрабатывать такие случаи. Всякий раз, когда у нас есть некоторая задержка или нам нужно дождаться какого-либо события или свойства элемента, который нужно найти, мы можем использовать wait_until, как показано ниже -

Код Watir с использованием wait_until

require 'watir'
b = Watir::Browser.new :chrome
b.goto('http://localhost/uitesting/testwait.html')
t = b.text_field(name: 'firstname')
t.exists?
t.set 'Riya Kapoor'
b.screenshot.save 'waittestbefore.png'
t.value
t.fire_event('onchange')
btn = b.button(id: 'btnsubmit').wait_until(&:enabled?)
btn.fire_event('onclick');
b.screenshot.save 'waittestafter.png'

Затем используйте следующую команду

btn = b.button(id: 'btnsubmit').wait_until(&:enabled?)

Watir будет ждать включения кнопки, а затем запускать событие click. Снимки экрана показаны ниже -

Waittestbefore.png

waittestafter.png

В этой главе мы узнаем, как использовать безголовую опцию веб-драйвера Watir для проверки URL-адреса страницы.

Синтаксис

Browser = Watir::Browser.new :chrome, headless: true

Тестовая страница, которую мы собираемся протестировать, показана здесь -

<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>

Вывод

Код Watir

require 'watir'
b = Watir::Browser.new :chrome, headless: true
b.goto('http://localhost/uitesting/textbox.html')
t = b.text_field(name: 'firstname')
t.exists?
t.set 'Riya Kapoor'
t.value
t.fire_event('onchange')
b.screenshot.save 'headless.png'

Мы добавили опцию headless : true в браузер Watir Chrome. Когда вы выполняете программу Ruby, она не открывает браузер, все выполняется в командной строке -

DevTools listening on ws://127.0.0.1:53973/devtools/browser/b4127866-afb8-4c74-b967-5bacb3354b19
[0505/144843.905:INFO:CONSOLE(8)] "inside wsentered", source: http://localhost/uitesting/textbox.html (8)

Мы добавили сообщение console.log, и то же самое в командной строке.

Снимок экрана headless.png показан ниже -

В Firefox

Код watir для Firefox показан здесь -

require 'watir'
b = Watir::Browser.new :firefox, headless: true
b.goto('http://localhost/uitesting/textbox.html')
t = b.text_field(name: 'firstname')
t.exists?
t.set 'Riya Kapoor'
t.value
t.fire_event('onchange')
b.screenshot.save 'headlessfirefox.png'

Снимок экрана для headlessfirefox.png показан здесь -

Для мобильного тестирования мы собираемся использовать настольный браузер, который будет действовать как браузер устройства для целей тестирования. Давайте разберемся с его процедурой в этой главе.

Чтобы протестировать ваше приложение в мобильных браузерах, нам нужно установить webdriver-user-agent.

Установка webdriver-user-agent

gem install webdriver-user-agent

Теперь мы собираемся использовать агент пользователя Webdriver, как показано в примере ниже -

пример

require 'watir'
require 'webdriver-user-agent'
driver = Webdriver::UserAgent.driver(browser: :chrome, agent: :iphone, orientation: :landscape)
browser = Watir::Browser.new driver
browser.goto 'https://facebook.com'
puts "#{browser.url}"
puts browser.url == 'https://m.facebook.com/'

Мы дали URL facebook.com. Когда вы его запускаете, он открывается в мобильном режиме в зависимости от агента пользователя, как показано ниже -

Давайте теперь попробуем в портретном режиме. Используйте для этой цели следующий код -

require 'watir'
require 'webdriver-user-agent'
driver = Webdriver::UserAgent.driver(browser: :chrome, agent: :iphone, orientation: :portrait)
browser = Watir::Browser.new driver
browser.goto 'https://facebook.com'
puts "#{browser.url}"
puts browser.url == 'https://m.facebook.com/'

Результат в портретном режиме показан ниже -

Возможность делать снимки экрана - одна из интересных функций, доступных в Watir. Во время автоматизации тестирования вы можете делать скриншоты и сохранять экраны. В случае возникновения какой-либо ошибки ее можно зафиксировать с помощью скриншота.

Ниже обсуждается простой пример вместе с тестовой страницей, на которой мы сделали снимок экрана.

Синтаксис

browser.screenshot.save 'nameofimage.png'

Тестовая страница

<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>

пример

require 'watir'
b = Watir::Browser.new :chrome
b.goto('http://localhost/uitesting/textbox.html')
t = b.text_field(id: 'firstname') // using the id of the textbox to locate the textbox
t.exists?
t.set 'Riya Kapoor'
b.screenshot.save 'textboxbefore.png'
t.value
t.fire_event('onchange')
b.screenshot.save 'textboxafter.png'

Скриншоты, которые мы сделали с помощью Watir, показаны здесь -

textboxbefore.png

textboxafter.png

Объект страницы в 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.

После выполнения кода, показанного выше, вы можете увидеть результат, как показано ниже -

Функция производительности страницы Watir позволяет отслеживать показатели времени отклика, и она отлично работает в Chrome, Firefox, IE9 и выше. Браузер Safari на данный момент не поддерживает.

Давайте подробнее рассмотрим, как использовать эту функцию. Чтобы использовать его, нам нужно установить watir-performance с помощью gem, как показано ниже -

Команда

gem install watir-performance

Мы закончили с установкой watir-performance. Поддерживаемые показатели:

  • summary
  • navigation
  • memory
  • Timing

Здесь обсуждается рабочий пример с использованием watir-performance. Здесь мы проверим время ответа для сайта - www.tutorialspoint.com, как показано ниже -

require 'watir'
require 'watir-performance'
10.times do
   b = Watir::Browser.new :chrome
   b.goto 'https://www.tutorialspoint.com'
   load_secs = b.performance.summary[:response_time] / 1000
   puts "Load Time: #{load_secs} seconds."
   b.close
end

вывод

Load Time: 7 seconds.
Load Time: 7 seconds.
Load Time: 5 seconds.
Load Time: 5 seconds.
Load Time: 6 seconds.
Load Time: 5 seconds.
Load Time: 5 seconds.
Load Time: 13 seconds.
Load Time: 12 seconds.
Load Time: 5 seconds.

Использование performance.timing

require 'watir'
require 'watir-performance'

b = Watir::Browser.new :chrome
b.goto 'https://www.tutorialspoint.com'
load_secs = b.performance.timing[:response_end] - b.performance.timing[:response_start]
puts "Time taken to respond is #{load_secs} seconds."
b.close

вывод

Time taken to respond is 41 seconds.

Использование performance.navigation

require 'watir'
require 'watir-performance'

b = Watir::Browser.new :chrome
b.goto 'https://www.tutorialspoint.com'
perf_nav = b.performance.navigation
puts "#{perf_nav}"
b.close

вывод

{:type_back_forward=>2, :type_navigate=>0, :type_reload=>1, 
:type_reserved=>255, :redirect_count=>0, :to_json=>{}, :type=>0}

Использование performance.memory

require 'watir'
require 'watir-performance'

b = Watir::Browser.new :chrome
b.goto 'https://www.tutorialspoint.com'
memory_used = b.performance.memory
puts "#{memory_used}"
b.close

вывод

{:js_heap_size_limit=>2, :type_navigate=>0, :type_reload=>1, :ty2136997888, 
:total_js_heap_size=>2, :type_navigate=>0, :type_reload=>1, :ty12990756, 
:used_js_heap_size=>2, :type_navigate=>0, :type_reload=>1, :ty7127092}

В этой главе мы узнаем, как работать с файлами cookie с помощью Watir.

Здесь обсуждается простой пример, который будет получать файлы cookie для указанного URL.

Синтаксис для получения файлов cookie

browser.cookies.to_a

пример

require 'watir'

b = Watir::Browser.new :chrome
b.goto 'https://www.tutorialspoint.com'
puts b.cookies.to_a

Вывод

{:name=>"_gat_gtag_UA_232293_6", :value=>"1", :path=>"/", 
:domain=>".tutorialspoint.com", :expires=>2019-05-03 08:33:58 +0000, 
:secure=>false}

{:name=>"_gid", :value=> "GA1.2.282573155.1556872379", :path=>"/", 
:domain=>".tutorialspoint.com", :expires=>2019-05-04 08:32:57 +0000, 
:secure=>false}

{:name=>"_ga", :value=>"GA1.2.2087825339.1556872379", :path=>"/", 
:domain=>".tutorialspoint.com", :expires=>
2021-05-02 08:32:57 +0000, :secure=>false}

Теперь давайте добавим файлы cookie, как показано ниже -

Синтаксис для добавления файлов cookie

browser.cookies.add 'cookiename', 'cookievalue', path: '/', expires: 
(Time.now + 10000), secure: true

пример

require 'watir'
b = Watir::Browser.new :chrome
b.goto 'https://www.tutorialspoint.com'
puts b.cookies.to_a
b.cookies.add 'cookie1', 'testing_cookie', path: '/', expires: 
(Time.now + 10000), secure: true
puts b.cookies.to_a

Вывод перед добавлением cookie

{:name=>"_gat_gtag_UA_232293_6", :value=>"1", :path=>"/", 
:domain=>".tutorialspoint.com", :expires=>2019-05-03 08:44:23 +0000, 
:secure=>false}

{:name=>"_gid", :value=>"GA1.2.1541488984.1556873004", 
:path=>"/", :domain=>".tutorialspoint.com", 
:expires=>2019-05-04 08:43:24 +0000, :secure=>false}

{:name=>"_ga", :value=>"GA1.2.1236163943.1556873004", 
:path=>"/", :domain=>".tutorialspoint.com", 
:expires=>2021-05-02 08:43:24 +0000, :secure=>false}

Вывод После добавления cookie

{:name=>"_gat_gtag_UA_232293_6", :value=>"1", :path=>"/", 
:domain=>".tutorialspoint.com", :expires=>2019-05-03 08:44:23 +0000, 
:secure=>false}

{:name=>"_gid", :value=>"GA1.2.1541488984.1556873004", 
:path=>"/", :domain=>".tutorialspoint.com", 
:expires=>2019-05-04 08:43:24 +0000, :secure=>false}

{:name=>"_ga", :value=>"GA1.2.1236163943.1556873004", 
:path=>"/", :domain=>".tutorialspoint.com", 
:expires=>2021-05-02 08:43:24 +0000, :secure=>false}

{:name=>"cookie1", :value=>"testing_cookie", :path=>"/", 
:domain=>"www.tutorialspoint.com", :expires=>2039-04-28 08:43:35 +0000, 
:secure=>true}

Обратите внимание, что последний - это тот, который мы добавили с помощью watir.

Очистить файлы cookie

Синтаксис

browser.cookies.clear

пример

require 'watir'

b = Watir::Browser.new :chrome
b.goto 'https://www.tutorialspoint.com'
puts b.cookies.to_a
b.cookies.clear
puts b.cookies.to_a

Вывод

{:name=>"_gat_gtag_UA_232293_6", :value=>"1", :path=>"/", 
:domain=>".tutorialspoint.com", :expires=>2019-05-03 08:48:29 +0000, 
:secure=>false}

{:name=>"_gid", :value=>"GA1.2.1264249563.1556873251", 
:path=>"/", :domain=>".tutorialspoint.com", 
:expires=>2019-05-04 08:47:30 +0000, :secure=>false}

{:name=>"_ga", :value=>"GA1.2.1001488637.1556873251", 
:path=>"/", :domain=>".tutorialspoint.com", 
:expires=>2021-05-02 08:47:30 +0000, :secure=>false

Empty response ie a blank line will get printed after cookie.clear is called.

Удалить определенный файл cookie

Синтаксис

browser.cookies.delete 'nameofthecookie'

пример

require 'watir'
b = Watir::Browser.new :chrome
b.goto 'https://www.tutorialspoint.com'
puts b.cookies.to_a
puts b.cookies.delete "_ga"
puts b.cookies.to_a

Вывод

All cookies:
{:name=>"_gat_gtag_UA_232293_6", :value=>"1", :path=>"/", 
:domain=>".tutorialspoint.com", :expires=>2019-05-03 08:52:38 +0000, 
:secure=>false}

{:name=>"_gid", :value=>"GA1.2.1385195240.1556873499", 
:path=>"/", :domain=>".tutorialspoint.com", 
:expires=>2019-05-04 08:51:37 +0000, :secure=>false}

{:name=>"_ga", :value=>"GA1.2.1383421835.1556873499", 
:path=>"/", :domain=>".tutorialspoint.com", 
:expires=>2021-05-02 08:51:37 +0000, :secure=>false}

After delete cookie with name _ga
{:name=>"_gat_gtag_UA_232293_6", 
:value=>"1", :path=>"/", :domain=>".tutorialspoint.com", 
:expires=>2019-05-03 08:52:38 +0000, :secure=>false}

{:name=>"_gid", :value=>"GA1.2.1385195240.1556873499", 
:path=>"/", :domain=>".tutorialspoint.com", 
:expires=>2019-05-04 08:51:37 +0000, :secure=>false}

Watir позволяет использовать прокси с помощью прокси-объекта, который необходимо использовать с браузером.

Синтаксис

proxy = {
   http: '127.0.0.1:8080',
   ssl: '127.0.0.1:8080'
}
b = Watir::Browser.new :chrome, proxy: proxy

Пример использования прокси с браузером Chrome показан ниже -

пример

require "watir"
proxy = {
   http: '127.0.0.1:8080',
   ssl: '127.0.0.1:8080'
}
b = Watir::Browser.new :chrome, proxy: proxy
b.goto 'google.com'
b.screenshot.save 'proxy.png'

Мы использовали прокси-объект, как показано ниже -

proxy = {
   http: '127.0.0.1:8080',
   ssl: '127.0.0.1:8080'
}

Детали адреса прокси должны использоваться как для http, так и для ssl. Мы можем использовать прокси с браузером Chrome, как показано ниже -

b = Watir::Browser.new :chrome, proxy: proxy

Выходной файл proxy.png показан ниже -

Пример использования прокси с браузером Firefox обсуждается ниже -

пример

require "watir"
proxy = {
   http: '127.0.0.1:8080',
   ssl: '127.0.0.1:8080'
}
b = Watir::Browser.new :firefox, proxy: proxy
b.goto 'google.com'
b.screenshot.save 'proxyfirefox.png'

Вы можете добавить детали прокси, как показано ниже -

proxy = {
   http: '127.0.0.1:8080',
   ssl: '127.0.0.1:8080'
}
b = Watir::Browser.new :firefox, proxy: proxy

Выходной файл proxyfirefox.png показан здесь -

В этой главе мы поймем, как обрабатывать предупреждения с помощью Watir.

Синтаксис

browser.alert.exists?
browser.alert.ok
browser.alert.close

Тестовая страница

<html>
   <head>
      <title>Testing Alerts Using Watir</title>
   </head>
   
   <body>
      <script type = "text/javascript">
         function wsformsubmitted() {
            alert("Button is Clicked !");
         }
      </script>
      <button id = "btnsubmit" onclick = "wsformsubmitted();">Submit</button>
   </body>
</html>

Кодекс Ватира

require 'watir'
b = Watir::Browser.new :chrome
b.goto('http://localhost/uitesting/testalert.html')
b.button(id: 'btnsubmit').click
b.alert.ok
b.screenshot.save 'alerttest.png'

Выходной файл alerttest.png показан здесь -

У нас есть кнопки или ссылки в пользовательском интерфейсе или на нашем веб-сайте, который загружает PDF-файл или документ. Мы можем протестировать это для использования с Watir, указав некоторые настройки браузеру.

Синтаксис для скачивания -

prefs = {
   'download' => {
      'default_directory' => "C:/download",
      'prompt_for_download' => false,
   }
}
b = Watir::Browser.new :chrome, options: {prefs: prefs}

У prefs есть загрузка, в которой нам нужно указать путь, по которому мы хотим, чтобы файл был сохранен после загрузки, и то же самое должно быть указано в браузерах с использованием параметров, как показано в синтаксисе выше.

Здесь показан рабочий пример. Здесь мы создали тестовую страницу с кнопкой, при нажатии на которую будет загружен файл с именем file.txt, как показано ниже -

<html>
   <head>
      <title>Testing UI using Watir</title>
   </head>
   
   <body>
      <br/>
      <br/>
      <button id = "btnsubmit">
         <a href = "file.txt" download>Click to Download!</a>
      </button>
      <br/>
   </body>
</html>

file.txt

This is for testing watir download

Вывод

Когда вы нажимаете кнопку загрузки, файл загружается.

Теперь давайте протестируем то же самое с помощью Watir -

require 'watir'
prefs = {
   'download' => {
      'default_directory' => "C:/download",
      'prompt_for_download' => false,
   }
}
b = Watir::Browser.new :chrome, options: {prefs: prefs}
b.goto('http://localhost/uitesting/filedownload.html')
b.button(id: 'btnsubmit').click
b.screenshot.save 'testdownload.png'

Путь, который мы указали для сохранения загруженного файла, - «C: / download». Когда мы выполним приведенный выше код, у нас будет загрузка файла по пути загрузки, как показано ниже -

Выходной файл testdownload.png показан здесь -

Вы встретите случаи, когда нам нужно использовать всплывающее окно или открытие нового окна браузера. В этой главе мы обсудим, как тестировать такие случаи с помощью Watir.

Синтаксис

browser.window

Вот рабочий пример, который мы собираемся протестировать -

<html>
   <head>
      <title>Testing UI using Watir</title>
   </head>
   
   <body>
      <script type = "text/javascript">
         function wsclick() {
            var myWindow = window.open(
               "https://www.google.com/", "mywindow", "width = 1000,height = 500");
         }
      </script>
      
      <form name = "myform" method = "POST">
         <div>
            <br>
            <input type = "button" id = "btnsubmit" name = "btnsubmit" value = "submit" onclick = "wsclick()"/>
            <br>
         </div>
      </form>
      <br/>
   </body>
</html>

Вывод

При нажатии кнопки «Открыть окно» открывается всплывающее окно. Здесь указан адрес www.google.com . Теперь давайте протестируем то же самое с помощью Watir /

пример

require 'watir'
b = Watir::Browser.new :chrome
b.goto('http://localhost/uitesting/windowpopup.html')
b.button(id: 'btnsubmit').click
b.window(title: 'Google').use do
   b.screenshot.save 'popupwindow.png'
   t = b.text_field(class: 'gLFyf')
   t.set 'Watir'
   b.screenshot.save 'popupwindowbefore.png'
   b.button(name: 'btnK').click
   b.screenshot.save 'popupwindowafter.png'
end

Снимки экрана, которые мы сделали, приведены ниже -

popupwindow.png

popupwindowbefore.png

popupwindowafter.png