Conversion Functions:
|
Asc(string):Returns the ANSI character code corresponding to the first letter in a string.
|
CInt(expression): Returns an expression that has been converted to a Variant of subtype Integer
|
CStr(expression): Returns an expression that has been converted to a Variant of subtype String
|
CDate(date):Returns an expression that has been converted to a Variant of subtype Date.
|
Date Functions:
|
Date:Returns the current system date.
|
DateAdd(interval, number, date):Returns a date to which a specified time interval has been added.
|
DateDiff(interval, date1, date2 [,firstdayofweek[, firstweekofyear]]):Returns the number of intervals between two dates.
|
DatePart(interval, date[, firstdayofweek[, firstweekofyear]]):Returns the specified part of a given date.
|
DateSerial(year, month, day):Returns a Variant of subtype Date for a specified year, month, and day.
|
Day(date):Returns a whole number between 1 and 31, inclusive, representing the day of the month
|
IsDate(expression):Returns a Boolean value indicating whether an expression can be converted to a date.
|
Now:Returns the current date and time according to the setting of your computer's system date and time.
|
Weekday(date, [firstdayofweek]):Returns a whole number representing the day of the week.
|
Year(date):Returns a whole number representing the year.
|
String Functions:
|
InStr([start, ]string1, string2[, compare]): Returns the position of the first occurrence of one string within another.
|
InStrRev(string1, string2[, start[, compare]]): Returns the position of an occurrence of one string within another, from the end of string.
|
Join(list[, delimiter]):Returns a string created by joining a number of substrings contained in an array.
|
LTrim(string),RTrim(string),Trim(string):Returns a copy of a string without leading spaces (LTrim), trailing spaces (RTrim),
or both leading and trailing spaces (Trim). |
Len(string | varname):Returns the number of characters in a string or the number of bytes required to store a variable.
|
Left(string, length): Returns a specified number of
|
characters from the left side of a string.
|
Mid(string, start[, length]):Returns a specified number of characters from a string.
|
Right(string, length): Returns a specified number of characters from the Right side of a string.
|
StrReverse(string1):Returns a string in which the character order of a specified string is reversed.
|
StrComp(string1, string2[, compare]):Returns a value indicating the result of a string comparison.
|
Split(expression[, delimiter[, count[, compare]]]):Returns a zero-based, one-dimensional array containing a specified number of substrings.
|
Space(number):Returns a string consisting of the specified number of spaces.
|
Friday, 13 December 2013
QTP Functions
Regular Expressions in QTP
Regular Expressions in QTP
Sometimes there might be situations where values of objects keep on varying and QTP may fail to recognize them or checkpoints might get failed as the expected and actual data are not matching. In such cases Regular expressions come into picture. It enables QTP to identify objects and text strings with varying values. Regular expressions can be used:
1. In identifying the property values of an object
2. In parametrization
3. For creation of checkpoints on objects with varying values
1. In identifying property values of an object:
In this concept, let’s see how to handle QTP when a value of an object is varied. Let’s walk through this section with a small example:
In this concept, let’s see how to handle QTP when a value of an object is varied. Let’s walk through this section with a small example:
Assume that you have to record a scenario of verifying the mails in a mail account. Open the mail with valid username and password. Now click on Inbox. When you have opened your mail account assume that there are 5 mails. So the inbox would be showing Inbox (5). When you click on that, the mails get displayed. Following would be the statement that gets generated when clicked on Inbox:
Browser(“Gmail”).Page(“Gmail”).Link(“Inbox(5)”).click
Now when the same script is run again, QTP fails at the same step as the number of mails in the inbox is 4. Or even more if some new mails have come. The script execution doesn’t get passed unless the total number of new mails is again 5. We make use of regular expression here as the value for the number of mails keeps varying.
For creating a regular expression, go to object repository from Resourcesà Object repository. Select the link object Inbox (5) from object list displayed in the left side.
Go to the object properties screen displayed in the right side of the screen. Select the property that has the value Inbox (5). Click on the configure icon that gets displayed there.
‘Value configuration Options’ dialog box gets displayed.
Check the Regular expressions check box. A dialog box gets raised asking the user whether to add a back slash before each special character in order to treat it literally. As we have special characters ‘(‘ and ‘)’ we need to click on Yes and QTP adds a slash character before both the Parenthesis characters.
If you want qtp script to be successful for 0-9 mails then give the following value in Constant edit box:
Inbox\([0-9]\)
For 0-99 mails
Inbox\([0-9][0-9]\)
For 0-999 mails
Inbox\([0-9][0-9][0-9]\)
Click on OK and close the object repository window. For first option QTP executes the scripts successfully if the Inbox has 0-9 mails. Second option executes successfully for 0-99 mails and third option for 0-999 mails.
2. In Parameterization:
In some cases, we need to parameterize the varying values in the script. In such cases we parameterize the values and use the regular expression in parameterized value i.e., in data table sheet where the value is present. Using the same example mentioned above lets discuss how can be regular expressions in parameterization process.
Select the link object Inbox (5) from object list displayed in the left side of Object repository.
Go to the object properties screen displayed in the right side of the screen. Select the property that has the value Inbox (5). Click on the configure icon that gets displayed there.
‘Value configuration Options’ dialog box gets displayed. Set the Parameter Radio button and select the location of data table (global/local). Enter a title for the column.Now check the Regular expressions checkbox in advanced configurations option. Click on Yes in the dialog box that gets displayed.
Click on OK and close the object repository window. If you want QTP script to be successful for 0-9 mails then give the following value in Data table sheet of QTP:
Inbox\([0-9]\)
For 0-99 mails
Inbox\([0-9][0-9]\)
For 0-999 mails
Inbox\([0-9][0-9][0-9]\)
For first option QTP executes the scripts successfully if the Inbox has 0-9 mails. Second option executes successfully for 0-99 mails and third option for 0-999 mails. Using this example, the values can be changed directly in the data table sheet.
3. For creation of checkpoints on objects with varying values
3. For creation of checkpoints on objects with varying values
Assume that you have to create a text check point on some text which gets varied continuously. In the same example mentioned above, you need to insert a text checkpoint on Inbox (5) which gets varied basing on the number of mails available in the inbox. When the checkpoint is created, it takes Inbox (5) as the expected value and when the same script is run again when there are 4 mails in the inbox, and then the checkpoint fails. To overcome such situations, regular expressions is used again.
Insert a checkpoint by selecting Insert-->Checkpoint-->Text Checkpoint. (Make sure that QTP is in recording mode)
Select the text on which you want to insert text checkpoint (i.e., Inbox (5)). Text checkpoint properties window gets opened.Make sure that the radio button is set to constant dialog box. Click on Constant Value options icon that gets displayed there.
‘Constant Value options’ dialog box gets displayed. Now check the regular expressions check box and Click on yes in the dialog box that gets displayed to treat ‘(‘ and ‘)’ as literal characters. Now in the same way as mentioned in the above two examples enter the data as per your requirement.
For 0-9 mails
Inbox\([0-9]\)
For 0-99 mails
Inbox\([0-9][0-9]\)
For 0-999 mails
Inbox\([0-9][0-9][0-9]\)
Click on OK and close the Text checkpoint properties window. For first option QTP checkpoint gets passed if the Inbox has 0-9 mails. Second option gets passed for 0-99 mails and third option for 0-999 mails.
Tuesday, 3 December 2013
QTP Driver Script
Actually we are using VBScript in most of the areas in QTP. But the Driver Script is the only QTP script, remaino all are VBscript files(.VBS).
Driver script is mainly useful to organize the Tests Exection and stores Test Logs in the specified file/folder.
Example:
adding sheets to runtime data table
datatable.AddSheet ("Module")
datatable.AddSheet ("Testcase")
datatable.AddSheet ("Teststep")
'Adding data sheets to runtime data table
Tcrowcount=datatable.GetSheet ("Testcase").getrowcount
For j=1 to Tcrowcount step 1
datatable.SetCurrentRow (j)
moduleid1=datatable.Value(4,"Testcase")
tcexe=datatable.Value(3,"Testcase")
If moduleid=moduleid1 and Ucase(tcexe)="Y" Then
TcId=datatable.Value(1,"Testcase")
Tsrowcount=datatable.GetSheet("Teststep").getrowcount
For k= 1 to Tsrowcount step 1
datatable.SetCurrentRow(k)
Tcid1=Datatable.Value(5,"Teststep")
If TcId= TcId1 Then
keyword= datatable.Value(3,"Teststep")
Select Case keyword
Case "ln"
res=Login()
datatable.Value(6,"Teststep")=res
Case "ca"
close_app
Case "op"
res=Openord()
datatable.Value(6,"Teststep")=res
End Select
End If
Next
End If
Next
End If
Next
datatable.ExportSheet "D:\Automation\Testlog\results.xls","Teststep"
Sample Initialization Script:
Initialization Script launches QTP Tool and Calls Driver Script, Driver Script execute Tests and Stores Results.
Finally Initialization Script Closes QTP tool
Option Explicit
Dim qtApp
set qtApp=createobject("QuickTest.Application")
qtApp.Launch
qtApp.Visible=True
qtApp.Open "D:\Automation\Testscripts\Driver"
qtApp.Test.Run
qtApp.Quit
Driver script is mainly useful to organize the Tests Exection and stores Test Logs in the specified file/folder.
Example:
adding sheets to runtime data table
datatable.AddSheet ("Module")
datatable.AddSheet ("Testcase")
datatable.AddSheet ("Teststep")
'Adding data sheets to runtime data table
Tcrowcount=datatable.GetSheet ("Testcase").getrowcount
For j=1 to Tcrowcount step 1
datatable.SetCurrentRow (j)
moduleid1=datatable.Value(4,"Testcase")
tcexe=datatable.Value(3,"Testcase")
If moduleid=moduleid1 and Ucase(tcexe)="Y" Then
TcId=datatable.Value(1,"Testcase")
Tsrowcount=datatable.GetSheet("Teststep").getrowcount
For k= 1 to Tsrowcount step 1
datatable.SetCurrentRow(k)
Tcid1=Datatable.Value(5,"Teststep")
If TcId= TcId1 Then
keyword= datatable.Value(3,"Teststep")
Select Case keyword
Case "ln"
res=Login()
datatable.Value(6,"Teststep")=res
Case "ca"
close_app
Case "op"
res=Openord()
datatable.Value(6,"Teststep")=res
End Select
End If
Next
End If
Next
End If
Next
datatable.ExportSheet "D:\Automation\Testlog\results.xls","Teststep"
Sample Initialization Script:
Initialization Script launches QTP Tool and Calls Driver Script, Driver Script execute Tests and Stores Results.
Finally Initialization Script Closes QTP tool
Option Explicit
Dim qtApp
set qtApp=createobject("QuickTest.Application")
qtApp.Launch
qtApp.Visible=True
qtApp.Open "D:\Automation\Testscripts\Driver"
qtApp.Test.Run
qtApp.Quit
Subscribe to:
Posts (Atom)