Friday, 30 June 2017

Selenium WebDriver : Working with Drop-down Options

So, by now you must have learnt about how to open a Web Page, Navigate to another page by clicking on a link, click a button or verify text present on the Web Page. If not, you need to practice these basic User Actions that can be performed through Automation. You can also check the videos which explains about the different things that we have already discussed and will be discussing in the upcoming posts, related to Test Automation using Selenium WebDriver.

 YouTube Channel : Click Here

In this post we are going to learn yet another important feature of Selenium WebDriver, that is Selecting one of the Drop-down Options.

Before we see how to use the methods provided by Selenium WebDriver to select Drop-down Options, we need to initialize the Object which we will be using to Select options. Following line of code will find the <select> tag in HTML source code, and assign it to an object which we can use to call different methods :



Select option = new Select(driver.findElement("<select> tag locator"));

Once we have initialized the Object, we are ready to use the Object to call different methods.


There are different ways of selecting Drop-down option, let's see them one by one :


1 - Select By Visible Text :

You can select options based on the values displayed in the drop-down list.


option.selectByVisibleText("Option text String");

This will select the option based on the String passed as parameter to above mentioned method.


2 - Select by Value :


option.selectByValue("Option value attribute");

You can find the value attribute of the <option> tag in the HTML source code.

  

3 - Select by Index :


option.selectByIndex(index);

index is 0-based (starts from zero), to be incremented by one for next option.



In this way we can Select any of the Drop-down options using any of the methods provided by Selenium WebDriver.

Feel free to comment in the comments section in case you have any queries.
Happy Learning.

Don't forget to Subscribe :
YouTube Channel : Click Here

Friday, 16 June 2017

Selenium WebDriver : Working with Radio Buttons

In this post, we are going to see how one can interact with Radio buttons present on a Web Page and select one of them. Radio Buttons are nothing but a list of options in which user is allowed to select exactly ONE option.

We are going to see how it can be done using Selenium WebDriver. Very simple, just stick to this post till the end. Also we have our YouTube Channel that will cover all the topics we are covering in this blog. So don't forget to subscribe to the channel for more interesting Test Automation videos. 

YouTube Channel : Click Here

So these are the HTML Radio Buttons as shown in below image :




HTML code looks like this :


  <input type="radio" name="animal" value="Bird"> Bird<br>
  <input type="radio" name="animal" value="Cat"> Cat<br>
  <input type="radio" name="animal" value="Dog"> Dog<br>
  <input type="radio" name="animal" value="Rabbit"> Rabbit<br>
  <input type="radio" name="animal" value="Pig"> Pig<br>




Now in order to select one of the Radio Button options, we just need to locate the appropriate option (Web Page Element) and click on that option using the click() method we already discussed in previous posts.



So in order to select Bird in above example, check the following code snippet : (Assuming the Web Page contains above HTML code)



public class Sample {
public static void main(String[] args) {
//Initialize Browser
System.setProperty("webdriver.gecko.driver", "Path to geckodriver.exe");
WebDriver driver = new FirefoxDriver();
driver.manage().window().maximize();
driver.get("Web Page URL");

//Find Element and Click
WebElement element = driver.findElement(By.cssSelector("input[value='Bird']"));
element.click();
}
}



driver.findElement(By.cssSelector("input[value='Bird']")); is used to locate the Radio Button option containing the value Bird.



CssSelector is used to find the required Web Page element (option) and click on that option. "tag[attribute='value']" is used as the CssSelector in the absence of ID or ClassName. 
The above code snippet will select the Bird option by using the click() method provided by Selenium WebDriver.


That's it in this post. Hope you are following the sequence of posts in this blog for better understanding of Test Automation using Selenium.
Don't forget to subscribe to our YouTube Channel for better understanding via videos and more examples.

Happy Learning.

YouTube Channel : Click Here

Friday, 9 June 2017

Selenium WebDriver : Getting text from Web Page

