Monday, 1 December 2014

Hard Assertion - assertNotNull(object) in webdriver Assertion



-> assertNotNull(object) assertion will check and verify that object is NOT NULL.

-> It will pass if object returns any value. That means without Null. and continue the execution. it will mark that specific test method as fail in TestNG result.

-> It will fail if object returns NULL.  and continue the execution in method.



Example :

Let us take example like we have two text box. one is Enabled in application. Second is disabled in application.



 WebElement txt1, txt2;
 @BeforeClass
 public void load_url(){
  driver.get("google.com");
  txt1 = driver.findElement(By.xpath("//input[@id='text1']"));
  txt2 = driver.findElement(By.xpath("//input[@id='text2']"));
 }

 //Example Of Assertion Method - will Pass
 @Test
 public void null1() {
  System.out.print("\n"+txt1.getAttribute("disabled"));
  Assert.assertNOTNull(txt1.getAttribute("disabled"));
 }

 //Example Assertion Method - will Fail
 @Test
 public void null2() {
  System.out.print("\n"+txt2.getAttribute("disabled"));
  Assert.assertNOTNull(txt2.getAttribute("disabled"));
 }



From the above example


First Text box -> Enabled="True". Its dont have Disabled attribute. So its returns NULL.

Second Text box -> Disabled="True". Its dont have Disabled attribute. So its returns value.


So o/p will be


-> null1() will get fail, because its not have the disabled attribute. So its return Null.

-> null2() will get pass, because its have the disabled attribute. So its return sone value. not return Null

Hard Assertion - assertNull(object) in Webdriver Assertion




-> assertNull(object) assertion will check and verify that object is NULL.

-> It will pass if object returns Null. and continue the execution

-> It will fail if object returns any value. then it will return error message like "java.lang.AssertionError: expected [null] but found [true]". Whenever your assertion fails, it will mark that specific test method as fail in TestNG result.



Example :

Let us take example like we have two text box. one is Enabled in application. Second is disabled in application.


   WebElement txt1, txt2;
 @BeforeClass
 public void load_url(){
  driver.get("google.com");
  txt1 = driver.findElement(By.xpath("//input[@id='text1']"));
  txt2 = driver.findElement(By.xpath("//input[@id='text2']"));
 }

 //Example Of Assertion Method - will Pass
 @Test
 public void null1() {
  System.out.print("\n"+txt1.getAttribute("disabled"));
  Assert.assertNull(txt1.getAttribute("disabled"));
 }

 //Example Assertion Method - will Fail
 @Test
 public void null2() {
  System.out.print("\n"+txt2.getAttribute("disabled"));
  Assert.assertNull(txt2.getAttribute("disabled"));
 }



From the above example


First Text box -> Enabled="True". Its dont have Disabled attribute. So its returns NULL.

Second Text box -> Disabled="True". Its dont have Disabled attribute. So its returns value.


So o/p will be


-> null1() will get pass, because its not have the disabled attribute. So its return Null.

-> null2() will get fails, because its have the disabled attribute. So its return sone value. not return Null

Hard Assertion - assertFalse(condition) Assertion in Selenium Webdriver



-> assertTrue assertion is generally used for when boolean condition false.

-> It will pass if condition returns "false". If it will return true then it will fail and skip test execution from that specific method.

-> Syntax for assertFalse assertion is as bellow.

Assert.assertFalse(condition);


Example:

Suppose you want to continue the process if checkbox Unchecked/unselect.



package TestNG_Package;

import org.openqa.selenium.WebDriver;
import org.openqa.selenium.firefox.FirefoxDriver;
import org.testng.annotations.AfterMethod;
import org.testng.annotations.BeforeMethod;
import org.testng.annotations.Test;
import org.testng.Assert;

public class TestNG_Test1 {

WebDriver driver1=new FirefoxDriver();
WebElement check1;

@BeforeMethod
public void OpenBrowser(){
driver1.get("http://google.com");
check1 = driver1.findElement(By.xpath("//input[@name='option1']"));
driver1.manage().window().maximize();
}

@AfterMethod
public void CloseBrowser(){
driver1.quit();
}


@Test
public void Assertion_method1() {
String title = driver1.getTitle();
Assert.assertFalse(check1.isSelected());
System.out.println("title"+title);
}


}


From above Example:

-> Assertion_method1 will get pass and complete all steps if select the check box and return the condition value as False .

-> Assertion_method1 will get fail and skip all steps if unselect the check box and return the condition value as True .

Hard Assertion - assertTrue(condition) Assertion in Selenium Webdriver



-> assertTrue assertion is generally used for boolean condition true.

-> It will pass if condition returns "true". If it will return false then it will fail and skip test execution from that specific method.

-> Syntax for assertTrue assertion is as bellow.

Assert.assertTrue(condition);


Example:

Suppose you want to continue the process if checkbox Selected/Checked.



Example :

package TestNG_Package;

import org.openqa.selenium.WebDriver;
import org.openqa.selenium.firefox.FirefoxDriver;
import org.testng.annotations.AfterMethod;
import org.testng.annotations.BeforeMethod;
import org.testng.annotations.Test;
import org.testng.Assert;

public class TestNG_Test1 {

WebDriver driver1=new FirefoxDriver();
WebElement check1;

@BeforeMethod
public void OpenBrowser(){
driver1.get("http://google.com");
check1 = driver1.findElement(By.xpath("//input[@name='option1']"));
driver1.manage().window().maximize();
}

@AfterMethod
public void CloseBrowser(){
driver1.quit();
}


@Test
public void Assertion_method1() {
String title = driver1.getTitle();
Assert.assertTrue(check1.isSelected());
System.out.println("title"+title);
}


}


From above Example:

-> Assertion_method1 will get pass and complete all steps if select the check box and return the condition value as True .

-> Assertion_method1 will get fail and skip all steps if unselect the check box and return the condition value as False .

This way, Assert.assertTrue(condition) is helps use to assert boolean condition true.

Hard Assertion - Assert.assertNotEquals(actual, expected, message) assertion in Selenium Webdriver



-> It's function is opposite to assertEquals() assertion.

-> Means if both sides values will not match then this assertion will pass else it will fail.

-> Here you can write your own message for failure condition



Example :

package TestNG_Package;

import org.openqa.selenium.WebDriver;
import org.openqa.selenium.firefox.FirefoxDriver;
import org.testng.annotations.AfterMethod;
import org.testng.annotations.BeforeMethod;
import org.testng.annotations.Test;
import org.testng.Assert;

public class TestNG_Test1 {

WebDriver driver1=new FirefoxDriver();

@BeforeMethod
public void OpenBrowser(){
driver1.get("http://google.com");
driver1.manage().window().maximize();
}

@AfterMethod
public void CloseBrowser(){
driver1.quit();
}


@Test
public void Assertion_method1() {
String title = driver1.getTitle();
Assert.assertNotEquals(title,"Home Page","Assertion_method1 has been Executed");
System.out.println("title"+title);
}


}



From above Example,

-> Assertion_Method will get fail and execution goes to next method if title is equal to "Home Page".Then The remaining part in method wont be executed.

-> Assertion_Method will get Pass and execution goes to next method if title is NOT equal to "Home Page".Then The remaining part in method will be executed.

Hard Assertion - Assert.assertEquals(actual, expected) assertion in selenium webdriver





-> This assertion used to compare actual and expected value.
-> If both the values are same means its continue the Execution.
-> IF both the values different means it will mark specifi method as fails immediately and exit from the test method.


You can use different types of values in actual and expected like boolean, byte[], char, double, float, int, etc..


Example :

package TestNG_Package;

import org.openqa.selenium.WebDriver;
import org.openqa.selenium.firefox.FirefoxDriver;
import org.testng.annotations.AfterMethod;
import org.testng.annotations.BeforeMethod;
import org.testng.annotations.Test;
import org.testng.Assert;

