Watir - Szybki przewodnik
Watir (testowanie aplikacji internetowych w języku Ruby), wymawiane jako „woda”, jest narzędziem typu open source opracowanym przy użyciu języka Ruby, które pomaga w automatyzacji aplikacji internetowych, które pasują do aplikacji tworzonych w dowolnym języku programowania. Przeglądarki obsługiwane podczas instalacji Watir: Internet Explorer, Firefox, Chrome, Safari i Edge. Watir jest dostępny jako Rubygems do instalacji.
Watir połączy się z podaną przeglądarką i postępuje zgodnie z instrukcjami otwierania adresu URL, klikania przycisku, wprowadzania danych w polu tekstowym, tak jak zrobi to każda prawdziwa osoba. Watir jest najczęściej używany do obsługi przeglądarek z platformami testowymi, takimi jak RSpec, Cucumber itp.
Funkcje Watir
Watir jest bogaty w funkcje, o których mowa poniżej -
Location web elements- Istnieją różne sposoby lokalizowania elementów sieci Web renderowanych w przeglądarce. Najczęściej używane to identyfikator, klasa, nazwa tagu, atrybuty niestandardowe, etykieta itp.
Taking Screenshots- Watir umożliwia wykonanie zrzutu ekranu z testów wykonanych w razie potrzeby. Pomaga to śledzić testy pośrednie.
Page Performance- Możesz łatwo zmierzyć wydajność strony za pomocą obiektu wydajności, który ma właściwości takie jak performance.navigation, performance.timing, performance.memory i performance.timeOrigin . Te dane są uzyskiwane podczas łączenia się z przeglądarką.
Page Objects- Obiekt strony w Watir pomoże nam ponownie wykorzystać kod w postaci klas. Korzystając z tej funkcji, możemy zautomatyzować naszą aplikację bez konieczności duplikowania kodu, a także umożliwić jej zarządzanie.
Downloads - Dzięki Watir łatwo jest przetestować pobieranie plików dla interfejsu użytkownika lub witryny internetowej.
Alerts - Watir zapewnia łatwe w użyciu interfejsy API do testowania wyskakujących alertów w interfejsie użytkownika lub na stronie internetowej.
Headless Testing- Korzystając z testów bezgłowych, szczegóły są pobierane w wierszu poleceń bez konieczności otwierania przeglądarki. Pomaga to w wykonywaniu przypadków testowych interfejsu użytkownika w wierszu poleceń.
Zalety korzystania z Watir
Watir oferuje następujące korzyści -
Watir jest narzędziem open source i bardzo łatwym w użyciu.
Watir został opracowany w języku Ruby, a każdą aplikację internetową działającą w przeglądarce można łatwo zautomatyzować za pomocą tego narzędzia.
Watir obsługuje wszystkie najnowsze przeglądarki, co ułatwia testowanie.
Watir ma wbudowane biblioteki do testowania wydajności strony, alertów, testowania ramek iframe, okien przeglądarki, robienia zrzutów ekranu itp.
Wady Watira
Jak każde inne oprogramowanie, Watir również ma swoje ograniczenia
Watir jest obsługiwany tylko dla frameworka testowego Ruby i nie może być używany z żadnymi innymi frameworkami testowymi.
Testowanie mobilne przy użyciu Watir nie jest ulepszone, a przeglądarki komputerowe są naśladowane tak, aby zachowywały się jak przeglądarki mobilne, zamiast działać jako urządzenia czasu rzeczywistego.
Watir (Web Application Testing in Ruby)wymawiane jako „Woda” to narzędzie typu open source opracowane przy użyciu języka Ruby, które pomaga w automatyzacji aplikacji internetowych bez względu na język, w którym jest napisana. Watir jest wyposażony w bogaty zestaw interfejsów API, które pomagają nam wchodzić w interakcję z przeglądarką, lokalizować elementy strony, robić zrzuty ekranu, pracować z alertami, pobierać pliki, otwierać wyskakujące okienka window.open , testować bezgłowy itp.
Obsługiwane przeglądarki to -
- Internet Explorer
- Firefox
- Chrome
- Safari
- Edge
Note - Watir jest dostępny jako klejnot Rubygems do instalacji.
Korzystając z Webdriver Watir, możesz testować swoje strony internetowe i aplikacje interfejsu użytkownika. Ponieważ Watir w pełni koncentruje się na kwestiach związanych z przeglądarką, możesz używać Watir wraz z innymi platformami testowymi, takimi jak -
- RSpec
- Cucumber
Główny kod testowy zostanie napisany przy użyciu frameworka testowego, a interakcja z przeglądarką będzie odbywać się z pomocą Watira.
Przepływ frameworka testowego wraz z Watir jest pokazany poniżej -
RSpec lub Cucumber są zaangażowani w program uruchamiający testy i kod testowy. Szczegóły dotyczące testowania strony internetowej lub interfejsu użytkownika można podzielić na obiekt strony, który będzie miał odniesienie do Watir, w którym otrzyma lokalizatory stron używane do testowania. Watir wraz ze swoim webdriverem pomaga w łączeniu się z przeglądarką i przeprowadzaniu automatyzacji testów.
Aby pracować z Watir, musimy zainstalować następujące elementy -
- Zainstaluj Rubiego
- Zainstaluj Watir
- Kopalnia Rubinów (IDE)
Ponieważ Watir jest zbudowany przy użyciu Rubiego, musimy zainstalować Rubiego i gem (menedżera pakietów dla Rubiego).
Instalacja Rubiego w systemie Windows
Aby zainstalować Ruby w systemie Windows, przejdź do - https://rubyinstaller.org/downloads/
Zainstaluj wersję ruby opartą na 32- lub 64-bitowym systemie operacyjnym. Tutaj zainstalowaliśmy podświetlony, jak pokazano na zrzucie ekranu. Po pobraniu postępuj zgodnie z wyświetlanymi instrukcjami i odpowiednio zainstaluj.
Po zakończeniu instalacji sprawdź, czy Ruby jest zainstalowany, sprawdzając wersję w wierszu poleceń, jak pokazano poniżej -
C:\> ruby -v
Jeśli Ruby został pomyślnie zainstalowany, możesz zobaczyć dane wyjściowe, jak pokazano poniżej -
Zainstalowana wersja to 2.6.3. Pomyślnie zainstalowaliśmy Rubiego w naszym systemie. Wraz z gemem instalacyjnym Ruby instalowany jest również menedżer pakietów Ruby. Możesz sprawdzić zainstalowaną wersję gem w następujący sposób -
Skończyliśmy z instalacją Ruby i Gem w systemie Windows.
Instalacja Rubiego w systemie Linux
Aby zainstalować Ruby w systemie Linux, uruchom następujące polecenia w terminalu 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
Instalacja Rubiego dla komputerów Mac
Aby zainstalować Ruby w systemie Linux, uruchom poniższe polecenia w terminalu Mac -
Zainstaluj xcode
xcode-select --install
Zainstaluj HomeBrew
/usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
Zainstaluj 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
Instalowanie Watir
Polecenie do zainstalowania watira to -
gem install watir
gem install watir
Następnie możesz zobaczyć ekran wyjściowy, jak pokazano poniżej -
RubyMine IDE
Będziemy używać RubyMine IDE do pisania i wykonywania naszych przypadków testowych. Oficjalna strona RubyMine IDE to www.jetbrains.com/ruby .
RubyMine to płatne IDE z 30-dniowym bezpłatnym okresem próbnym. Kliknij przycisk bezpłatnej wersji próbnej, aby pobrać. Możesz także użyć innego, wybranego przez siebie środowiska IDE, do napisania przypadków testowych.
Po kliknięciu przycisku bezpłatnej wersji próbnej rozpocznie się pobieranie. Po zakończeniu pobierania zainstaluj go w swoim systemie.
Kliknij Dalej i kontynuuj instalację. Po zakończeniu instalacji otwórz IDE i poprosi o utworzenie projektu, jak pokazano poniżej -
Kliknij Utwórz nowy projekt, wpisaliśmy nazwę projektu jako Watir i tutaj jest wyświetlacz w IDE -
Napiszemy nasze przypadki testowe w watir / folder i wykonamy je.
W tym rozdziale zainstalujemy sterowniki przeglądarki potrzebne do przetestowania naszego projektu za pomocą Watir. Przed Watir 6 musieliśmy dołączyć watir-webdriver, aby korzystać ze sterowników przeglądarki. Wraz z wydaniem Watir 6, watir-webdriver jest dostępny jako część pakietu Watir i użytkownicy nie muszą osobno dodawać watir-webdriver .
Przeglądarki takie jak Chrome, Firefox i Safari są dostępne domyślnie i nie musisz ich dodawać zewnętrznie. Jeśli podczas testów pojawi się problem polegający na tym, że sterownik przeglądarki nie jest dostępny, zawsze możesz go pobrać zgodnie z instrukcją poniżej.
Zamierzamy zainstalować sterowniki dla następujących przeglądarek -
- Sterownik dla przeglądarek - Chrome
- Sterownik dla przeglądarek - Firefox
- Sterownik dla przeglądarek - Edge
- Sterownik dla przeglądarek - Internet Explorer
- Sterownik dla przeglądarek - Safari
Sterownik przeglądarki - Chrome
Aby pobrać sterownik do przeglądarki Chrome, przejdź do - https://sites.google.com/a/chromium.org/chromedriver/downloads.
Sprawdź wersję swojej przeglądarki i odpowiednio pobierz sterownik Chrome. Aby sprawdzić wersję swojej przeglądarki Chrome, wykonaj poniższe czynności -
Kliknij O Google Chrome, a otrzymasz wersję Chrome, jak pokazano poniżej -
Więc nasza wersja to 74. Więc pobierz sterownik Chrome w wersji 74.
Następnie pobierz sterownik chrome w zależności od systemu operacyjnego. Pobieramy chromedriver_win32.zip, jest on przeznaczony zarówno dla komputerów 32-bitowych, jak i 64-bitowych. Jeśli planujesz użyć pobranego sterownika, dodaj lokalizację gdzieś w zmiennej PATH.
Sterownik przeglądarki - Firefox
W przypadku sterownika Firefox przejdź do - https://github.com/mozilla/geckodriver/releases jak pokazano na zrzucie ekranu poniżej -
Zgodnie z systemem operacyjnym pobierz sterownik, jak pokazano powyżej. Jeśli planujesz użyć pobranego sterownika, dodaj lokalizację gdzieś w zmiennej PATH.
Sterownik przeglądarki - Edge
W przypadku sterownika Firefox przejdź do - https://developer.microsoft.com/en-us/microsoft-edge/tools/webdriver/ jak pokazano na zrzucie ekranu poniżej -
Kliknij posiadaną wersję Microsoft Edge, jak pokazano poniżej -
Kliknij link Zwolnij, a przekieruje Cię do -
Tutaj możesz znaleźć wersję do pobrania dostępną dla systemu Windows. Jeśli planujesz użyć pobranego sterownika, dodaj lokalizację gdzieś w zmiennej PATH.
Sterownik przeglądarki - Internet Explorer
Aby zainstalować sterownik dla przeglądarki Internet Explorer, przejdź do - https://docs.seleniumhq.org/download/ jak pokazano poniżej -
Szczegóły dotyczące sekcji pobierania w IE są pokazane tutaj -
Zgodnie z systemem operacyjnym pobierz 32- lub 64-bitową wersję IE dla systemu Windows. Dodaj również lokalizację do zmiennej PATH, aby użyć sterownika.
Sterowniki do przeglądarek - Safari
Sterowniki Safari nie muszą być pobierane zewnętrznie dla Safari w wersji 10 i nowszych. Są one pobierane wraz z pakietem gem podczas instalacji Watir.
Należy pamiętać, że sterowniki dla przeglądarki Chrome, Firefox, Internet Explorer są również dostępne po zainstalowaniu Watir. Jeśli jednak napotkasz jakiekolwiek problemy i potrzebujesz określonej wersji do przetestowania, możesz pobrać je zgodnie z przeglądarką i zaktualizować lokalizację w PATH, aby wykorzystać ją do testowania aplikacji.
Domyślnie Watir otworzy przeglądarkę chrome na wypadek, gdyby nazwa przeglądarki nie została określona. Wymagane sterowniki przeglądarki są instalowane wraz z instalacją Watir. Jeśli napotkasz jakiekolwiek problemy podczas pracy z przeglądarkami, zainstaluj sterownik, jak pokazano w rozdziale Sterowniki przeglądarek i zaktualizuj lokalizację w zmiennej PATH.
W tym rozdziale dowiemy się, jak otworzyć przeglądarkę za pomocą Watir.
Kroki, aby otworzyć przeglądarkę za pomocą Watir
Otwórz IDE RubyMine i utwórz nowy plik: test1.rb
Wybierz OK i kliknij wzór pliku jako rubinowy, jak pokazano poniżej -
Kliknij OK, aby utworzyć plik.
Teraz napiszemy prosty kod, który otworzy przeglądarkę, jak pokazano poniżej -
test1.rb
require 'watir'
Watir::Browser.new
Kliknij przycisk Uruchom, który jest podświetlony w środowisku IDE, jak pokazano powyżej. Po kliknięciu Uruchom otworzy przeglądarkę, jak pokazano poniżej -
Przeglądarka otworzy się i zamknie automatycznie. Dodajmy teraz trochę więcej kodu do pliku test1.rb.
Możemy określić nazwę przeglądarki, jak pokazano poniżej -
Przykład dla Chrome
require 'watir'
Watir::Browser.new :chrome
Teraz otwórzmy URL strony w naszym przypadku testowym.
Przykład
require 'watir'
browser = Watir::Browser.new
browser.goto("https://www.google.com")
Kliknij Uruchom, aby zobaczyć dane wyjściowe, jak pokazano poniżej -
Podobnie możesz otworzyć przeglądarkę Firefox, Safari, Internet Explorer.
Przykład dla przeglądarki Firefox
require 'watir'
Watir::Browser.new :firefox
Przykład dla przeglądarki Internet Explorer
Watir Code
require 'watir'
browser = Watir::Browser.new :ie
browser.goto("https://www.google.com")
Po uruchomieniu kodu wyświetlany jest następujący błąd -
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.
Oznacza to, że pakiet Watir nie ma sterownika InternetExplorer. Pobraliśmy to samo stąd -https://docs.seleniumhq.org/download/ i zaktualizowane w zmiennej PATH.
Teraz uruchom go ponownie, aby zobaczyć, jak przeglądarka Internet Explorer otwiera się, jak pokazano poniżej -
Kod Watir, aby otworzyć przeglądarkę Safari
require 'watir'
browser = Watir::Browser.new :safari
browser.goto("https://www.google.com")
Kod Watir do przeglądarki Microsoft Edge
require 'watir'
browser = Watir::Browser.new :edge
browser.goto("https://www.google.com")
W tym rozdziale omówimy, jak pracować z obserwowaniem w Watir -
- Praca z polami tekstowymi
- Praca z kombinacjami
- Praca z przyciskami radiowymi
- Praca z polami wyboru
- Praca z przyciskami
- Praca z linkami
- Praca z Div's
Praca z polami tekstowymi
Składnia
browser.text_field id: 'firstname' // will get the reference of the textbox
Tutaj spróbuję zrozumieć, jak pracować z polami tekstowymi w interfejsie użytkownika.
Rozważ stronę Textbox.html, jak pokazano poniżej -
<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>
Odpowiednie wyjście jest pokazane poniżej -
Mamy pole tekstowe, po wpisaniu nazwy onchange zdarzenie jest uruchamiane i nazwa jest wyświetlana poniżej.
Teraz napiszmy kod, w którym zlokalizujemy pole tekstowe, wpiszemy nazwę i uruchomimy zdarzenie onchange.
Watir Code
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')
Używamy przeglądarki Chrome i podaliśmy pageurl jako http://localhost/uitesting/textbox.html.
Użycie przeglądarki goto api otworzy pageurl i znajdziemy pole tekstowe o id: imię. Jeśli tak, ustawimy wartość jako Riya Kapoor i użyjemy interfejsu API fire_event do uruchomienia zdarzenia onchange.
Teraz uruchommy kod, aby wyświetlić dane wyjściowe, jak pokazano poniżej -
Praca z kombinacjami
Składnia
browser.select_list id: 'months' // will get the reference of the dropdown
Strona testowa, którą teraz przetestujemy, jest pokazana tutaj -
<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>
Wynik
Po wybraniu miesiąca z listy rozwijanej to samo zostanie wyświetlone poniżej.
Przetestujmy teraz to samo za pomocą Watira.
Watir Code do wyboru combo
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')
Aby pracować z kombinacjami, musisz zlokalizować wybrany element za pomocą b.select_list api, a następnie id z listy rozwijanej. Aby wybrać wartość z listy rozwijanej, musisz użyć t.select i żądanej wartości.
Dane wyjściowe podczas wykonywania są następujące -
Praca z przyciskami radiowymi
Składnia
browser.radio value: 'female'
// will get the reference of the radio button with value “female”
Oto strona testowa, której będziemy używać do pracy z przyciskami radiowymi -
<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>
Wybierzemy przycisk radiowy o wartości Kobieta, jak pokazano w kodzie Watira -
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'
Aby pracować z przyciskiem radiowym, musimy poinformować przeglądarkę o wartości, którą wybieramy, tj b.radio value:”female”
Robimy również zrzut ekranu i zapisujemy go jako radiobutton.png i to samo jest wyświetlane poniżej -
Praca z polami wyboru
Składnia
browser. checkbox value: 'Train'
// will get the reference of the checkbox with value “Train”
Oto strona testowa dla pól wyboru -
<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>
Teraz użyjmy Watir, aby zlokalizować pole wyboru w przeglądarce, jak pokazano poniżej -
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'
Aby zlokalizować pole wyboru w przeglądarce, użyj b. Pola wyboru z wartością, którą chcesz wybrać.
Praca z przyciskami
Składnia
browser.button(:name => "btnsubmit").click
// will get the reference to the button element with has name “btnsubmit”
Oto strona testowa przycisku -
<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>
Oto kod watir do zlokalizowania przycisku na danej stronie -
require 'watir'
b = Watir::Browser.new
b.goto('http://localhost/uitesting/button.html')
b.button(:name => "btnsubmit").click
b.screenshot.save 'button.png'
Oto zrzut ekranu button.png
Praca z linkami
Składnia
browser.link text: 'Click Here'
// will get the reference to the a tag with text ‘Click Here’
Zamierzamy użyć następującej strony testowej do testowania linków -
<html>
<head>
<title>Testing UI using Watir</title>
</head>
<body>
<br/>
<br/>
<a href = "https://www.google.com">Click Here</a>
<br/>
</body>
</html>
Dane Watir wymagane do testowania łączy podano poniżej -
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'
Wynik
Praca z Div's
Składnia
browser.div class: 'divtag'
// will get the reference to div with class “divtag”
Strona testowa, na której możemy przetestować 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>
Wynik
Kod Watir do testowania div jest pokazany tutaj -
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'
Wynik
W Watir do testowania musisz zlokalizować elementy i można to zrobić na różne sposoby - używając id, class lub text elementu.
W tym rozdziale zobaczymy kilka przykładów, które pokazują różne sposoby lokalizowania elementów.
Korzystanie z identyfikatora elementu
Strona testowa
<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>
Przykład
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'
W tym przykładzie używamy id elementu textbox, aby go zlokalizować i ustawić wartość.
t = b.text_field(id: 'firstname')
Wynik
Jeśli chcesz zlokalizować div, span lub inny znacznik HTML, możesz zrobić to samo za pomocą id w następujący sposób -
Dla div
browser.div(id: "divid")
browser.div(id: /divid/)
Na rozpiętość
browser.span(id: "spanid")
browser.span(id: /spanid/)
Używając NAZWY elementu
Strona testowa
<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>
Przykład
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'
Wynik
Korzystanie z nazwy tagu
Możesz zlokalizować dowolne elementy html bezpośrednio za pomocą tagu html, jak pokazano poniżej.
Dla div
browser.div(id: "divid")
browser.div(id: /divid/)
Na rozpiętość
browser.span(id: "spanid")
browser.span(id: /spanid/)
Dla tagu p
browser.p(id: "ptag")
browser.p(id: /ptag/)
Na przycisk
browser.button(id: "btnid")
browser.button(id: /btnid/)
Korzystanie z nazwy klasy
Możesz zlokalizować element, używając jego nazwy klasy. Można to zrobić, jak pokazano poniżej -
Dla div
browser.div(class: "divclassname")
browser.div(class: /divclassname/)
Na rozpiętość
browser.span(class: "spanclassname”)
browser.span(class: /spanclassname/)
Dla tagu p
browser.p(class: "pclassname")
browser.p(class: /pclassname/)
Na przycisk
browser.button(class: "btnclassname")
browser.button(class: /btnclassname/)
Do pola tekstowego
browser.text_field(class: 'txtclassname')
browser.text_field(class: /txtclassname/)
Możesz również przejść wiele zajęć, jak pokazano poniżej -
Dla div
browser.div(class: ["class1", "class2"])
Korzystanie z tekstu
To kolejny sposób na lokalizowanie elementów przy użyciu elementów z tekstem. Na przykład -
browser.button(text: "button text")
browser.button(text: /button text/)
Korzystanie z etykiety
Możesz użyć etykiety elementu, aby go zlokalizować, jak pokazano poniżej -
browser.text_field(label: "text here"))
browser.text_field(label: /text here/))
Korzystanie z atrybutów danych
W przypadku, gdy masz atrybuty danych w tagach HTML, możesz zlokalizować elementy, używając ich, jak pokazano poniżej -
Na przykład możesz zlokalizować tag, jak pokazano poniżej -
<div data-type = "test1"></div>
Możesz zlokalizować element div w następujący sposób -
browser.div(data-type: 'test1'))
browser.div(data-type: /test1/))
Korzystanie z atrybutów niestandardowych
Możesz również zlokalizować elementy za pomocą atrybutów niestandardowych, jak pokazano poniżej -
Przykład elementu html
<div itemprop = ”content”>
….
</div>
Możesz zlokalizować element div w następujący sposób -
browser.div(itemprop: ‘content'))
browser.div(itemprop: /content/))
Korzystanie z widocznego atrybutu
Element wykorzystujący widoczny atrybut można zlokalizować, jak pokazano poniżej -
browser.div(visible: true)
browser.div(visible: false)
Watir oferuje łatwą w użyciu składnię do pracy z ramkami iframe.
Składnia
browser.iframe(id: 'myiframe')
// will get the reference of the iframe where we want to input details.
Aby zrozumieć, jak radzić sobie z ramkami iframe i lokalizować elementy wewnątrz iframe, w tym rozdziale zajmiemy się przykładem.
Przykład
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>
Wynik
W powyższym przykładzie formularz wejściowy jest zdefiniowany wewnątrz elementu iframe. Kod Watir, który pomoże nam go zlokalizować i przetestować formularz jest podany poniżej -
Watir Code
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'
Kod Watira do zlokalizowania elementu iframe w podanym tutaj adresie URL -
t = b.iframe(id: 'myiframe').text_field
Użyliśmy nazwy tagu iframe i identyfikatora iframe, jak pokazano powyżej.
Zrzuty ekranu powyższego kodu pokazano poniżej -
iframetestbefore.png
iframetestafter.png
W tym rozdziale wyjaśnijmy szczegółowo, że czeka. Aby zrozumieć automatyczne oczekiwanie, stworzyliśmy prostą stronę testową. Kiedy użytkownik wpisze tekst w polu tekstowym, zdarzenie onchange jest uruchamiane i po 3 sekundach przycisk jest aktywny.
Watir ma wywołanie interfejsu API wait_unit, które oczekuje na określone zdarzenie lub właściwość. Przetestujemy to samo dla strony testowej, jak podano poniżej -
Składnia
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>
Wynik
Po wpisaniu tekstu w polu tekstowym będziesz musiał poczekać 3 sekundy na aktywację przycisku.
Po kliknięciu przycisku Prześlij zostanie wyświetlony następujący tekst -
Ponieważ dodaliśmy opóźnienie aktywacji przycisku, automatyzacja ma trudności z obsługą takich przypadków. Ilekroć mamy jakieś opóźnienie lub musimy czekać na jakieś zdarzenie lub właściwość elementu do zlokalizowania, możemy skorzystać z wait_until, jak pokazano poniżej -
Kod Watir za pomocą 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'
Następnie użyj następującego polecenia
btn = b.button(id: 'btnsubmit').wait_until(&:enabled?)
Watir będzie czekał, aż przycisk zostanie włączony, a później uruchomi zdarzenie kliknięcia. Przechwycone zrzuty ekranu pokazano poniżej -
Waittestbefore.png
waittestafter.png
W tym rozdziale dowiemy się, jak używać opcji headless webdrivera Watir do testowania adresu URL strony.
Składnia
Browser = Watir::Browser.new :chrome, headless: true
Strona testowa, którą zamierzamy przetestować, jest pokazana tutaj -
<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>
Wynik
Kod Watira
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'
Dodaliśmy opcję bez głowy : true do przeglądarki Chrome Watir. Kiedy uruchomisz program Ruby, nie otworzy on przeglądarki, wszystko zostanie wykonane w linii poleceń -
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)
Dodaliśmy komunikat console.log i to samo w linii poleceń.
Zrzut ekranu z headless.png pokazano poniżej -
W przeglądarce Firefox
Kod Watir dla przeglądarki Firefox jest pokazany tutaj -
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'
Zrzut ekranu dla headlessfirefox.png jest pokazany tutaj -
Do testów mobilnych będziemy używać przeglądarki na komputery stacjonarne, która będzie działać jako przeglądarka urządzenia do celów testowych. Rozumiemy jego procedurę w tym rozdziale.
Aby przetestować Twoją aplikację w przeglądarkach mobilnych, musimy zainstalować webdriver-user-agent.
Instalowanie webdriver-user-agent
gem install webdriver-user-agent
Teraz użyjemy agenta użytkownika Webdriver, jak pokazano w poniższym przykładzie -
Przykład
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/'
Podaliśmy adres facebook.com. Po uruchomieniu otwiera się w trybie mobilnym, na podstawie agenta użytkownika, jak pokazano poniżej -
Spróbujmy teraz w trybie portretowym. W tym celu użyj następującego kodu -
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/'
Wyjście w trybie portretowym jest takie, jak pokazano poniżej -
Możliwość robienia zrzutów ekranu to jedna z interesujących funkcji dostępnych w Watir. Podczas automatyzacji testów możesz robić zrzuty ekranu i zapisywać ekrany. W przypadku wystąpienia błędu można to udokumentować za pomocą zrzutu ekranu.
Prosty przykład wraz ze stroną testową, na której zrobiliśmy zrzut ekranu, omówiono poniżej -
Składnia
browser.screenshot.save 'nameofimage.png'
Strona testowa
<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>
Przykład
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'
Zrzuty ekranu, które zrobiliśmy za pomocą Watir, są pokazane tutaj -
textboxbefore.png
textboxafter.png
Obiekt strony w Watir pomaga nam ponownie wykorzystać kod w postaci klas. Korzystając z funkcji obiektu strony, możemy zautomatyzować naszą aplikację bez konieczności duplikowania kodu, a także sprawić, że kod jest łatwy do zarządzania.
Podczas testowania możemy utworzyć obiekt strony dla każdej strony, którą będziemy testować. Następnie uzyskamy dostęp do metod i właściwości za pomocą obiektu strony.
Powody używania obiektu strony -
W przypadku jakichkolwiek zmian na stronie przy zmianie zmian, ponowne pisanie kodu nie jest potrzebne.
Aby uniknąć redundancji kodu.
Zamierzamy użyć RSpec do wykorzystania obiektu strony w Watir. Jeśli nie jesteś zaznajomiony z RSpec, tutaj jest pełny samouczek dostępny dla RSpec do nauki.
Strona, na której zamierzamy przeprowadzić test, jest podana tutaj -
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>
Wynik
Teraz utworzymy obiekt strony dla powyższej strony, jak pokazano poniżej -
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
Istnieją trzy zdefiniowane klasy - InitializeBrowser, TestPage i TestTextbox -
InitializeBrowser - Spowoduje to zainicjowanie otwartej przeglądarki i udostępnienie obiektu przeglądarki klasom TestPage i TestTextbox.
TestPage - Ta klasa będzie miała odniesienie do obiektu do TestTextbox i zawiera metodę przechwytywania zrzutu ekranu i zamykania przeglądarki.
TestTextbox - Ta klasa będzie miała metody do otwierania adresu URL strony, podawania odniesienia do pola tekstowego, ustawiania danych i uruchamiania zdarzenia onchange.
Po wykonaniu kodu pokazanego powyżej możesz zobaczyć dane wyjściowe, jak pokazano poniżej -
Funkcja Watir Page Performance pozwala na śledzenie metryk czasu odpowiedzi i działa dobrze w Chrome, Firefox, IE9 i nowszych. Przeglądarka Safari nie ma obecnie obsługi.
Przyjrzyjmy się bliżej, jak korzystać z tej funkcji. Aby z tego skorzystać, musimy zainstalować wydajność watir za pomocą gem, jak pokazano poniżej -
Komenda
gem install watir-performance
Skończyliśmy z instalacją wydajności wody. Obsługiwane dane to -
- summary
- navigation
- memory
- Timing
W tym miejscu omówiono działający przykład wykorzystujący wydajność watira. Tutaj sprawdzimy czas odpowiedzi witryny - www.tutorialspoint.com, jak pokazano poniżej -
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
wynik
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.
Korzystanie z 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
wynik
Time taken to respond is 41 seconds.
Korzystanie z 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
wynik
{:type_back_forward=>2, :type_navigate=>0, :type_reload=>1,
:type_reserved=>255, :redirect_count=>0, :to_json=>{}, :type=>0}
Korzystanie z 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
wynik
{: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}
W tym rozdziale dowiemy się, jak pracować z plikami cookie za pomocą Watir.
Tutaj omówiono prosty przykład, który pobierze pliki cookie dla podanego adresu URL.
Składnia do pobierania plików cookie
browser.cookies.to_a
Przykład
require 'watir'
b = Watir::Browser.new :chrome
b.goto 'https://www.tutorialspoint.com'
puts b.cookies.to_a
Wynik
{: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}
Teraz dodajmy pliki cookie, jak pokazano poniżej -
Składnia dodawania plików cookie
browser.cookies.add 'cookiename', 'cookievalue', path: '/', expires:
(Time.now + 10000), secure: true
Przykład
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
Dane wyjściowe przed dodaniem pliku 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}
Wyjście Po dodaniu pliku 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}
Zwróć uwagę, że ostatnia to ta, którą dodaliśmy za pomocą watir.
Usuń pliki cookie
Składnia
browser.cookies.clear
Przykład
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
Wynik
{: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.
Usuń określony plik cookie
Składnia
browser.cookies.delete 'nameofthecookie'
Przykład
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
Wynik
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 pozwala na korzystanie z proxy za pomocą obiektu proxy, który musi być używany z przeglądarką.
Składnia
proxy = {
http: '127.0.0.1:8080',
ssl: '127.0.0.1:8080'
}
b = Watir::Browser.new :chrome, proxy: proxy
Przykład korzystania z serwera proxy w przeglądarce Chrome pokazano poniżej -
Przykład
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'
Użyliśmy obiektu proxy, jak pokazano poniżej -
proxy = {
http: '127.0.0.1:8080',
ssl: '127.0.0.1:8080'
}
Szczegóły adresu proxy mają być używane zarówno dla protokołu http, jak i ssl. Możemy używać proxy z przeglądarką chrome, jak pokazano poniżej -
b = Watir::Browser.new :chrome, proxy: proxy
Wyjście proxy.png pokazano poniżej -
Przykład korzystania z serwera proxy w przeglądarce Firefox omówiono poniżej -
Przykład
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'
Możesz dodać szczegóły serwera proxy, jak pokazano poniżej -
proxy = {
http: '127.0.0.1:8080',
ssl: '127.0.0.1:8080'
}
b = Watir::Browser.new :firefox, proxy: proxy
Tutaj pokazane jest wyjście proxyfirefox.png -
W tym rozdziale dowiemy się, jak postępować z alertami za pomocą Watir.
Składnia
browser.alert.exists?
browser.alert.ok
browser.alert.close
Strona testowa
<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>
Watir Code
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'
Tutaj pokazane jest wyjście alerttest.png -
Mamy przyciski lub linki w interfejsie użytkownika lub w naszej witrynie internetowej, które umożliwiają pobranie pliku PDF lub dokumentu. Możemy to przetestować pod kątem korzystania z Watir, podając pewne preferencje przeglądarce.
Składnia pobierania -
prefs = {
'download' => {
'default_directory' => "C:/download",
'prompt_for_download' => false,
}
}
b = Watir::Browser.new :chrome, options: {prefs: prefs}
Preferencje obejmują pobieranie, w którym musimy podać ścieżkę, w której chcemy, aby plik był przechowywany po pobraniu, i to samo należy podać przeglądarkom za pomocą opcji przedstawionych w powyższej składni.
Tutaj pokazano działający przykład. Tutaj stworzyliśmy stronę testową z przyciskiem, którego kliknięcie spowoduje pobranie pliku o nazwie file.txt, jak pokazano poniżej -
<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>
plik.txt
This is for testing watir download
Wynik
Po kliknięciu przycisku pobierania plik zostanie pobrany.
Teraz przetestujmy to samo za pomocą 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'
Podana przez nas ścieżka przechowywania pobranego pliku to „C: / download”. Kiedy wykonamy powyższy kod, pobierzemy plik w ścieżce pobierania podanej jak pokazano poniżej -
Wyjście testdownload.png jest pokazane tutaj -
Napotkasz przypadki, w których musimy użyć wyskakującego okienka lub otwarcia nowego okna przeglądarki. W tym rozdziale omówimy, jak przetestować takie przypadki za pomocą Watir.
Składnia
browser.window
Oto działający przykład, który zamierzamy przetestować -
<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>
Wynik
Kliknięcie przycisku Otwórz okno powoduje otwarcie wyskakującego okienka. Tutaj podany przez nas adres URL to www.google.com . Teraz przetestujmy to samo za pomocą Watir /
Przykład
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
Zrzuty ekranu, które zrobiliśmy, podano poniżej -