Watir - Penantian Otomatis

Dalam bab ini, mari kita pahami menunggu secara detail. Untuk memahami penantian otomatis, kami telah membuat halaman pengujian sederhana. Ketika pengguna memasukkan teks dalam acara onchange kotak teks diaktifkan dan setelah 3-detik tombol diaktifkan.

Watir memiliki panggilan api wait_unit yang menunggu di acara atau properti tertentu. Kami akan menguji hal yang sama untuk halaman pengujian seperti yang diberikan di bawah ini -

Sintaksis

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

testwait.html

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

Keluaran

Saat Anda memasukkan teks ke dalam kotak teks, Anda harus menunggu selama 3 detik hingga tombol tersebut diaktifkan.

Saat Anda mengklik tombol Kirim, teks berikut akan ditampilkan -

Sekarang karena kami telah menambahkan penundaan untuk tombol yang akan diaktifkan, sulit bagi otomatisasi untuk menangani kasus seperti itu. Setiap kali kita mengalami penundaan atau harus menunggu pada beberapa kejadian atau properti elemen yang akan ditemukan, kita dapat menggunakan wait_until seperti yang ditunjukkan di bawah ini -

Kode Watir menggunakan 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'

Selanjutnya, gunakan perintah berikut

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

Watir akan menunggu tombol untuk diaktifkan dan kemudian pergi ke acara klik untuk diaktifkan. Tangkapan layar yang diambil ditunjukkan di bawah ini -

Waittestbefore.png

waittestafter.png