public class TestNG_Test1 {

WebDriver driver1=new FirefoxDriver();

@BeforeMethod
public void OpenBrowser(){
driver1.get("http://google.com");
driver1.manage().window().maximize();
}

@AfterMethod
public void CloseBrowser(){
driver1.quit();
}


@Test
public void Assertion_method() {
String title = driver1.getTitle();
Assert.assertEquals(title,"Home Page");
System.out.println("title"+title);
}

@Test
public void Verification_method() {
String title = driver1.getTitle();
if(title=="Home Page)
System.out.println("title"+title);
else
Syste,.out.println("Different Title");
}

}


From above Example,

-> Assertion_Method will get fail and execution goes to next method if title is not equal to "Home Page". The remaining part in method wont be executed.

-> Assertion_Method will get pass and execution goes to next method if title is equal to "Home Page". The remaining part in method will be executed.

-> Verification_Method will run completely if title have any values. Its just verify the values. Its not terminate tthe process.


Hard Assertion and Soft Assertion in Selenium webdriver using TestNG framework




-> Assertion used to verify the result. and if result is not as our expected means its stopped the perticular method execution.

-> There are many assertions available in Selenium WebDriver with TestNG framework and we will look at all of then one by one.

-> Assertions are important and very useful in any automation tools to assert something during your test execution.

-> This pass or fail indication will helps you in your testing process. So this is the very good function in selenium
WebDriver which helps us to find and log issue.

-> Use hard assertions in selenium webdriver only when you wants to skip remaining test execution on assertion fail. If you wants to continue execution on assertion failure, you can use TestNg soft assertions.



Difference between Assertion and Verification

Verification and assertion are not euqal. Both are different.

-> Verification is used to verify the result.

-> Assertion also verify the result. If result is not our expected means its stopped the perticular method execution.



How to use Hard Assertion in Selenium Webdriver

-> We can use pre defined class(Assert) for Hard Assertion. We no need to create object.

-> We use Hard Assertion in Selenium Webdriver like below

Assert.assertEquals(actual, expected)
Assert.assertNotEquals(actual, expected, message)
Assert..assertTrue(condition)
Assert.assertFalse(condition)
Assert.assertNull(object)
Assert.assertNotNull(object)



=========================================================\



Soft Assertion 



-> The hard assertion used to mark method as fail if assertion condition get false and the remaining statements inside the method will be aborted.

-> But the soft Assertion used to mark method as fail if assertion condition get false and the remaining statements inside the method will be continue the process. And also its reports them the Assertion get failure.



How to use Soft Assertion in Selenium Webdriver


-> If you will use soft assertion then your test execution will remain continue even If any assertion fails.

-> The Assertion failure will be reported in the report, so that we can verify at the end of the execution.

-> We can use soft assertion when we have multiple assertions need to be run in same method and execute all assertion even if any one of them fails in between.

-> To use testng soft assertion, you have to use testng SoftAssert class. Its declaration like below,

SoftAssert S_assert = new SoftAssert()

The we can use above object (S_assert) for using same methods which using in Hard Assertion like

S_assert.assertEquals(actual, expected)
S_assert.assertNotEquals(actual, expected, message)
S_assert.assertTrue(condition)
S_assert.assertFalse(condition)
S_assert.assertNull(object)
S_assert.assertNotNull(object)


The above methods used for Soft assertion in Selenium webdriver


This SoftAssert class is not throw the exception if assertion failure and recording failure. 

Parameterize with JXL (Data Driven)

parameterize with JXL


@Test
  public void test () throws BiffException, IOException, InterruptedException
  {
  //Open MyDataSheet.xls file from given location.
  FileInputStream fileinput = new FileInputStream("D:\\MyDataSheet.xls");
  //Access first data sheet. getSheet(0) describes first sheet.
  Workbook wbk = Workbook.getWorkbook(fileinput);
  Sheet sheet = wbk.getSheet(0);
 
  //Read data from the first data sheet of xls file and store it in array.
  String TestData[][] = new String[sheet.getRows()][sheet.getColumns()];
 
  //To enable Last Name text box.
  JavascriptExecutor javascript = (JavascriptExecutor) driver;
  String toenable = "document.getElementsByName('lname')[0].removeAttribute('disabled');";
  javascript.executeScript(toenable);
   
  //Type data in first name and last name text box from array.
  for(int i=0;i<sheet.getRows();i++)
  {
   for (int j=0;j<sheet.getColumns();j++)
   {
    TestData[i][j] = sheet.getCell(j,i).getContents();
    if(j%2==0)
    {
     driver.findElement(By.xpath("//input[@name='fname']")).sendKeys(TestData[i][j]);
    }
    else
    {
     driver.findElement(By.xpath("//input[@name='lname']")).sendKeys(TestData[i][j]);
    }
   }
   Thread.sleep(1000);
   driver.findElement(By.xpath("//input[@name='fname']")).clear();
   driver.findElement(By.xpath("//input[@name='lname']")).clear();
  }
  Thread.sleep(1000);
 
  }

Friday, 15 August 2014

Array Functions in QTP


1)Array() in QTP


-> The Array function returns a  variant containing an array.

-> The first element of array index is zero.



Syntax

Array(arglist)


Here,

arglist - Required. Its contains value seperated by comma. and values represented as array.


Example:


a=array(3,5,8)
msgbox a(1)


Here the values are,

a(0)=3
a(1)=5
a(2)=8




2) Filter() in QTP

-> Filter function used to create another array variable from another array variable by using some filter creteria.


Syntex:

Filter(Source_arrayvariable,value[,include[,compare]])


Here,


Source_arrayvariable = Required. one dimensional array. This is source string

value = Required. Used for search string in Source_arrayvariable. Its case- sensitive.

include = Optional, Boolean value
 True = Default. Return String as per matched with above given value.
 False = Return string that is not matched as per above given value.
Compare = Optional. Specifies the string comparison to use.
0 = vbBinaryCompare - Perform a binary comparison
1 = vbTextCompare - Perform a textual comparison



Return Values:

Return new array with values from Source_arrayvariable as per the filter creteria.



Example:


a=Array("Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday")
b=filter(A,"Sun",true)
For each str  In b
print str
Next



O/P
Sunday




3) IsArray() function in QTP

-> IsArray() returns boolean value and its indicates that given variable is array variable or normal variable.

->  If the variable is an array, it returns True, otherwise, it returns False.


Syntex :

IsArray(variable)

Variable : Required. Any variable


Return type:

True : If the variable is an array
False : If the variable is NOT an array,


Example:

a=Array("Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday")
print msgbox(IsArray(A))


O/P

TRUE



4) Join() funtion in QTP

The Join() function used to join all elements from array.


Syntex:

Join(Array_Variable[,delimiter])

Here,

Array_Variable = Required. one dimensional array variable name.
delimiter = optional, used to add delemiter char with end of all element(Sub String) in given array variable.


Return Types:

Its return String which contains all number of element (substrings) in an array.


Example :

a=Array("Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday")
print join(a,"#")

o/p

Sunday#Monday#Tuesday#Wednesday#Thursday#Friday#Saturday



5) Split Function in QTP


Split function used to zero based, one dimensional array that contains specified number of sub string.


Syntax:

Split(expression[,delimiter[,count[,compare]]])

Here,


6) LBound Function in QTP

Returns the smallest subscript for the indicated dimension of an array

LBound(arrayname[,dimension])





7) UBound Function in QTP

Returns the largest subscript for the indicated dimension of an array


UBound(arrayname[,dimension])

String Function in QTP



1) Instr function in QTP

Instr returns first occurance of the string1 with in another string2.

Syntex:

Instr([start,] String1,String2, [compare])

Here,

Start   = optional, Postion of the start search from String1
String1 = Required, This is main String.
String2 = Required, This is sub String to be search in String2
Compare = Optional, Specifies the string comparison to use. Default is 0

 Can have one of the following values:

 0 = vbBinaryCompare - Perform a binary comparison
     1 = vbTextCompare - Perform a textual comparison



Return Values :

0      -> If String1 is ""
0       ->  If String2 is not found
0           -> if start > len(String1)
Null       -> If String1 is Null
Null       -> If String2 is Null
Start val   -> If Strin2 is ""
position val-> If string2 is found within string1



Example :

Instr(1,"The QTP Tutorial","T")

