Selenium 4
Angie Jones
https://angiejones.tech
https://TestAutomationU.com
@techgirl1908
Senior Director, Developer Relations
Applitools
Test Automation University
data:image/s3,"s3://crabby-images/70a98/70a985854b0d721bf21eb2ae811f851d2b5134fa" alt=""
π Test Driving π
@techgirl1908
@techgirl1908
Relative Locators
@techgirl1908
data:image/s3,"s3://crabby-images/e85f1/e85f12e473920ff09c325db286fc47f70ff488f7" alt=""
@techgirl1908
<ul id="productList">
<!-- Test Automation in the Real World -->
<li id="pid1" class="ui-li-has-thumb ui-first-child">...</li>
<!-- Experiences of Test Automation -->
<li id="pid2" class="ui-li-has-thumb">...</li>
<!-- Agile Testing -->
<li id="pid3" class="ui-li-has-thumb">...</li>
<!-- How Google Tests Software -->
<li id="pid4" class="ui-li-has-thumb">...</li>
<!-- Java for Testers -->
<li id="pid5" class="ui-li-has-thumb">...</li>
<!-- Advanced Selenium in Java -->
<li id="pid6" class="ui-li-has-thumb">...</li>
<!-- The Cucumber for Java Book -->
<li id="pid7" class="ui-li-has-thumb">...</li>
<!-- BDD in Action -->
<li id="pid8" class="ui-li-has-thumb ui-last-child">...</li>
</ul>
@techgirl1908
@techgirl1908
var element = driver.findElement(
);
@techgirl1908
@techgirl1908
var element = driver.findElement(
withTagName("li").
);
@techgirl1908
@techgirl1908
var element = driver.findElement(
withTagName("li").
toLeftOf(By.id("pid3"))
);
@techgirl1908
@techgirl1908
var element = driver.findElement(
withTagName("li").
toLeftOf(By.id("pid3"))
);
assertEquals("pid2", element.getAttribute("id"));
ComparisonFailure:
Expected :pid2
Actual :pid1
@techgirl1908
@techgirl1908
data:image/s3,"s3://crabby-images/e85f1/e85f12e473920ff09c325db286fc47f70ff488f7" alt=""
pid1
pid3
@techgirl1908
var elements = driver.findElements(
withTagName("li").
toLeftOf(By.id("pid3"))
);
System.out.println(
elements.
stream().
map(e->e.getAttribute("id")).
collect(Collectors.toList())
);
[pid1, pid2, pid5, pid6]
@techgirl1908
@techgirl1908
data:image/s3,"s3://crabby-images/e85f1/e85f12e473920ff09c325db286fc47f70ff488f7" alt=""
pid1
pid3
pid2
pid5
pid6
var element = driver.findElement(
withTagName("li").
toLeftOf(By.id("pid3")).
toRightOf(By.id("pid1"))
);
assertEquals("pid2", element.getAttribute("id"));
@techgirl1908
var element = driver.findElement(
withTagName("li").
toLeftOf(By.id("pid3")).
toRightOf(By.id("pid1"))
);
assertEquals("pid2", element.getAttribute("id"));
@techgirl1908
@techgirl1908
@techgirl1908
data:image/s3,"s3://crabby-images/fd69a/fd69a8e298ada66b350e2c0afd7ea4a9cabae29f" alt=""
var element = driver.findElement(
withTagName("li").
toLeftOf(By.id("pid3")).
toRightOf(By.id("pid1"))
);
assertEquals("pid2", element.getAttribute("id"));
@techgirl1908
Things are not always as they appear...
@techgirl1908
data:image/s3,"s3://crabby-images/11d70/11d7083944270dbea7553cbd1290c43d7f7c053b" alt=""
@techgirl1908
<div class="view">
<input class="toggle" type="checkbox">
<label>goodbye world</label>
<button class="destroy"></button>
</div>
driver.findElement(
withTagName("input").
toLeftOf(By.xpath("//label[text()='goodbye world']")))
.click();
NoSuchElementException
data:image/s3,"s3://crabby-images/a9b45/a9b45a3f19c8f27085dbe37374cf8e3e03f0d9c3" alt=""
@techgirl1908
@techgirl1908
data:image/s3,"s3://crabby-images/40df5/40df5df871a5799bb2b21a924bd636936e2c14f3" alt=""
data:image/s3,"s3://crabby-images/e810e/e810e1c819b492fa7273595f3621c7fb374993fa" alt=""
@techgirl1908
Use it sparingly
@techgirl1908
Use for interaction,
not verification
@techgirl1908
Questions on
Relative Locators
@techgirl1908
New Window/Tab
@techgirl1908
driver.get("https://applitools.com/");
data:image/s3,"s3://crabby-images/2ab4f/2ab4f411ff1823b8ee4c83ed4375ef36d3a85906" alt=""
@techgirl1908
driver.get("https://applitools.com/");
driver.switchTo().newWindow(WindowType.TAB);
data:image/s3,"s3://crabby-images/8fe22/8fe22ed49a298abfc8faf9b18c4e6211f4a8dd84" alt=""
@techgirl1908
driver.get("https://applitools.com/");
driver.switchTo().newWindow(WindowType.TAB);
driver.get("https://testautomationu.applitools.com");
data:image/s3,"s3://crabby-images/3b7bb/3b7bbf58ce436a8bbe39b75b3f0977ef0bb8f9b1" alt=""
@techgirl1908
var windows = driver.getWindowHandles();
for(var window : windows){
driver.switchTo().window(window);
if("Automated Visual Testing with Visual AI".equals(driver.getTitle())){
break;
}
}
data:image/s3,"s3://crabby-images/3b959/3b95975477289cdd8dfd889b8cf6829721913a81" alt=""
@techgirl1908
Questions on
New Windows/Tabs
@techgirl1908
Chrome DevTools Protocol
@techgirl1908
data:image/s3,"s3://crabby-images/06338/06338c13727562ffa07d633746fe5b67f742b811" alt=""
@techgirl1908
data:image/s3,"s3://crabby-images/77fa8/77fa8b3711ed4b2f10ede70b41ff1b0411aa7d0a" alt=""
@techgirl1908
@techgirl1908
data:image/s3,"s3://crabby-images/f78b3/f78b3016e8f0cd277bd715378ef0b9251d0d1f02" alt=""
@techgirl1908
data:image/s3,"s3://crabby-images/2e480/2e480a32a39811a552c3a5dca2261f79632eb97b" alt=""
@techgirl1908
ChromeDriver driver = new ChromeDriver();
DevTools devTools = driver.getDevTools();
data:image/s3,"s3://crabby-images/36595/36595b6fd412b2097137b3b3c316e3b0fbe21669" alt=""
@techgirl1908
data:image/s3,"s3://crabby-images/e1b72/e1b7218bb520cd5372621dd06a5207b452ba56f1" alt=""
data:image/s3,"s3://crabby-images/9b2d7/9b2d7d6b598d6b35cc0b7d04148568448641599c" alt=""
@techgirl1908
ChromeDriver driver = new ChromeDriver();
DevTools devTools = driver.getDevTools();
devTools.createSession();
devTools.send(Emulation.setGeolocationOverride(
Optional.of(35.8235),
Optional.of(-78.8256),
Optional.of(100))
);
driver.get("https://mycurrentlocation.net/");
@techgirl1908
data:image/s3,"s3://crabby-images/af370/af3706d52133c2b15e2cd59c584e7d6166d383a3" alt=""
devtools.send(
Network.emulateNetworkConditions(
true,
250,
-1,
-1,
of(ConnectionType.CELLULAR2G)
));
@techgirl1908
How can I
test drive Selenium 4?
@techgirl1908
data:image/s3,"s3://crabby-images/9812a/9812aaed0006d40114aae743d745afe55ed7cef9" alt=""
data:image/s3,"s3://crabby-images/18e9c/18e9cf9772d3dae6973fb30dfb3d0ed686f9acd1" alt=""
@techgirl1908
data:image/s3,"s3://crabby-images/b8203/b820340fe09f6db6e660b327864a5ea696464093" alt=""
Selenium 4
Angie Jones
https://angiejones.tech
https://TestAutomationU.com
@techgirl1908
Senior Director, Developer Relations
Applitools
Test Automation University
data:image/s3,"s3://crabby-images/70a98/70a985854b0d721bf21eb2ae811f851d2b5134fa" alt=""