Selenium WebDriver, Locators...
In Part-3 we built a project using Maven, which created a
wonderful project structure, if you see properly it has ‘src/test/java’ and ‘/src/main/java’
folders. We will normally use ‘src/test/java’ to write our test-cases inside it
and ‘src/main/java’ to write the miscellaneous/helper classes[we will discuss
this further].
So for now, we start our first automation script and we will
keep on enhancing it further. Go to your
eclipse IDE to ‘GoogleSearchTest’ project that we created in Part-3.
Right-click on ‘src/main/java’ >New-Class->IntialTest[Give this as the
class name]
Once you click ‘Finish’ a template of your class will be
formed. Paste below lines as mentioned
in the screenshot:
System.setProperty("webdriver.chrome.driver","path to
chromedriver.exe");
Webdriver driver = new ChromeDriver();
Now go to the link https://chromedriver.chromium.org/downloads
and click ‘ChromeDriver 83.0.4103.39’, because this is my
current Chrome browser version.
Now select what OS version you have. Since I have Windows
machine, I will click the appropriate one
as below, to download it to my drive:
Now go to the location where it is downloaded and move it any
location of your choice[if required] and unzip it, to get the .exe file. Copy
the location where it is unzipped, for me, it is ‘C:\Software\drivers\chromedriver_win32 (1)’:
Now update this path in your code as below:
You must be still wondering, why there is still an error
even after so many steps. These are repeatable steps, occurring in almost every
scripts, so now after gaining the understanding of these steps, you won't find
it lengthy at all.
Secondly, there is one more magic Maven which we will see, is that now, for the above error line we don't need to download Selenium jar, but instead of
we doing it, we will ask our friend Maven to do it for us, how? Just type ‘selenium
maven dependency’ in google, and now navigate to the link suggested and click on ‘Selenium
Server’ link:
And select the latest stable version, never select ‘Alpha
version’ as below:
Now just click/select the text available inside the box:
Go to your eclipse>double-click pom.xml file[it’s the
heart of your project] :
Copy text after ‘dependency’ tag as
mentioned below and save it:
Now go to your code and hover on the first error, you will
find some solutions now to resolve your issue, which was not present earlier:
One issue resolved:
Now again hover mouse on another issue, it will suggest
corrective measures to be taken and select the option mentioned below:
The code now after resolving the issues, is free from
errors, because Maven provided all the corrective implementations that the code
needed, without you doing anything, other than just hovering and selecting
appropriate suggestions:
What do the above two lines do?:
System.setProperty("webdriver.chrome.driver","path
to chromedriver.exe");
-This basically sets the system property to key named ‘webdriver.chrome.driver’
and value is the path where the chrome
driver is downloaded on your system.
Webdriver driver =
new ChromeDriver();
-This is basically used to create an instance of the chrome
driver.
Now you have the power of chrome-based driver with you and you are all
set to do whatever actions you want your chrome browser to do.
Remember our
test-case was to open Chrome browser, then open Google.com and then type the word
‘selenium’ in Google search box, it should display various options Google
provides as per its search criteria. So now add ‘driver.get("http://www.google.com");‘ line in above code > save
> right-click > Run As > Java Application:
Magic: The moment you run this, another chrome browser
instance will open and it will run your desired test-case
There are 2-3 points by which you can guarantee that the browser opened was as an output of an automated test-case:
- In your eclipse IDE console, it will show message: ‘ChromeDriver was started successfully.’
- On newly opened browser it will show message ‘Chrome is being controlled by an automated test software’
- And the third is the desired URL being opened.
Yes, this confirms you have successfully automated a simple
browser-related test-case. Congratulations!!
Now, let's move to locators. Selenium has the following locators:
But what are locators?
Selenium provides a number of Locators to locate a GUI
element precisely on a web-page, whether its a text-box, radio button, or any
other element. So using these locators we can find the web-element and do our
required set of actions on it. We will see it’s usage in due course. Simple,
right!!
So now for our test-case, we need to send a string/set of
characters called ‘selenium’ in Google search box. So to find locator for this,
right-click the element on which you want to perform the action, in our case, right-click
inside the search box.
And select ‘Inspect’, you will see below[highlighting the
part of the code on which we inspected]:
Here we can see inside the highlighted portion a tag
starting from ‘input’ having various attributes and associated values for it,
like attribute ‘class’ has value ‘gLFyf gsfi’ and many others following it. We
will use ‘CSS selector locator to uniquely identify our element and how to implement
it is, given in below code:
driver.findElement(By.cssSelector("input.gLFyf.gsfi")).sendKeys("selenium");
You can use below cheat-sheet for finding elements using
CSS:
So in our example, we used tagname.classValue like ‘input.gLFyf.gsfi’ , ie tagname is ‘input’ and attribute ‘class’ has value ‘gLFyf gsfi’. The small catch here is if you see properly in our eclipse code we have mentioned class value as ‘gLFyf.gsfi’ and on Google inspect page, it is ‘gLFyf gsfi’.
No.
|
Tag
|
Comment
|
1.
|
tagname[attribute=’value’]
|
To be used
when you have tagname, attribute and value
|
2.
|
[attribute=’value’]
|
Above can
also be written like this, excluding tagname
|
3.
|
tagname[attribute*=’value’]
|
To be used
when using a regular expression, in case the value is too big, you can use part
of it.
|
4.
|
tagname#idValue
|
To be used
when you have ‘id’ attribute and value, a shortcut
|
5.
|
tagname.classValue
|
To be used
when having ‘class’ attribute and value, a shortcut
|
So in our example, we used tagname.classValue like ‘input.gLFyf.gsfi’ , ie tagname is ‘input’ and attribute ‘class’ has value ‘gLFyf gsfi’. The small catch here is if you see properly in our eclipse code we have mentioned class value as ‘gLFyf.gsfi’ and on Google inspect page, it is ‘gLFyf gsfi’.
So whenever using
class as an attribute and if the value of the class has space we need to
replace that space with a dot(.). As we have successfully found the element, we
need to send out characters or string ‘selenium’ into it. We do that by writing
‘.sendKeys(“selenium”), to the element we accurately found.
Now again run the code as ‘Java Application’ as mentioned
earlier:
Now you will find below:
Wooo... You have successfully automated your required manual
test-case as mentioned in Part-2.
Isn’t it easy, as I told you earlier? Do comment and let me
know your feedback, if this was helpful to you or you would like to refer this to
your friend or colleague who wants to learn automation.
In the next section Part-5, we will improvise this further and use all the
locators and other things like TestNG, Screenshot, Logs, ExtentReporting, Jenkins and many-many other
automation features to build a robust framework.
Thanks for reading!!
Tasveer: Lisa Ray....!
For earlier articles click below link:
Part-1:Want to quickly become an Selenium Automation Engineer and build framework right from scratch?
Part-2:Want to quickly become an Selenium Automation Engineer and build framework right from scratch?
Part-3:Want to quickly become an Selenium Automation Engineer and build framework right from scratch?
Part-4: Want to quickly become an Selenium Automation Engineer and build framework right from scratch?
Part-1:Want to quickly become an Selenium Automation Engineer and build framework right from scratch?
Part-2:Want to quickly become an Selenium Automation Engineer and build framework right from scratch?
Part-3:Want to quickly become an Selenium Automation Engineer and build framework right from scratch?
Part-4: Want to quickly become an Selenium Automation Engineer and build framework right from scratch?
Did she really loved me....? Part-1
Did she really loved me....? Part-2
Did she really loved me....? Part-3
Did she really loved me....? Part-4
Did she really loved me....? Part-5
Did she really loved me....? Part-6
Did she really loved me....? Part-7
Did she really loved me....? Part-8
Did she really loved me....? Part-9
Did she really loved me....? Part-10
Did she really loved me....? Part-11
Did she really loved me....? Part-12
Did she really loved me....? Part-13
Did she really loved me....? Part-14
Did she really loved me....? Part-15[The End]
Want to own your own start-up? Want to be Richie Rich?
Hey Corona, you should go now!!
Part-1: Want Quick Divorce? Come in...: [Kahani Ghar-Ghar ki]
Part-2: Want Quick Divorce? Come in...[Kahani Ghar Ghar ki]
Did she really loved me....? Part-2
Did she really loved me....? Part-3
Did she really loved me....? Part-4
Did she really loved me....? Part-5
Did she really loved me....? Part-6
Did she really loved me....? Part-7
Did she really loved me....? Part-8
Did she really loved me....? Part-9
Did she really loved me....? Part-10
Did she really loved me....? Part-11
Did she really loved me....? Part-12
Did she really loved me....? Part-13
Did she really loved me....? Part-14
Did she really loved me....? Part-15[The End]
Want to own your own start-up? Want to be Richie Rich?
Hey Corona, you should go now!!
Part-1: Want Quick Divorce? Come in...: [Kahani Ghar-Ghar ki]
Part-2: Want Quick Divorce? Come in...[Kahani Ghar Ghar ki]