Watir - Objets de page

Page Object dans Watir nous aide à réutiliser le code sous forme de classes. En utilisant la fonctionnalité d'objet de page, nous pouvons automatiser notre application sans avoir à dupliquer de code et rend également le code gérable.

Lors du test, nous pouvons créer un objet de page pour chacune des pages que nous allons tester. Ensuite, nous allons accéder aux méthodes et propriétés à l'aide de l'objet page.

Les raisons de l'utilisation de l'objet de page -

  • Si des modifications sont apportées à la page lors des modifications, la réécriture du code n'est pas nécessaire.

  • Pour éviter la redondance du code.

Nous allons utiliser RSpec pour utiliser l'objet de page dans Watir. Incase si vous n'êtes pas familier avec RSpec, voici un tutoriel complet disponible pour RSpec pour vous apprendre.

La page sur laquelle nous allons effectuer le test est donnée ici -

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>

Production

Nous allons maintenant créer un objet de page pour la page ci-dessus comme indiqué ci-dessous -

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

Il y a trois classes définies - InitializeBrowser, TestPage et TestTextbox -

  • InitializeBrowser - Cela initialisera le navigateur ouvert et partagera l'objet navigateur avec les classes TestPage et TestTextbox.

  • TestPage - Cette classe aura une référence d'objet à TestTextbox et contient la méthode pour capturer une capture d'écran et fermer le navigateur.

  • TestTextbox - Cette classe aura des méthodes pour ouvrir l'url de la page, donner une référence à textfield, définir les données et déclencher l'événement onchange.

Une fois que vous exécutez le code ci-dessus, vous pouvez voir la sortie comme indiqué ci-dessous -