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)