Dzone Refcard67 Selenium PDF
Dzone Refcard67 Selenium PDF
CONTENTS
öö What Is Selenium?
ö ö Getting Started
ö ö Locators
ö ö Page Objects
ö ö Waiting
ö ö Screenshots on Failure
ö ö Mobile Support
WRITTEN BY DAVE HAEFFNER AUTHOR, ELEMENTAL SELENIUM
What Is Selenium? you can either let your IDE (Integrated Development Environment) use
Selenium is a free and open-source browser automation library used Maven to import the dependencies or open a command-prompt, cd
by millions of people for testing purposes and to automate repetitive into the project directory, and run mvn clean test-compile.
web-based administrative tasks. It has the support of the largest
<dependency>
browser vendors, who have integrated Selenium into the browsers
<groupId>org.seleniumhq.selenium</groupId>
themselves. It is also the core technology in countless other automa-
<artifactId>selenium-java</artifactId>
tion tools, APIs, and frameworks.
<version>LATEST</version>
<scope>test</scope>
Selenium/WebDriver is now a W3C (World Wide Web Consortium)
</dependency>
Recommendation, which means that Selenium is the official standard
for automating web browsers.
Getting Started
Selenium language bindings are available for multiple programming
languages:
• Java
• JavaScript
• Python
• Ruby
• C#
In order to start writing tests, you first need to install the bindings for
your preferred programming language.
1
A brief history of web and mobile app testing.
You will need to have the Java Development Kit (version 8+ for 3.x browser. In all cases (except Safari), this driver must be downloaded
and 4.x versions of Selenium) and Maven installed on your machine. and installed separately from the browser itself.
For more information on the Selenium Java bindings, check out the
For each example below, the code snippet will do no more than launch
API documentation.
a single browser on your local machine. See below for examples that
JAVASCRIPT (NPM) perform more actions, such as locating elements and navigating. Fur-
JavaScript offers two different approaches for incorporating Seleni- ther below will give examples for running Selenium in parallel.
um/WebDriver into your tests:
CHROME
TRADITIONAL JAVASCRIPT BINDINGS In order to use Chrome, you need to download the ChromeDriver bi-
Use the following command into a command-prompt to install the nary for your operating system (pick the highest number for the latest
JavaScript bindings for Selenium: npm install selenium-webdriver version). You either need to add it to your System Path or specify its
location as part of your test setup.
You will need to have Node.js and NPM installed on your machine. For
more information about the Selenium JavaScript bindings, check out //Create a new instance of the ChromeDriver
WEBDRIVER.IO Note: For more information about ChromeDriver, check out the Chro-
WebDriver.IO is a "next-gen" test framework for getting started with mium team's page for ChromeDriver.
You will need to install Microsoft Visual Studio and NuGet to install recommended to test them as separate browsers.
these libraries and build your project. For more information on the
SAFARI
Selenium C# bindings, check out the API documentation.
Safari on OS X works without having to download a browser driver:
Launching a Browser Note: Safari only runs on MacOS systems. For more information about
Selenium requires a "browser driver" in order to launch your intended SafariDriver, check out Apple's page for SafariDriver.
Note: Internet Explorer versions older than 11 are no longer support- Note: For more information about working with elements, check out
ed by Microsoft. The Internet Explorer Driver still maintains support the Selenium WebElement API Documentation.
for some older versions but will not guarantee any such support after
Selenium v4 ships. For more information about this and other Interne- COMPLEX USER GESTURES
Selenium's Actions Builder enables more complex keyboard and
tExplorerDriver details, check out the Selenium project Wiki page for
mouse interactions. Things like drag-and-drop, click-and-hold,
InternetExplorerDriver.
double-click, right-click, hover, etc.
Commands and Operations
// a hover example
The most common operations you'll perform in Selenium are navi-
WebElement avatar = driver.findElement(By.
gating to a page and examining WebElements. You can then perform
name("target"));
actions with those elements (e.g., click, type text, etc.), ask questions (new Actions(driver)).moveToElement(avatar).build().
about them (e.g., Is it clickable? Is it displayed?), or pull information perform();
out of the element (e.g., the text of an element or the text of a specific
attribute within an element). Note: For more details about the Action Builder, check out the Actions
API documentation.
VISIT A PAGE
driver.get("http://the-internet.herokuapp.com"); Locators
In order to find an element on the page, you need to specify a locator.
FIND AN ELEMENT There are several locator strategies supported by Selenium:
// find just one, the first one Selenium finds
WebElement element = driver.findElement(locator); BY LOCATOR EXAMPLE (JAVA)
these approaches, since they can be very brittle (and slow). Alter- An Example Test
natively, talk with a developer on your team when the app does not To tie these concepts together, here is a simple test that demonstrates
present simple locators. Tell them what you're trying to automate and how to use Selenium to exercise a common functionality (e.g. login)
work with them to get more semantic markup added to the page. This by launching a browser, visiting the target page, interacting with the
will make the application more testable and make your tests far easier necessary elements, and verifying the page is in the correct place.
to write and maintain.
Note that this example is intended to get users familiar with how to
CSS SELECTORS manipulate elements and the WebDriver API. A better method for
APPROACH LOCATOR DESCRIPTION abstracting and combining commands will come below.
ID #example # denotes an ID
import org.junit.Test;
• CSS Selectors Reference This allows you to write your tests using user-centric language, rather
than Selenium-centric language. This is called the "Page Object Model."
• XPath Syntax Reference
When your application changes and your tests break, you only have to
• CSS & XPath Examples by Sauce Labs
update your Page Objects in one place in order to accommodate the
• The difference between nth-child and nth-of-type
changes. This gives us reusable functionality across our suite of tests,
• How To Verify Your Locators as well as more readable tests.
Let's create a page object for the login example shown before, then public void setUp() {
@Before Note: For more info, check out the case against using Implicit and
CODE CONTINUED ON NEXT COLUMN Explicit Waits together and Explicit vs. Implicit Waits.
Using Implicit Waits is no longer recommended. It can cause unnec- 19:05:12.718 INFO - Launching Selenium Grid hub
essary delays in testing time, and it masks the "intent" of your tests. ...
There are many discussions online to study the topic more in-depth. After that, we can register nodes to the hub.
As those articles suggest, there are cases when Implicit Waits are > java -jar selenium-server-standalone.jar -role node
necessary. The official documentation for Implicit Waits is here. -hub http://ip-address-or-dns-name-to-your-hub:4444/
grid/register
Screenshots on Failure 19:05:57.880 INFO - Launching a Selenium Grid node
Selenium can take screenshots of the browser window. We recom- ...
mend taking a screenshot whenever a test fails. In JUnit, this done
Note: To run node processes on multiple machines, you will need to
with a TestWatcher rule.
place the standalone server on each machine and launch it with the
@Rule same registration command (providing the IP Address or DNS name of
public TestRule watcher = new TestWatcher() { the hub, and specifying additional parameters as needed).
@Override
protected void failed(Throwable th, Description desc) Once these processes are running, you must make a small change to
{ your test config, to create a RemoteWebDriver that will utilize the Grid.
File scrFile = ((TakesScreenshot)driver).
FirefoxOptions options = new FirefoxOptions();
getScreenshotAs(OutputType.FILE);
"http://ip-address-or-dns-name-to-your-hub:4444/wd/hub";
try {
driver = new RemoteWebDriver(new URL(url), options);
FileUtils.copyFile(scrFile,
new File("failshot_"
Selenium Grid is a great option for scaling your test infrastructure,
+ desc.getClassName()
but it doesn't give you parallelization for free. It can handle as many
+ "_" + desc.getMethodName()
connections as you throw at it (within reason), but you still need to
+ ".png"));
} catch (IOException ex) {
find a way to execute your tests in parallel (with your test framework,
throw new RuntimeException(ex); for instance). Also, if you are considering standing up your own grid,
} be sure to check out docker-selenium, ecs-selenium (requires AWS),
} and Zalenium.
}
Note: When Selenium 4.0 is officially released, these examples are
subject to change and may no longer hold true.
Running Tests in Parallel
In order to run your tests on different browser/operating system
SELENIUM SERVICE PROVIDERS
combinations simultaneously, you need to initialize a special kind of
Rather than take on the overhead of a standing up and maintaining
WebDriver: a RemoteWebDriver. This allows you to execute your tests
a test infrastructure, you can easily outsource things to a third-party
on a different machine that you maintain (using the Selenium Grid)
cloud provider (a.k.a. someone else's Grid) like Sauce Labs.
or one of the many cloud providers (Sauce Labs, BrowserStack, etc).
These providers allow you to pay for the use of cloud servers for test Note: You'll need an account to use Sauce Labs. Their free trial offers
execution, but in an environment that you don't have to spend time enough to get you started. And if you're signing up because you want
or resources to maintain. to test an open-source project, then be sure to check out their Open
Sauce account.
SELENIUM GRID
There are two main elements to the Selenium Grid — a hub to manage //Create the SauceOptions object with your credentials
the tests, and nodes to execute them. The hub ensures your tests end and other info
up on the right node and manages all communication between the MutableCapabilities sauceOptions = new
nodes and your test code. Nodes host the browser/OS combinations MutableCabilities();
sauceOptions.setCapability("username", "<username");
and execute your test commands while providing constant feedback
sauceOptions.setCapability("accesskey", "<accesskey");
to the hub.
Selenium Grid comes built into the Selenium Standalone Server, //Create the ChromeOptions object with the browser info
you require
which you can download here.
ChromeOptions chromeOptions = new ChromeOptions();
Then start the hub: CODE CONTINUED ON NEXT PAGE
Note: You can see a full list of Sauce Labs' available platform op-
tions here. Be sure to check out Sauce Labs' documentation portal
for more details.
Mobile Support
Within the WebDriver ecosystem, there are a few mobile testing solu-
Devada, Inc.
600 Park Offices Drive
Suite 150
Research Triangle Park, NC
888.678.0399 919.678.0300
DZone communities deliver over 6 million pages each month
to more than 3.3 million software developers, architects, Copyright © 2019 DZone, Inc. All rights reserved. No part of this
and decision makers. DZone offers something for everyone, publication may be reproduced, stored in a retrieval system, or
including news, tutorials, cheat sheets, research guides, fea- transmitted, in any form or by means electronic, mechanical,
ture articles, source code, and more. "DZone is a developer’s photocopying, or otherwise, without prior written permission of
dream," says PC Magazine. the publisher.