o/p 1


2) InStrRev function in QTP

InstrRev returns first occurance of the String1 with in another string. The search begin starts from end of the string. But position returned counts from the beginning of the string.


Syntex:

InStrRev(String1,String2[,start],[compare])

Here,

String1 = Required, This is main String.
String2 = Required, This is sub String to be search in String2
Start   = Optional. Specifies the starting position for each search. The search begins at the last character position by default (-1)
Compare = Optional. Specifies the string comparison to use. Default is 0

 Can have one of the following values:

 0 = vbBinaryCompare - Perform a binary comparison
     1 = vbTextCompare - Perform a textual comparison



Return Values :

0      -> If String1 is ""
0       ->  If String2 is not found
0           -> if start > len(String1)
Null       -> If String1 is Null
Null       -> If String2 is Null
Start val   -> If Strin2 is ""
position val-> If string2 is found within string1


Example :

Instr(1,"The QTP Tutorial","a")

o/p 11



3) Lcase function in QTP

Converts specified string to lower case.

Syntex:

Lcase(String)

Here,

String = Required, string to be change lower case.



4) Ucase function in QTP

Converts specified string to upper case.

Syntex:

Ucase(String)

Here,

String = Required, string to be change upper case.







5) Left function in qtp

Left function used to returns number of characters from left side of the string.

Syntex:

Left(string1,length)

Here,

String1 = Required, Main string used to returns character from.
lenght  = Required, Specifies how many characters to return from left side of the string.


Return values

if length = 0      -> Returns Empty String ""
if length >= len(String) -> Returns full String
if lenght < len(string)    -> Returns number of character from left side


Example :

left("This is QTP tutorial",11)

o/p "This is QTP"





6) Right function in qtp

Right function used to returns number of characters from right side of the string.

Syntex:

Right(string1,length)

Here,

String1 = Required, Main string used to returns character from.
length  = Required, Specifies how many characters to return from right side of the string.


Return values

if length = 0      -> Returns Empty String ""
if length >= len(String) -> Returns full String
if lenght < len(string)    -> Returns number of character from right side


Example :

left("This is QTP tutorial",11)

o/p "TP tutorial"




7) Len Function in QTP

Len function used to returns the number of characters from given string.

Syntex:

Len(String)

Here,

String = Required

Example:

len("qtp")

o/p 3



8) Ltrim function in QTP

Ltrim Function used to remove spaces from left side.

Syntex:

Ltrim(String)

Here,

String = Required

Example:

len("qtp  ")

o/p qtp


9) Ltrim function in QTP

Rtrim Function used to remove spaces from right side.

Syntex:

Rtrim(String)

Here,

String = Required

Example:

len("  qtp")

o/p qtp



10) Trim function in QTP

Trim Function used to remove spaces from both side.

Syntex:

Ltrim(String)

Here,

String = Required

Example:

len("  qtp  ")

o/p qtp   



11) Mid function in QTP

Mid function returns number of characters from given string

Syntax

Mid(string,start[,length])

Here,

String = Required, The string which char can be returned
Start  = Required, Specifies the starting position.
lenght = optional, the number of characters to be returned.

Return values,

If start > len(String) = Return empty string ("")

Ex:

mid("This is QTP Tutorial",1,4)

o/p  This




12) Replace function in QTP

Replace the specified number of string with in one another.

Syntex:

Replace(String,Find,ReplaceWith[,Start[,Count[,compare)

Here,

String      = Required. Main String used to replace
Find    = Required, THis is String which is find in the main String for replacement
ReplaceWith = Required, Substring which is going to replace in main string.
Start       = Optional, From which postion from main string going to search and replace. Default is 1. All characters before the start position will be removed.
count       = Optional, number of replacement in Main String. Default value is -1, which means make all possible substitutions
compare       = Optional, Specifies the string comparison to use. Default is 0

 Can have one of the following values:
 0 = vbBinaryCompare - Perform a binary comparison
        1 = vbTextCompare - Perform a textual comparison   



Example :

Replace("This is a beautiful day!","i","##",2,2)

o/p  "h##s ##s a beautiful day!"




13) Space function in QTP

The Space function returns a string that consists of a specified number of spaces.


Syntax

Space(number)


Here,

number    = Required. The number of spaces you want in the string


Example

space(3)

o/p "   "



14) Strcomp function in QTP

The Strcomp function used to comapare the two string and return the values as per the result of comparison.

Syntax:

StrComp(string1,string2[,compare])

String1 = Required.
String2 = Required.
compare = Optional, Specifies the string comparison to use. Default is 0

 Can have one of the following values:
 0 = vbBinaryCompare - Perform a binary comparison
        1 = vbTextCompare - Perform a textual comparison


Return values,

-1    = if string1 < string2
0    = if string1 = string2
1    = if string1 > string2
Null    = if string1 or string2 is Null





15) String function in QTP

The String function returns the string with contains given number of continuous character.

Syntex:

String(Number,character)


Here,

number     = Required. The length of the returned string
character = Required. The character that will be repeated


Return values,

if character = "more than one letter"  -> It consists first letter of that string.

Example:

String(4,H)   ->  O/P  HHHH
String(4,"

How to use FOR EACH loop in QTP



-> FOR EACH loop used to execute every single element or item in a group.

-> Normally its used to like

1) Every single element in an Array
2) Every single files in a folder
3) Every character in a String

in these type of situation we can use FOR EACH loop.

Syntex

For Each [Item] In [Group]
   [loopBody]
Next [Item]


Example :

a=Array("Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday")

For each str In a
print str
Next

output :

Sunday
Monday
Tuesday
Wednesday
Thursday
Friday
Saturday



From above example, we print the every element in array.


GetAttribute Method in Selenium





-> This method used to Gets the value of the specified attribute for this Web element.

Syntex:

WebElement.GetAttribute("Attribute_Name")

o/p

Returns the value of the Attribute name.



Example:



Source :

<a id="link1" href="http:gmail.com">
<span lang="LBLSHOVIDEOS">Selenium</span></a>


Script :


String attr1=driver1.findElement(By.linkText("Selenium")).getAttribute("id");
System.out.println("Attribute ID Value="+attr1);

String attr2=driver1.findElement(By.linkText("Selenium")).getAttribute("href");
System.out.println("Attribute HREF Value="+attr2);



O/P :

Attribute ID Value= Link1

Attribute HREF Value=http:gmail.com

Data driven testing in TestNG (Using @DataProvider annotaion)





-> @DataProvider annotations in TestNG is important for data driven framework in selenium.

-> @DataProvider Annotation of testng framework provides us a facility of storing and preparing data set In method.

-> Task for @DataProvider Annotation is supplying data for test method. That means we can configure data with in the @DataProvider annotations and use those data inside the @Test methods.

-> @dataprovider method should return an Object[][] with data.

-> we have to create two dimensional array in @DataProvider annotation data to stored the data.



Example:


Bellow given example will retrieve userid and password one by one from @DataProvider annotated method and will feed them In LogIn_Test(String Usedid, String Pass) one by one. Run this example In your eclipse and observe result.



public class Sample_Login {

 WebDriver driver = new FirefoxDriver();


 @BeforeTest
    public void setup() throws Exception {
         driver.manage().window().maximize();
         driver.manage().timeouts().implicitlyWait(15, TimeUnit.SECONDS);
         driver.get("http://only-testing-blog.blogspot.in/2014/05/login.html");
    }


  @AfterTest
 public void tearDown() throws Exception {
   driver.quit();
     }


 //This method will return two dimensional array.
 //This method behaves as data provider for LogIn_Test method.

 @DataProvider

 public Object[][] LoginCredentials(){

  //Created two dimensional array with 4 rows and 2 columns.
  //4 rows represents test has to run 4 times.
  //2 columns represents 2 data parameters.

 Object[][] Cred = new Object[4][2];

  Cred[0][0] = "UserId1";
  Cred[0][1] = "Pass1";

  Cred[1][0] = "UserId2";
  Cred[1][1] = "Pass2";

  Cred[2][0] = "UserId3";
  Cred[2][1] = "Pass3";

  Cred[3][0] = "UserId4";
  Cred[3][1] = "Pass4";
  return Cred; //Returned Cred
 }



