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;">l;
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
Снимки экрана, которые мы сделали, приведены ниже -