Descriptive programming in QTP
Introduction:
This
document demonstrates the usage of Descriptive programming in QTP. It
also discusses situations where Descriptive programming can be used.
Using Descriptive Programming automation scripts can be created even if
the application has not been developed.
Descriptive Programming:
Whenever QTP
records any action on any object of an application, it adds some
description on how to recognize that object to a repository of objects
called object repository. QTP cannot take action on an object until
unless its object description is in the Object Repository. But
descriptive programming provides a way to perform action on objects
which are not in Object repository
Object Identification:
To identify an
object during the play back of the scripts QTP stores some properties
which helps QTP to uniquely identify the object on a page. Below screen
shots shows an example Object repository:
Now
to recognize a radio button on a page QTP had added 2 properties the
name of the radio button and the html tag for it. The name the left tree
view is the logical name given by QTP for the object. This can be
changed as per the convenience of the person writing the test case. QTP
only allows UNIQUE logical name under same level of hierarchy. As we see
in the snapshot the two objects in Browser->Page node are “WebTable”
and “testPath”, they cannot have the same logical name. But an object
under some other node can have the same name. Now with the current
repository that we have, we can only write operation on objects which
are in the repository. Some of the example operations are given below
Browser("Browser").Page("Page").WebRadioGroup ("testPath").Select "2"
cellData = Browser("Browser").Page("Page").WebTable ("WebTable").GetCellData (1,1)
Browser("Example2").Page("Page").WebEdit("testPath").Set "Test text"
When and Why to use Descriptive programming?
Below are some of the situations when Descriptive Programming can be considered useful:
The objects in
the application are dynamic in nature and need special handling to
identify the object. The best example would be of clicking a link which
changes according to the user of the application, Ex. “Logout
<<UserName>>”.
When object
repository is getting huge due to the no. of objects being added. If the
size of Object repository increases too much then it decreases the
performance of QTP while recognizing a object.
When you don’t
want to use object repository at all. Well the first question would be
why not Object repository? Consider the following scenario which would
help understand why not Object repository
Scenario 1:
Suppose we have a web application that has not been developed yet. Now
QTP for recording the script and adding the objects to repository needs
the application to be up, that would mean waiting for the application to
be deployed before we can start of with making QTP scripts. But if we
know the descriptions of the objects that will be created then we can
still start off with the script writing for testing
Scenario 2:
Suppose an application has 3 navigation buttons on each and every page.
Let the buttons be “Cancel”, “Back” and “Next”. Now recording action on
these buttons would add 3 objects per page in the repository. For a 10
page flow this would mean 30 objects which could have been represented
just by using 3 objects. So instead of adding these 30 objects to the
repository we can just write 3 descriptions for the object and use it on
any page.
Modification to
a test case is needed but the Object repository for the same is Read
only or in shared mode i.e. changes may affect other scripts as well.
When you want
to take action on similar type of object i.e. suppose we have 20
textboxes on the page and there names are in the form txt_1, txt_2,
txt_3 and so on. Now adding all 20 the Object repository would not be a
good programming approach.
How to use Descriptive programming?
There are two ways in which descriptive programming can be used
By creating properties collection object for the description.
By giving the description in form of the string arguments.
By creating properties collection object for the description.
To use this method you need first to create an empty description
Dim obj_Desc ‘Not necessary to declare
Set obj_Desc = Description.Create
Now we have a blank description in “obj_Desc”. Each description has 3 properties “Name”, “Value” and “Regular Expression”.
obj_Desc(“html tag”).value= “INPUT”
When you use a
property name for the first time the property is added to the collection
and when you use it again the property is modified. By default each
property that is defined is a regular expression. Suppose if we have the
following description
obj_Desc(“html tag”).value= “INPUT”
obj_Desc(“name”).value= “txt.*”
This would mean
an object with html tag as INPUT and name starting with txt. Now
actually that “.*” was considered as regular expression. So, if you want
the property “name” not to be recognized as a regular expression then
you need to set the “regularexpression” property as FALSE
obj_Desc(“html tag”).value= “INPUT”
obj_Desc(“name”).value= “txt.*”
obj_Desc(“name”).regularexpression= “txt.*”
This is how of we create a description. Now below is the way we can use it
Browser(“Browser”).Page(“Page”).WebEdit(obj_Desc).set “Test”
When we say
.WebEdit(obj_Desc) we define one more property for our description that
was not earlier defined that is it’s a text box (because QTPs WebEdit
boxes map to text boxes in a web page).
If we know that
we have more than 1 element with same description on the page then we
must define “index” property for the that description
Consider the HTML code given below
<INPUT type=”textbox” name=”txt_Name”>
<INPUT type=”textbox” name=”txt_Name”>
Now
the html code has two objects with same description. So distinguish
between these 2 objects we will use the “index” property. Here is the
description for both the object
For 1st textbox:
obj_Desc(“html tag”).value= “INPUT”
obj_Desc(“name”).value= “txt_Name”
obj_Desc(“index”).value= “0”
For 2nd textbox:
obj_Desc(“html tag”).value= “INPUT”
obj_Desc(“name”).value= “txt_Name”
obj_Desc(“index”).value= “1”
Consider the HTML Code given below:
<INPUT type=”textbox” name=”txt_Name”>
<INPUT type=”radio” name=”txt_Name”>
We can use the same description for both the objects and still distinguish between both of them
obj_Desc(“html tag”).value= “INPUT”
obj_Desc(“name”).value= “txt_Name”
When I want to
refer to the textbox then I will use the inside a WebEdit object and to
refer to the radio button I will use the description object with the
WebRadioGroup object.
Browser(“Browser”).Page(“Page”).WebEdit(obj_Desc).set “Test” ‘Refers to the text box
Browser(“Browser”).Page(“Page”).WebRadioGroup(obj_Desc).set “Test” ‘Refers to the radio button
But if we use
WebElement object for the description then we must define the “index”
property because for a webelement the current description would return
two objects.
Hierarchy of test description:
When using
programmatic descriptions from a specific point within a test object
hierarchy, you must continue to use programmatic descriptions
from that point
onward within the same statement. If you specify a test object by its
object repository name after other objects in the hierarchy have
been described using programmatic descriptions, QuickTest cannot identify the object.
For example,
you can use Browser(Desc1).Page(Desc1).Link(desc3), since it uses
programmatic descriptions throughout the entire test object hierarchy.
You can also
use Browser("Index").Page(Desc1).Link(desc3), since it uses programmatic
descriptions from a certain point in the description (starting
from the Page object description).
However, you
cannot use Browser(Desc1).Page(Desc1).Link("Example1"), since it uses
programmatic descriptions for the Browser and Page objects but
then attempts
to use an object repository name for the Link test object (QuickTest
tries to locate the Link object based on its name, but cannot
locate it in the repository because the parent objects were specified using programmatic descriptions).
Getting Child Object:
We
can use description object to get all the objects on the page that
matches that specific description. Suppose we have to check all the
checkboxes present on a web page. So we will first create an object
description for a checkboxe and then get all the checkboxes from the
page
Dim obj_ChkDesc
Set obj_ChkDesc=Description.Create
obj_ChkDesc(“html tag”).value = “INPUT”
obj_ChkDesc(“type”).value = “checkbox”
Dim allCheckboxes, singleCheckBox
Set allCheckboxes = Browse(“Browser”).Page(“Page”).ChildObjects(obj_ChkDesc)
For each singleCheckBox in allCheckboxes
singleCheckBox.Set “ON”
Next
The above code
will check all the check boxes present on the page. To get all the child
objects we need to specify an object description i.e. we can’t use the
string arguments that will be discussed later in the 2nd way of using
the programming description.
Possible Operation on Description Object
Consider the below code for all the solutions
Dim obj_ChkDesc
Set obj_ChkDesc=Description.Create
obj_ChkDesc(“html tag”).value = “INPUT”
obj_ChkDesc(“type”).value = “checkbox”
Q: How to get the no. of description defined in a collection
A: obj_ChkDesc.Count ‘Will return 2 in our case
Q: How to remove a description from the collection
A: obj_ChkDesc.remove “html tag” ‘would delete the html tag property from the collection
Q: How do I check if property exists or not in the collection?
A: The answer
is that it’s not possible. Because whenever we try to access a property
which is not defined its automatically added to the collection. The
only way to determine is to check its value that is use a if
statement “if obj_ChkDesc(“html tag”).value = empty then”.
Q: How to browse through all the properties of a properties collection?
A: Two ways 1st:
For each desc in obj_ChkDesc
Name=desc.Name
Value=desc.Value
RE = desc.regularexpression
Next
2nd:
For i=0 to obj_ChkDesc.count - 1
Name= obj_ChkDesc(i).Name
Value= obj_ChkDesc(i).Value
RE = obj_ChkDesc(i).regularexpression
Next
By giving the description in form of the string arguments.
You can describe an object directly in a statement by specifying property:=value pairs describing the object instead of specifying an object’s
name. The general syntax is:
TestObject("PropertyName1:=PropertyValue1", "..." , "PropertyNameX:=PropertyValueX")
TestObject—the test object class could be WebEdit, WebRadioGroup etc….
PropertyName:=PropertyValue—the test object property and its value. Each property:=value pair should be separated by commas and quotation
marks. Note
that you can enter a variable name as the property value if you want to
find an object based on property values you retrieve during a run
session.
Consider the HTML Code given below:
<INPUT type=”textbox” name=”txt_Name”>
<INPUT type=”radio” name=”txt_Name”>
Now to refer to the textbox the statement would be as given below
Browser(“Browser”).Page(“Page”).WebEdit(“Name:=txt_Name”,”html tag:=INPUT”).set “Test”
And to refer to the radio button the statement would be as given below
Browser(“Browser”).Page(“Page”).WebRadioGroup(“Name:=txt_Name”,”html tag:=INPUT”).set “Test”
If we refer to them as a web element then we will have to distinguish between the 2 using the index property
Browser(“Browser”).Page(“Page”).WebElement(“Name:=txt_Name”,”html tag:=INPUT”,”Index:=0”).set “Test” ‘ Refers to the textbox
Browser(“Browser”).Page(“Page”).WebElement(“Name:=txt_Name”,”html
tag:=INPUT”,”Index:=1”).set “Test” ‘ Refers to the radio button
Examples
'Script for Login
Systemutil.Run "C:\Program Files\HP\QuickTest Professional\samples\flight\app\flight4a.exe"
with Dialog("text:=Login")
.WinEdit("attached text:=Agent Name:").set "abcd"
.WinEdit("attached text:=Password:").set "mercury"
.WinButton("text:=OK").click
End with
'Script for Insert new Record
With Window("text:=Flight Reservation")
.WinMenu("menuobjtype:=2").Select "File;New Order"
.ActiveX("acx_name:=MaskEdBox").Type "062610"
.WinCombobox("attached text:=Fly From:").Select "Denver"
.WinComboBox("attached text:=Fly To:").Select "Paris"
.WinButton("text:=FLIGHT").Click
.Dialog("text:=Flights Table").WinList("attached text:=From","nativeclass:=ListBox").Select 1
.Dialog("text:=Flights Table").WinButton("text:=OK").Click
.WinEdit("attached text:=Name:","nativeclass:=Edit").Set "james"
.WinButton("text:=&Insert Order").click
End With'
Script for open Record
With window("text:=Flight Reservation")
.WinMenu("menuobjtype:=2").Select "File;Open Order..."
with .Dialog("text:=Open Order")
.WinCheckBox("text:=&Order No.").Set "ON"
.WinEdit("window id:=1016").Set "1"
.WinButton("text:=OK").Click
End With
End With
0 comments:
Post a Comment