 //Give data provider method name as data provider.
 //Passed 2 string parameters as LoginCredentials() returns 2 parameters In object.

 @Test(dataProvider="LoginCredentials")

 public void LogIn_Test(String Usedid, String Pass){
   driver.findElement(By.xpath("//input[@name='userid']")).clear();
   driver.findElement(By.xpath("//input[@name='pswrd']")).clear();
   driver.findElement(By.xpath("//input[@name='userid']")).sendKeys(Usedid);
   driver.findElement(By.xpath("//input[@name='pswrd']")).sendKeys(Pass);
   driver.findElement(By.xpath("//input[@value='Login']")).click();
   String alrt = driver.switchTo().alert().getText();
   driver.switchTo().alert().accept();
   System.out.println(alrt);
  }
}




testng.xml file to run this example Is as bellow.


<suite name="Simple Suite">
 <test name="Simple Skip Test">
  <classes>
   <class name = "Testng_Pack.Sample_Login"/>
  </classes>
 </test>
</suite>




After run the above code, the user id and password entered one by one in above URL.

Selenium WebDriver Parallel Tests Execution Using TestNG - @Parameters




-> Browser compatibility testing Is most Important thing for any web application and generally you have to perform browser compatibility testing before 1 or 2 days of final release of application. In such a sort time period, you have to verify each Important functionality In every browsers suggested by client.


-> If you will go for running your all webdriver tests In each browsers one by one then It will take too much time to complete your test and you may not complete It before release.

-> In such situation, Running your tests In all required browsers at same time will helps you to save your time efforts.

-> The above situation solved in selenium by using @Parameters annotation in TestNG framework.



Parallelism In TestNG


We can configure our TestNG.xml file in such a way to run our test suite or tests or methods in seperate browsers Is known as parallelism In TestNG.


ParellelTestng.java


package TestNG_Package;

import org.openqa.selenium.WebDriver;
import org.openqa.selenium.firefox.FirefoxDriver;
import org.testng.annotations.AfterMethod;
import org.testng.annotations.BeforeMethod;
import org.testng.annotations.Test;

public class TestNG_Test1 {

 private  WebDriver driver1=null;

  @BeforeClass
  @Parameters ({"browser"})

  public void setup(String browser)
 {
   if (browser.equals("FFX"))
  {
     System.out.println("Test Starts Running In Firefox Browser.");
     driver1 = new FirefoxDriver(); 
    }
  else if (browser.equals("CRM"))
  {
     System.out.println("Test Starts Running In Google chrome.");
     System.setProperty("webdriver.chrome.driver",  "D:\\chromedriver_win32_2.3\\chromedriver.exe");
     driver1 = new ChromeDriver(); 
   }
   driver1.manage().window().maximize();
   driver1.get("http://only-testing-blog.blogspot.in/2014/05/login.html");
  }


 @AfterClass
 public void closebrowser()
 {
    driver1.quit();
 }


 @Test
 public void MethodOne() {

  String a= "Selenium";
  if(a.equals("Selenium")
   throw new SkipException("Skipped");

  String title = driver1.getTitle();
  System.out.println("title"+title);   
 }



 @Test
 public void MethodTwo() {
  String title = driver1.getTitle();
  System.out.println("title"+title);   
 }


}




testng.xml

<suite name="webDriver" parallel="tests">

 <test name="Test In FireFox" >
    <parameter name="browser" value="FFX" />
    <classes>
      <class name="Testng_Pack.Test_Parallel" />
    </classes>
  </test>

   <test name="Test In Google Chrome" >
    <parameter name="browser" value="CRM"></parameter>
    <classes>
      <class name="Testng_Pack.Test_Parallel"></class>
    </classes>
  </test>

</suite>




From above example we can run same test in both Chrome and FireFox at same time.

From above Testng.xml file

-> parallel="tests" which inside <suite> tag will instruct TestNG to consider method of each <test> tag as seperate Thread. that Means If you wants to run your test In 2 different browsers then you need to create two <test> blocks for each browser Inside testng.xml file.

-> Inside each <test> tag block, define one more tag "parameter" with same name(In both <test> block) but with different values.Its used to pass in ParellelTestng.java method.



From ParellelTestng.java

-> Here we are used @Parameters annotation to pass parameter in method.Values of this parameter will be feed by testng.xml file.

-> If condition will check that value to decide which driver to use for test. This way, example testng.xml file will feed two values(FFX and CRM) In parameter so It will open Firefox and Google chrome browsers and run test In both browsers

How To Skip WebDriver Test In TestNG





We can skip the execution from perticular test by using throw new SkipException() exception. THis is TestNG exception.

Sometimes you need to check some condition like If some condition match then skip test else perform some action In your webdriver test. In this kind of situation, you can use SkipException() exception.


Consider below example




package TestNG_Package;

import org.openqa.selenium.WebDriver;
import org.openqa.selenium.firefox.FirefoxDriver;
import org.testng.annotations.AfterMethod;
import org.testng.annotations.BeforeMethod;
import org.testng.annotations.Test;

public class TestNG_Test1 {
WebDriver driver1=new FirefoxDriver();
@BeforeMethod
public void OpenBrowser(){
driver1.get("http://google.com");
driver1.manage().window().maximize();
}
@AfterMethod
public void CloseBrowser(){
driver1.quit();
}
@Test
public void MethodOne() {

String a= "Selenium";
if(a.equals("Selenium")
throw new SkipException("Skipped");

String title = driver1.getTitle();
System.out.println("title"+title);   
}



@Test
public void MethodTwo() {
String title = driver1.getTitle();
System.out.println("title"+title);   
}


}



o/p

MethodOne Skipped due to SkipException()
MethodTwo executed


From above example if execution throw SkipExeption() means the rest of the commands inside the method wont get executed. Its skipped from current method and control goes to next method.

Include/Exclude Selenium WebDriver Test Package From Test Suite Using testng.xml




We can include or exclude selenium webdriver from test suite using below steps


1) Create new package and classes as below

TestNGOnePack(package) -> BaseClassOne.java, ClassOne.java, ClassTwo.java
TestNGTwoPack(package) -> ClassOne.java, ClassTwo.java
TestNGThreePack(package) -> ClassOne.java, ClassTwo.java


2) Include perticular package from test suite


<suite name="Suite One">
  <test name="Test One" >
     <packages>
        <package name=".*">
           <include name="TestNGOnePack" > </include>
        </package>
     </packages>
  </test>
</suite>


We can execute only "TestNGOnePack", "TestNGThreePack" package from this execution. We exclude "TestNGTwoPack" package from execution.


3) Exclude Perticular package from test suite execution



<suite name="Suite One">
  <test name="Test One" >
     <packages>
        <package name=".*">
           <exclude name="TestNGOnePack" > </exclude>
        </package>
     </packages>
  </test>
</suite>

We can execute only  "TestNGTwoPack","TestNGThreePack" package from this execution. We exclude "TestNGOnePack" package from execution.So its not get execute.

Include/Exclude Only Selected Test Methods from class Test Suite Using testng.xml





Its possbile we can include or exclude selected test method from any class.


1) Create new package and classes as below

TestNGOnePack(package) -> TestNG_Test1.java

2) And BaseClassOne.java have before methods

TestMethod1(),TestMethod2(),TestMethod3()



3) Include test method from class for execution


<suite name="TestNG_Suite">
<test name="TestNG_Test">
<classes>
<class name="TestNGOnePack.TestNG_Test1"></class>
<methods>
<include name="TestMethod1"> </include>
<include name="TestMethod2"> </include>
</methods>
</classes>
</test>
</suite>



From above example, we execute only TestMethod1 and TestMethod2 in execution. But the TestMethod3 is not executed.




4) Exclude Test Method from class for execution.


<suite name="TestNG_Suite">
<test name="TestNG_Test">
<classes>
<class name="TestNGOnePack.TestNG_Test1"></class>
<methods>
<exclude name="TestMethod1"> </exclude>   
</methods>
</classes>
</test>
</suite>



