Watir - Localisation des éléments Web

Dans Watir pour les tests, vous devez localiser les éléments et cela peut être fait de différentes manières - en utilisant l'id, la classe ou le texte de l'élément.

Dans ce chapitre, nous verrons quelques exemples qui montrent différentes manières de localiser des éléments.

Utilisation de l'ID de l'élément

Page de test

<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>

Exemple

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'

Dans cet exemple, nous utilisons l'identifiant de l'élément textbox pour le localiser et définir la valeur.

t = b.text_field(id: 'firstname')

Production

Si vous avez besoin de localiser le div, le span ou toute autre balise html, vous pouvez faire de même en utilisant id comme suit -

Pour div

browser.div(id: "divid")
browser.div(id: /divid/)

Pour span

browser.span(id: "spanid")
browser.span(id: /spanid/)

Utilisation du NOM de l'élément

Page de test

<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>

Exemple

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'

Production

Utilisation du nom de balise

Vous pouvez localiser tous les éléments html que vous souhaitez en utilisant directement la balise html comme indiqué ci-dessous.

Pour div

browser.div(id: "divid")
browser.div(id: /divid/)

Pour span

browser.span(id: "spanid")
browser.span(id: /spanid/)

Pour p tag

browser.p(id: "ptag")
browser.p(id: /ptag/)

Pour le bouton

browser.button(id: "btnid")
browser.button(id: /btnid/)

Utilisation du nom de classe

Vous pouvez localiser l'élément en utilisant son nom de classe. Cela peut être fait comme indiqué ci-dessous -

Pour div

browser.div(class: "divclassname")
browser.div(class: /divclassname/)

Pour span

browser.span(class: "spanclassname”)
browser.span(class: /spanclassname/)

Pour p tag

browser.p(class: "pclassname")
browser.p(class: /pclassname/)

Pour le bouton

browser.button(class: "btnclassname")
browser.button(class: /btnclassname/)

Pour la zone de texte

browser.text_field(class: 'txtclassname')
browser.text_field(class: /txtclassname/)

Vous pouvez également passer plusieurs cours comme indiqué ci-dessous -

Pour div

browser.div(class: ["class1", "class2"])

Utilisation du texte

C'est encore une autre façon de localiser des éléments en utilisant des éléments avec un texte. Par exemple -

browser.button(text: "button text")
browser.button(text: /button text/)

Utilisation de l'étiquette

Vous pouvez utiliser l'étiquette de l'élément pour le localiser comme indiqué ci-dessous -

browser.text_field(label: "text here"))
browser.text_field(label: /text here/))

Utilisation des attributs de données

Si vous avez des attributs de données pour vos balises html, vous pouvez localiser les éléments en l'utilisant comme indiqué ci-dessous -

Par exemple, vous pouvez localiser la balise comme indiqué ci-dessous -

<div data-type = "test1"></div>

Vous pouvez localiser le div comme suit -

browser.div(data-type: 'test1'))
browser.div(data-type: /test1/))

Utilisation d'attributs personnalisés

Vous pouvez également localiser les éléments à l'aide d'attributs personnalisés comme indiqué ci-dessous -

Exemple d'élément html

<div itemprop = ”content”>
   ….
</div>

Vous pouvez localiser le div comme suit -

browser.div(itemprop: ‘content'))
browser.div(itemprop: /content/))

Utilisation de l'attribut visible

L'élément utilisant l'attribut visible peut être localisé comme indiqué ci-dessous -

browser.div(visible: true)
browser.div(visible: false)