If you want to get some text (full / partial) that is displayed on Web Page, for verification, data extraction or any other purpose, we have some WebDriver methods that will do the job for us. Users with basic Object-Oriented knowledge can easily use these methods to achieve what is required.

In Types of Locators, we have seen different techniques to locate Web Page elements that are required to be found during Test Automation. It includes finding by ID, ClassName, Tag, LinkText, etc. that can be achieved by using appropriate Selenium WebDriver methods using the WebDriver Object instance.

In this post, we are going to see the way of extracting text from Web Page using Selenium WebDriver. Trust me it is as simple as one line of code.
Check the following code snippet :



public class Sample {
public static void main(String[] args) {
//Initialize Browser
System.setProperty("webdriver.gecko.driver", "E:\\AllJARS\\Selenium_Driver_Servers\\geckodriver.exe");
WebDriver driver = new FirefoxDriver();
driver.manage().window().maximize();
driver.get("https://www.google.com/");

//Find element
WebElement element = driver.findElement(By.cssSelector("a[href='https://mail.google.com/mail/?tab=wm']"));

//Get Text
System.out.println(element.getText());
}
}


The above code snippet navigates to Google, finds link (Gmail), extracts the text (Gmail) and prints it on console.

getText() method is used to extract the text from the Web Page element found using one of the locating techniques.
In this way we can find the required element and get or extract the required text from the Web Page. Further, we can use any substring() method provided by Java to get the desired String value (reduced length compared to Original String).


element.getText();

So, the above line of code can be used to extract the text from Web Page as required. Simple, isn't it ?
Hope you liked this post. In case of any queries or suggestions, feel free to comment in comments section.
Thank you for reading.

Happy Learning.

YouTube Channel : Click Here

Friday, 2 June 2017

Selenium WebDriver : Using Navigation methods

Want to navigate to a particular Website (or URL), and you are feeling a bit lazy to open a browser, type in the website URL again and again.. and again.. whenever you want to ? Welcome to another post in which we are going to see how we can use selenium WebDriver to open a Website. 

If you are new to Selenium, check out my previous posts on how to set up the environment to get started with Selenium WebDriver.


Selenium WebDriver provides us with different methods such as get() and navigate(), which can be used directly to get the website (or URL) specified as parameters with these methods.


1 - Using get() method :

     Following code snippet can be used to get a webpage after initializing Web Browser :

 

public class Sample {
public static void main(String[] args) {
//Initialize Browser
System.setProperty("webdriver.gecko.driver", "E:\\AllJARS\\Selenium_Driver_Servers\\geckodriver.exe");
WebDriver driver = new FirefoxDriver();
driver.manage().window().maximize();


driver.get("https://www.google.com/");
}
}


Note : get() takes the URL of the website as a parameter.

 


2- Using navigate() method :

      Following code snippet can be used as an alternative method to get() :

 

public class Sample {
public static void main(String[] args) {
//Initialize Browser
System.setProperty("webdriver.gecko.driver", "E:\\AllJARS\\Selenium_Driver_Servers\\geckodriver.exe");
WebDriver driver = new FirefoxDriver();
driver.manage().window().maximize();
driver.navigate().to("https://www.google.com/");

driver.findElement(By.cssSelector("#_eEe a")).click();
driver.navigate().back();
driver.navigate().forward();
}
}


Note : navigate().to() takes the URL of the website as a parameter.

 

If you use navigate().to() method to get a web page, it also allows you to use couple of more methods to navigate through the history of the Web Browser. So you would be able to go back or forward, as far as Web Browser history is concerned.

 

Using back() : (To navigate back in history)

driver.navigate().back();

 

Using forward() : (To navigate forward in history)

driver.navigate().forward();

 

Above 2 mentioned methods (back()  and forward()) allows you to navigate through the history of the Web Browser as and when required.

 

That's it in this short post about navigating to Web Pages using Selenium WebDriver. Feel free to comment in the comments section if you have any queries / suggestions.

Stay tuned for more interesting posts about Test Automation using Selenium.

Happy Learning.  

YouTube Channel : Click Here