From above example, we execute only TestMethod2(),TestMethod3() in execution. But TestMethod1() is exclude from execution. So its not executed.

Configure testng.xml In Eclipse For Selenium WebDriver To Run All Or Specific Package



TestNG is very useful and powerful framework for selenium webdriver. We need to configure our tests based on our requirements or test scenarios.


Create new package and classes as below


TestNGOnePack(package) -> BaseClassOne.java, ClassOne.java, ClassTwo.java
TestNGTwoPack(package) -> ClassOne.java, ClassTwo.java
TestNGThreePack(package) -> ClassOne.java, ClassTwo.java



Configure testng.xml to run selected packages from all packages of webdriver project in single test suite


From three packages, I wants to run only two packages -> "TestNGTwoPack" and "TestNGThreePack". For that we need to configure testng.xml as bellow.

<suite name="Suite One">
 <test name="Test One" >
  <packages>
   <package name="TestNGTwoPack" />
   <package name="TestNGThreePack" />
  </packages>
 </test>
</suite>


In above example <packages> tag used to describe group of packagesand  is used to add specific package in our test suite.

So when you run above testng.xml file, It will run only targeted two packages(TestNGTwoPack, TestNGThreePack). Other (TestNGOnePack)package(s) will be excluded from execution.


Configure testng.xml to run all packages of project in single test suite

If you wants to run all packages of your project, you can configure your testng.xml using wildcard(.*) with package tag as bellow.

<suite name="Suite One">
 <test name="Test One" >
  <packages>
   <package name=".*" />  
  </packages>
 </test>
</suite>

Configure testng.xml In Eclipse For Creating Web Driver test using classes from different packages.



For example we create new packages and classes using below steps,

Step 1. Create package = "TestNGOnePack" with classes = BaseClassOne.java, ClassOne.java and ClassTwo.java

Step 2. Create package = "TestNGTwoPack" under same project and add ClassOne.java and ClassTwo.java files

Step 3. Create package = "TestNGThreePack" under same project and add ClassOne.java and ClassTwo.java file



Here i dont want to execut all classes from all packages. I need some selected classes from selected packages. like like TestNGOnePack.ClassOne, TestNGTwoPack.ClassTwo, TestNGThreePack.ClassOne and TestNGThreePack.ClassTwo


Here we need to configure testng.xml file as below

<suite name="Suite One">
 <test name="Test One" >
  <classes>
   <class name="TestNGOnePack.ClassOne" />
   <class name="TestNGTwoPack.ClassTwo" />
   <class name="TestNGThreePack.ClassOne" />
   <class name="TestNGThreePack.ClassTwo" /> 
  </classes>
 </test>
</suite>


This way we can configure our test suite using only specific class from different packages

Configure testng.xml In Eclipse For Create single or multiuple class run under single or multiple test.



We can create any number of class may run under in any number of test in same execution by using testng.xml file.


For Example:


1. BaseClassOne.java
package TestNGOnePack;

import java.util.concurrent.TimeUnit;

import org.openqa.selenium.WebDriver;
import org.openqa.selenium.firefox.FirefoxDriver;
import org.testng.annotations.AfterSuite;
import org.testng.annotations.BeforeSuite;

public class BaseClassOne {

    public static WebDriver driver = new FirefoxDriver();

    //@BeforeSuite annotation describes this method has to run before all suites
    @BeforeSuite
    public void setup() throws Exception {
         driver.manage().window().maximize();
         driver.manage().timeouts().implicitlyWait(15, TimeUnit.SECONDS);
         driver.get("http://only-testing-blog.blogspot.in/2013/11/new-test.html");
    }

    //@AfterSuite annotation describes this method has to run after execution of all suites
    @AfterSuite
         public void tearDown() throws Exception {
         driver.quit();
    }
}
Above class will be used as base class to initialize and close webdriver instance.


2. ClassOne.java
package TestNGOnePack;

import org.testng.annotations.Test;

public class ClassOne extends TestNGOnePack.BaseClassOne{

 //@Test annotation describes this method as a test method
 @Test
  public void testmethodone() {
    String title = driver.getTitle();
    System.out.print("\nCurrent page title is : "+title);
    String Workdir = System.getProperty("user.dir");
    String Classpackname = this.getClass().getName();
    System.out.print("\n'"+Workdir+" -> "+Classpackname+" -> testmethodone' has been executed successfully");
  }
}

Above ClassOne is inherited from BaseClassOne.



3. ClassTwo.java
package TestNGOnePack;

import org.testng.annotations.Test;

public class ClassTwo extends TestNGOnePack.BaseClassOne{

 //@Test annotation describes this method as a test method
 @Test
  public void testmethodone() {
  driver.navigate().to("http://only-testing-blog.blogspot.in/2014/01/textbox.html");
  String title = driver.getTitle();
  System.out.print("\nCurrent page title is : "+title);
  String Workdir = System.getProperty("user.dir");
  String Classpackname = this.getClass().getName();
  System.out.print("\n'"+Workdir+" -> "+Classpackname+" -> testmethodone' has been executed successfully");
  }
}




We can create above two class as Classone.java and ClassTwo.java. Then we create testng.xml file as below for run under same test or multiple test.


Configure testng.xml to run two classes in one test

<suite name="Suite One" >
 <test name="Test One" >
  <classes>
   <class name="TestNGOnePack.ClassOne" />
   <class name="TestNGOnePack.ClassTwo" />
  </classes>
 </test>
</suite>


When test execuion get complete we can see the both class are run under same test.



Configure testng.xml to run two classes in two tests

.
Now if you wants to run both classes as separate test then you have to configure your testng.xml file as bellow.



<suite name="Suite One" >
 <test name="Test One" >
  <classes>
   <class name="TestNGOnePack.ClassOne" /> 
  </classes>
 </test>
 <test name="Test Two" >
  <classes>
   <class name="TestNGOnePack.ClassTwo" />
  </classes>
 </test>
</suite>

Configure testng.xml In Eclipse For Creating And Running WebDriver Test Suit Using testng.xml File



Usage Of testng.xml File

In TestNG framework, We need to create testng.xml file for below purpose

-> To create and handle multiple test classes.

-> we can configure our web test as per our needs in testng.xml file.

-> we can set dependency

-> include or exclude any method or any classes or any package.

-> Set Priority



Creating TestNG.xml file



1) For creating testNG.xml file, we need to right click on project -> New-> file -> open new file wizard

2) In New File wizard select project and give file name as "TestNG.xml" and then click Finish button.

3) It will add TestNG.xml file under our current project.

4) Then add below lines in TestNG.xml file (Select Source tab for type below code in Eclipse)


<suite name="TestNG_Suite">
<test name="TestNG_Test">
<classes>
<class name="TestNG_Package.TestNG_Test1"></class>
</classes>
</test>
</suite>



Here,

-> <suite> :

 suite tag defines the TestNG suite. You can give any name to your suite using 'name' attribute. In above given example, We have given "Suite One" to our test suite.


-> <test> :

test tag defines the TestNG test. You can give any name to your test using 'name' attribute. In above given example, We have given "Test One" to our test.


-> <classes> :

classes tag defines multiple class. We can multiple test class under classes tag. In our example we have only one class.


-> <class> :

class tag defines the class name which you wants to consider in test execution.


Example :

In above given example, we have defined name="TestNG_Package.TestNG_Test1"

Here 'TestNG_Package' describes package name
and 'TestNG_Test1' describes class name.

So in above example we are going to run only one class.



5) Running TestNG.xml file


Right click on testng.xml file -> Run As -> Select TestNG Suite

It will start execution of Test_Test1 class.



6)  View test execution HTML report generated by TestNG


- Right click on Project named as "TestNG_Project and select Refresh.

- then Folder with name = "test-output" will be created under your project folder.

- Explorer that "test-output" folder. then we can see the "index.html" file.

- Right click on "index.html" file then select open with -> Web browser - To see the HTML report in Eclipse.

Thursday, 14 August 2014

Steps for Create and Run TestNG testcase in Eclipse



