Watir - Attentes automatiques

Dans ce chapitre, laissez-nous comprendre les attentes en détail. Pour comprendre les attentes automatiques, nous avons créé une simple page de test. Lorsque l'utilisateur entre du texte dans la zone de texte, l'événement onchange est déclenché et après 3 secondes, le bouton est activé.

Watir a un appel api wait_unit qui attend un événement ou une propriété en particulier. Nous allons tester la même chose pour la page de test comme indiqué ci-dessous -

Syntaxe

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>

Production

Lorsque vous entrez le texte dans la zone de texte, vous devrez attendre 3 secondes pour que le bouton soit activé.

Lorsque vous cliquez sur le bouton Soumettre, le texte suivant s'affiche -

Maintenant que nous avons ajouté un délai d'activation du bouton, il est difficile pour l'automatisation de gérer de tels cas. Chaque fois que nous avons un retard ou que nous devons attendre un événement ou une propriété de l'élément à localiser, nous pouvons utiliser wait_until comme indiqué ci-dessous -

Code Watir utilisant 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'

Ensuite, utilisez la commande suivante

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

Watir va attendre que le bouton soit activé et plus tard, l'événement de clic sera déclenché. Les captures d'écran capturées sont présentées ci-dessous -

Waittestbefore.png

waittestafter.png