Let me describe you steps of writing your first test case with TestNG.


1) Create New Project and New package for TestNG

- File -> New -> Java Project -> give new project name as "TestNG_Project"

- Richt click on "src" inside project name as "TestNG_Project" -> New -> Package -> give name as TestNG_Package



2) Add TestNG library


- Goto your project's Properties -> Java Build Path -> Libraries Tab.

- Click on Add Library button -> Select TestNG from Add Library popup and then click on Next and Finish buttons.

- And then verify it will add TestNg library in your project under library tab. Now click on OK button to close that window.



3) Create TestNG Class

- TO create TestNG class is different steps compare to create normal class in java project. Follow below steps to create TestNG class

- Right click on package as TestNG_package and click -> new -> other - it will open new wizard window

- Select TestNG from new wizard window and click on next button.

- on next screen add class name as "TestNG_Test1" and click finish.

- It will as new class as "TestNG_class1" under TestNG_Project with below coding.


package TestNG_Package;


public class TestNG_Test1 {

@Test
public void f(){
}
}




4) Add/write sample webdriver test script.

Write your own test script or add bellow given script in TestNG class file.




package TestNG_Package;

import org.openqa.selenium.WebDriver;
import org.openqa.selenium.firefox.FirefoxDriver;
import org.testng.annotations.AfterMethod;
import org.testng.annotations.BeforeMethod;
import org.testng.annotations.Test;

public class TestNG_Test1 {
WebDriver driver1=new FirefoxDriver();
@BeforeMethod
public void OpenBrowser(){
driver1.get("http://google.com");
driver1.manage().window().maximize();
}
@AfterMethod
public void CloseBrowser(){
driver1.quit();
}
@Test
public void f() {
String title = driver1.getTitle();
System.out.println("title"+title);   
}
}





5)  Run Webdriver test script with TestNG


- Go to Run -> Run As -> And Click on TestNg Test

- It will run your webdriver test with TestNG.

- we can the result after complete the execution.



6)  View test execution HTML report generated by TestNG


- Right click on Project named as "TestNG_Project and select Refresh.

- then Folder with name = "test-output" will be created under your project folder.

- Explorer that "test-output" folder. then we can see the "index.html" file.

- Right click on "index.html" file then select open with -> Web browser - To see the HTML report in Eclipse.


(Also the testng-customsuite.xml file will create automatically and configure the web driver test. Path = C:\Users\arunraj\AppData\Local\Temp\testng-eclipse--360075510\testng-customsuite.xml)

Steps for Downloading And Installing Testng In Eclipse For WebDriver



-> TestNG is very powerful and easy to use framework and it is supported by tools like Eclipse, Maven, IDEA, etc..

-> Here we are going to use TestNG Framework with Eclipse so obviously you must have installed latest Java development kit (JDK) in your system and you must have Eclipse.




TestNG Installation Steps In Eclipse


Refer this link -> http://www.softwaretestingmentor.com/selenium-tutorials/how-to-setup-testng-with-selenium-webdriver-in-eclipse-ide/


1) Open Eclipse and go to Menu Help -> Install New Software. It will open new software installation window.

2) In new software installation window, Type http://beust.com/eclipse exactly in Work with field and click on Add button.

For Eclipse 3.4 and above, enter http://beust.com/eclipse.
For Eclipse 3.3 and below, enter http://beust.com/eclipse1.

3) Type name as "TestNG" and select "ok"

4) TestNG should get displayed under the name section, select the TestNG check box, click next and finish installation. ( Note: If TestNG already installed, then Next button is disabled.).

5) Restart eclipse to finalize installation. After restarting eclipse TestNG will get configured automatically in eclipse IDE.






Error facing while install TestNG with eclipse.


We may face after step(3) - Type name as "TestNG" and select "ok".  like below


" Problem occurred

"installing Software" has encountered a problem.

An error occurred while collecting items to be installed "


So we need to restart Eclipse and then follow the steps in above TestNG Installation Steps In Eclipse.





How to verify TestNG installed successfully in Eclipse


-> Once you have installed the plug-in, restart Eclipse

-> select the menu Window -> Show View -> Other

-> Select Java category, then we can see the TestNG is listed.

-> And Click the Testng and observe the below scenario.

1) If TestNG tab will open in console without any error then TestNG installed Successfully.
2) If TestNG tab will open in console with any error then TestNG not installed Successfully.
3) If TestNG is not listed under Java category then the TestNG is not installed in our eclipse.

Similarities and Difference Between Junit and TestNG Framework For WebDriver




Similarities Between JUnit and TestNG


1) We can create test suite in JUnit and TestNG both frameworks.

2) Timeout Test Is possible very easily in both the frameworks.

3) We can ignore specific test case execution from suite in both the frameworks.

4) It is possible to create expected exception test in both the frameworks.

5) Annotations - Few annotations are similar in both frameworks suite like @Test, @BeforeClass, @AfterClass. JUnit's Annotations @Before and @After are similar to TestNG's @BeforeMethod and @AfterMethod annotations.




Difference Between JUnit and TestNG


1) In TestNG, Parameterized test configuration is very easy while It is very hard to configure Parameterized test in JUnit.

2) TestNG support group test but it is not supported in JUnit.

3) TestNG has a feature to configure dependency test. Dependency test configuration is not possible in JUnit.

4) TestNG support @BeforeTest, @AfterTest, @BeforeSuite, @AfterSuite, @BeforeGroups, @AfterGroups which are not supported in JUnit.

5) Test prioritization, Parallel testing is possible in TestNG. It is not supported by JUnit.

Introduction Of TestNG




-> TestNG is unit testing framework. and its most popular among all java developers and selenium webdriver automation test engineers.

-> TestNG's development is inspired from combination of NUnit and JUnit. Its have all features from JUnit and also its have more features comapare to JUnit.



TestNG Annotations

-> The main reason behind TestNG's popularity is we can create and configure test case and test suite very easily using many different annotations of TestNG.

-> Few annotations are similiar with JUnit. Also its have more annotations.

-> Annotations in TestNG are which guides you what to do next or which method should be exeute next.

-> TestNG has also facility to pass parameters with annotations.


1) @Test
2) @BeforeMethod
3) @AfterMethod
4) @BeforeClass
5) @AfterClass
6) @BeforeTest
7) @AfterTest
8) @BeforeSuite
9) @AfterSuite
10) @DataProvider
11) @BeforeGroups
12) @AfterGroups
13) @Parameters
14) @Factory
15) @Listeners



1) @Test

-> Generally method under @Test used to write all testing related activity.
-> We can have any number of @Test method in single class of our test.



2) @BeforeMethod

-> Any Method which its marked as BeforeMethod will execute before each and every @Test Method Annotations.
-> Generally method under @BeforeMethod used to initializing browser or environment related setup.
-> The method under @BeforeMethod annotation will executed before each @Test annotations. That means if we have four @Test annotaions in your class, then the @BeforeMethod will execute four times.
-> Its same as @Before annoation in JUnit.



3) @AfterMethod

-> Any Method which its marked as BeforeMethod will execute after each and every @Test Method Annotations.
-> Generally method under @BeforeMethod used to close the instances.
-> The method under @AfterMethod annotation will executed after each @Test annotations. That means if we have four @Test annotaions in your class, then the @AfterMethod will execute four times.
-> Its same as @After annoation in JUnit.



4) @BeforeClass

-> Methods under @BeforeClass will execute before any one of the first test method starts execution.
-> It will execute only once even if there are multiple @Test method in our class.



5) @AfterClass

-> The method under @AfterClass will execute all the completion of @Test methods exection in class.
-> It will execute only once even if there are multiple @Test method in our class.



6) @BeforeTest

-> @BeforeTest annotated method will be executed before the any @Test annotated method of those classes which are inside <test> tag in testng.xml file.



7) @AfterTest

-> @AfterTest annotated method will be executed when all @Test annotated methods completes its execution of those classes which are inside <test> tag in testng.xml file.



8) @BeforeSuite

-> Method marked with @BeforeSuite annotation will run before the all suites from test.



9) @AfterSuite

-> @AfterSuite annotated method will start running when execution of all tests executed from current test suite.



10) @DataProvider

When you use @DataProvider annotation for any method that means you are using that method as a data supplier. Configuration of @DataProvider annotated method must be like it always return Object[][] which we can use in @Test annotated method.
VIEW PRACTICAL EXAMPLE OF @DataProvider ANNOTATION


11) @BeforeGroups

@BeforeGroups annotated method will run before the first test run of that specific group.


12) @AfterGroups

@AfterGroups annotated method will run after all test methods of that group completes its execution.


13) @Parameters

When you wants to pass parameters in your test methods, you need to use @Parameters annotation.
VIEW PRACTICAL EXAMPLE OF @Parameters ANNOTATION


14) @Factory

When you wants to execute specific group of test cases with different values, you need to use @Factory annotation. An array of class objects is returned by @Factory annotated method and those TestNG will those objects as test classes.

 
15) @Listeners

@Listeners are used to with test class. It is helpful for logging purpose.



Major Features


1) TestNG has a built in multiple Before and After and other annotations like @BeforeSuite, @AfterSuite, @BeforeTest, @BeforeGroups, @DataProvider, @Parameters, @Test etc.. All the TestNG annotations are very easy to understand and implement.

2) we can configure dependent test method. That means Test1() is dependent to Test2(). or else if test we cn configure if test1() is fail means Test1() has to be execute or not.

3) There is not required to extend any class in TestNG

4) We can configure our test suite using test methods, classes, packages, groups, etc.. in single testng.xml file.

5) Support of configuring test groups like backendtest-group, frontendtest-group etc..

6) we can also tell TestNG to execute only specific group/groups.

7) TestNG is supported by many tools and plug-ins like Eclipse, Maven, IDEA, etc..

8) TestNG has built in HTML report and XML report generation facility. It has also built in  logging facility.

9) Support for data-driven testing (with @DataProvider).

10) Flexible test configuration.

11) Ability to re-execute failed test cases.

12) TestNG also supports
-> parallel testing
-> Parameterization (Passing parameters values through XML configuration)
-> Data Driven Testing(executing same test method multiple times using different data)



How to use For Each loop in Java



-> It was introduced in JDK 1.5

-> Its mainly used to traverse the elements from array or collections.

-> The advantage of for-each loop is that it eliminates the possibility of bugs and makes the code more readable.


Syntex:

for(data_type variable : array | collection)
{

}


Example :

class ForEachExample1{ 
  public static void main(String args[]){ 
   int arr[]={12,13,14,44}; 
 
   for(int i:arr){ 
     System.out.println(i); 
   } 
 
 }  

     

Output:12
       13
       14
       44

Tuesday, 8 July 2014

How to navigate URL, Back and forward using selenium webdriver


-> Navigate URL

If we want to naviagte another URL from current URL then we can use below commands for navigate URL.

driver1.navigate().to("www.gmail.com")


-> Back

If we want to back from the current URL same as click "back" button in browser, then we can use below commands.

driver1.navigate().back();


-> forward


If we want to forward from the current URL same as click "forward" button in browser, then we can use below commands.

driver1.navigate().back();

Generate alert in selenium webdriver (using JavascriptExecutor)


-> We can use JavaScriptExecuter for generate alert in selenium webdriver

-> JavaScriptExecuter is very helpful interface in selenium webdriver, because we can use JavaScriptExecuter for run any type of Java script commands.

-> But generating alert in selenium webdriver is rare case for create Automation script. We can use below code for generate alert,


@Test
 public void test () throws InterruptedException
 {
  //Generating Alert Using Javascript Executor
  JavascriptExecutor javascript = (JavascriptExecutor) driver;
  javascript.executeScript("alert('Test Case Execution Is started');");
  Thread.sleep(3000);
  driver.switchTo().alert().accept();
 }

How to store Text of the element in selenium wedriver (using getText())



-> We can use getText() method used to display only the text with in the tag.

-> Its display all text contains with in any tag or element. Its wont display anything if there is not text available.


Example 1:

<a id="SHO">
<span lang="VIDEOS">arunrajvdm</span>
</a>

o/p (web page) arunrajvdm (link)

String ans=driver1.findElement(By.linkText("arunrajvdm")).getText()
System.out.println("Get Videos="+ans);


o/p (Selenium) : arunrajvdm (text)




Example 2:

<li id="li25">
 <b class="font-10">
  <span lang="LBLSKU">This is</span>
  :
 </b>
  official blogger
</li>


o/p (web Page)  This is official blogger


String ans=driver1.findElement(By.id("li25")).getText()
System.out.println("Get Videos="+ans);


o/p (Selenium) : This is official blogger (text)

Its display all the text message with in the <li> tag. So getText() used to display conatins all text with in the tag



Example 3:


<select name="SelectNUmber" class="form-drop">
<option selected="selected" title="1">1</option>
<option  title="2">2</option>
<option  title="3">3</option>
<option  title="4">4</option>
<option  title="6">6</option>

</select>


Code:

Str1=driver1.findElement(By.xpath("//td[3]/select")).getText();
System.out.println("All the TExt ="+Str1);

O/p
All the TExt = 1
2
3
4
6



Example 4:

<select name="SelectNUmber" class="form-drop">
<option selected="selected" title="1">1</option>
<option  title="2">2</option>
<option  title="3">3</option>
<option  title="4">4</option>
<option  title="6">6</option>

</select>


Code:

Str1=driver1.findElement(By.tagName("select")).getText();
System.out.println("All the TExt ="+Str1);


O/p
All the TExt = 1
2
3
4
6

Difference between Click() and Submit() in Selenium



-> Both click() and submit() both are used to click Button in Web page.

-> Selenium Webdriver has one special method to submit any form and that method name Is submit(). submit() method works same as clicking on submit button.


When to use .click() method :

-> You can use .click() method to click on any button.There is no restriction for click buttons.

-> That means element's type = "button" or type = "submit", .click() method will works for both.

-> If button is inside <form> tag or button is outside <form> tag, the click() method will work.



When to use .submit() method :

-> we can use .submit() method for only submit form after click on button.

-> That means element's type = "submit" and button should be inside <form> tag, then only submit() will work.

-> if element's type = "button" means submit() will not work.

-> If button outside of the <form> tag means submit() will not work


For Example, Submit() will work if submit button should be inside <form> tag and element type="submit" as below

<form>
<input id="submitbutton" name="submitbutton" type="submit" value="Next step" class="g-button g-button-submit">
</form>


But click() method will work for all  buttons in webpage with out any restrictions.

Timeout and Expected condition in Selenium Webdriver using JUnit



Sometimes we need to set timeout condition in your test or we need to mention expected consition in selenium webdriver



Timeout Test In JUnit For WebDriver

-> The timeout function used onlt in @Test annotation.
-> Supposing you have written test for one module and you wants to set timeout for your test.
-> Here timeout means allowed maximum time to complete full test.
-> Here Execution allowed for mentioned timeout value. After that mentioned timeout value,it will skip remaining stpes and marked the function as error in console.

Example :

@Test(timeout=1000)
 public void test1(){  
 }

From above example, it will allow 1000 milli sec for execution.

if it will take more than 1000 milli sec for execution means it will skip remaining stes inside the function. And come out from test1() function and test1() marked as error.



Expected Exception Test In JUnit For WebDriver

-> some times we are expecting some exception during your webdriver test execution and that exception which is acceptable.
-> If you are using junit framework for your webdriver test then you can do it very easily.
-> We can specify expected exception condition with @Test annotation as bellow.

@Test(expected = NullPointerException.class)
 public void exceptiontest2() {
 }

Here my expected exception is null pointer exception so my expected condition is NullPointerException.class. You can write your expected exception like IndexOutOfBoundsException.class, ArithmeticException.class, etc.


Example :

@Test(timeout=2000)
 public void test1() throws InterruptedException{
 driver.findElement(By.xpath("//input[@name='fname']")).sendKeys("junittest2 class-test1");
 System.out.print("\njunittest2 class-test1 executed before sleep");
 Thread.sleep(5000);
 System.out.print("\njunittest2 class-test1 executed after sleep");
 }

 @Test
 public void exceptiontest1() {
     throw new NullPointerException();
 }

 @Test(expected = NullPointerException.class)
 public void exceptiontest2() {
  throw new NullPointerException();
 }



Console Output :

Browser open
junittest2 class-test1 executed before sleep
Browser close

-> test1() method is display with error because test was time out after 2000 milisecond as per our condition.
-> exceptiontest2() pass successfully because we have placed expected exception condition with it.
-> exceptiontest1() display with error because there was not any expected exception condition.

How to ignore/exclude test in webdriver using Junit



-> We can use @ignore inbuilt annotation will help us to ignore specific method from test for execution.
-> We need to put @Ignore annotation in test before @Test method which we want to exclude

Example:

If we want to ignore/exclude below test from execution. we need to put @ignore annotation in test before @Test method



package JuintPackage;

import static org.junit.Assert.*;

import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.firefox.FirefoxDriver;

public class Junit_Test1 {

WebDriver driver1=new FirefoxDriver();

@Before
public void beforetest()
{
driver1.manage().window().maximize();
driver1.get("http://google.com");
}

@After
public void aftertest()
{
driver1.quit();
}


@Test
public void Execute_Process()
{

driver1.findElement(By.linkText("Gmail")).click();
}

// ignore below test from execution

@ignore
@Test
public void Execute_SecondProcess()
{

driver1.findElement(By.linkText("Images")).click();
}

}



From above example using @ignore annotation we can ignore/exclude Execute_SecondProcess() method from execution.

Click the Element inside the Span using selenium webdriver



1) If we want to work with any operation inside the span, its better to use xPath to identify the element.

2) if we want to click link by using below coding inside spane mean

<span> Mobiles & Accessories </span>

Then you should use the xPath to find the element, because those text is inside the span.

The below code is used to click the above web element in selenium webdriver

driver1.findElement(By.xPath("/html/body/div[4]/div[3]/div/div/div/div/ul/li[3]/span")).click();

Implement Junit Framework in selenium Webdriver


1) Prework: ( Setup JUnit Framework in eclipse)

Generally you do not need to install junit with eclipse if you have already added external jar files of webdriver  with eclipse. Because required jar file for junit will be already there with webdriver jar files while download from this site -> http://docs.seleniumhq.org/download/.

-> Before using Junit framework in our selenium, we need to make sure JUnit external Jar files are added in eclipse in below path.

Right click on your project -> Build Path -> Configure build path

It will open java build path window. In that window, go to Libraries tab. Here you will see all your jar files. In jar file tree view, look for the jar file name which is starting with junit.


-> If above required .jar file is not added in eclipse means then we need to download and add .jar file in this link -> http://junit.org/



2) Create JUnit Test Case.

We need to create JUnit testcase and will add to our package using below steps in eclips.

i) Right click on "src" -> new -> package-> create new package (EX: JuintPackage)
ii) Right click on above created package -> new -> other-> java-> JUnit-> JUnit test case -> create new testcase java file (Ex:JUnit_Test1.java)


And use use below code for JUnit  testcase as JUnit_Test1.java inside the package JuintPackage.


package JuintPackage;

import static org.junit.Assert.*;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.firefox.FirefoxDriver;

public class Junit_Test1 {

WebDriver driver1=new FirefoxDriver();

@Before
public void beforetest()
{
driver1.manage().window().maximize();
driver1.get("http://google.com");
}

@After
public void aftertest()
{
driver1.quit();
}


@Test
public void Execute_Process()
{

driver1.findElement(By.linkText("Gmail")).click();
}

}




And save the above test case.


iii) Run above JUnit Test case. 

Eclipse will run your test case using JUnit and on completion of execution, you can see your result in JUnit pane in eclipse.



3) Running JUnit Test suite (Run Multiple JUnit Test case)

When you run junit test suite, eclipse will run all test cases  one by one. When execution completed, you will see output lines in console.


Steps for running JUnit Test Suite

i) Create two Junit Test case by using Step(2). and saved as Junit_Test1 and JUnit_Test2 respectively.

ii) Then use below stesp for create JUnit Test Suite

 Right click on Package -> new -> other-> java-> JUnit-> select JUnit test suite -> give Test Suite name (JUnit_Tests1)-> choose Junit testcases need to be run (Chosse Junit_Test1 and Junit_Test2)-> click Finish


Its automatically create cose as below


package JuintPackage;

import org.junit.runner.RunWith;
import org.junit.runners.Suite;
import org.junit.runners.Suite.SuiteClasses;

@RunWith(Suite.class)
@SuiteClasses({ Junit_Test1.class, Junit_Test2.class })
public class Junit_TestSuite1 {

}


if we see above suite class, there are two JUnit annotations added with name @RunWith and @SuiteCLasses

Here,

-> @RunWith annotation will references junit to run test in class

-> @SuiteClasses describes classes included in that test suite.



iii) when you run junit test suite, eclipse will run both test cases (Junit_Test1 and Junit_Test) one by one. When execution completed, you will see bellow given output lines in console.

junittest1 class is executed
junittest2 class-test1 method is executed
junittest2 class-test2 method is executed




Ref: http://software-testing-tutorials-automation.blogspot.com/2014/01/learn-selenium-webdriver-online-free.html

What is Junit Framework in Selenium



What is TestNG and JUnit frameworks?

-> TestNG and JUnit are tools  to help you organize our test.

-> We can define what you want to run before/after tests and we can able to group the tests and reporting them to made easier.


How are TestNG and JUnit frameworks are related to selenium?

-> Those frameworks are usually mentioned with Selenium.

-> Selenium is common testing tool. But selenium combined with any framework (TestNG or JUnit) together do some work. But both are completly different

-> Selenium used connects you to your browser

-> TestNG/JUnit used to organizes the tests




What is JUnit Framework in Selenium Webdriver

-> JUnit is used the most, then TestNG, then FitNesse

-> JUnit is a simple framework to write repeatable tests. It is an instance of the xUnit architecture for unit testing frameworks.

-> We have using some JUnit annotations to control the flow and activity of code execution.

-> You must need to insert JUnit annotation inside the java code to execute your test case as junit test case.

-> The important annotations are

1) @Before
2) @Test
3) @After
4) @BeforeClass
5) @AfterClass.



1. @Before Annotation 

-> THe method under @Before annotation will be executed before the moethod written under @Test annotation.
-> Generally method under @Before used to initializing browser or environment related setup.
-> The method under @Before annotation will executed before each @Test annotations. That means if we have four @Test annotaions in your class, then the @Before method will execute four times.



2. @After Annotation

-> The method under @After annotation will execute after completion of @Test method execution.
-> Generally @After annoation used to close the browser and release the memory of object which created in JUnit framework.
-> The method under @After annotation will executed after each @Test annotations. That means if we have four @Test annotaions in your class, then the @After method will execute four times.


3. @Test

-> The method under @Test annotation will execute after completion of @Before method execution.
-> Generallu method under @Test used to write all testing related activity.
-> We can have any number of @Test method in single class.


4. @BeforeClass

-> Methods under @BeforeClass will execute before any one of the test method starts execution.
-> It will execute only once even if there are multiple @Test method in our class.


5. @AfterClass

-> The method under @After class will excute all the completion of @Test methods exection in class.
-> It will execute only once even if there are multiple @Test method in our class.



Difference between @Before and @BeforeClass annotations


-> The method under @Before annotation will executed before each @Test annotations. That means if we have four @Test annotaions in your class, then the @Before method will execute four times.
->

Test method marked with @Before annotation will be executed before the each @Test method. Means if there are 5 @Test methods in your class then @Before test method will be executed 5 times.
Test method marked with @BeforeClass annotation will be executed just before the class. Means @BeforeClass method will be executed only once before the class even if there are 5 @Test methods in your class.


Difference between @After and @AfterClass annotations

Same as @Before annotation, Test method marked with @After annotation will be executed after the each @Test method.
@AfterClass annotation will be executed only once after last @Test method executed.