QTP New Feature Version 10.0
QTP New Feature Version 10.0
QTP New Feature Version 10.0
The variables that are commonly used across the environment in many tests by different
resources are know as Environment Variables.
1. Built-in-variables
1.Built-in-variables :- These variables will be by default available in every test and can
be directly used in any test with help of following syntax.
Syntax: Environment.value(“Built-in-variables”)
Example :
msgbox var
2. User Defined Variables :- The variables which are required commonly in number of
test apart from the Built-in-variables need to be created by the user which are known as
User Defined Variables.
User Defined Variables are created in environment file, any body in that environment can
Associate this file and use the variables in it.
i. Internal User Defined Variables : These Variables are used in the same file. See
below example:
VbWindow("Form1").VbEdit("val1").Set environment.Value("a")
VbWindow("Form1").VbEdit("val2").Set environment.Value("b")
VbWindow("Form1").VbButton("ADD").Click
ii. External User Defined Variables :- which are Imported from other file. See below
example (Proceed step by step):
If you want you can make use of Exported data or you can create your own data in a file
with .xml extention file in the Environment folder
VbWindow("Form1").VbEdit("val1").Set environment.Value("a")
VbWindow("Form1").VbEdit("val2").Set environment.Value("b")
VbWindow("Form1").VbButton("ADD").Click
Simple code to vadilate all the links of web page(DP and child object)
‘***********************************************************************
Count number of links and objects in web page by child method objects
To count the number of links in a web page, We can use ChildObjects to get the link
collection, then retrieve the properties for example number of links or any other objects
on page.
The example below uses the PressKey method to send keyboard input to an application.
obj.PressKey 63
The PressKey method uses the ASCII value for the key.
63 is the ASCII value for F5.
The function below shows a message box that disappears after the specified timeout (in
seconds). The script execution then continues.
End Sub
If TimeOut is 0, it behaves just like a normal message box. If TimeOut is greater than 0,
the dialog box disappears after the specified number of seconds.
The following are some file operations which are useful for debugging scripts in QTP.
The following examples can be downloaded from here.
' Creates a specified file and returns a TextStream object that can be used to read from or
write to the file.
' f.Close
End Function
' Opens a specified file and returns a TextStream object that can be used to read from,
write to, or append to the file.
' f.Close
End Function
' Appends a line to a file.
Const ForAppending = 8
End If
f.WriteLine sLine
f.Close
End Function
Const ForWriting = 2
End If
f.WriteLine sLine
f.Close
End Function
The NormalizeString function receives a string and returns the equivalent string in a
regular expression.
Function NormalizeString(OrgStr)
Dim TempStr
End function
You must have the Microsoft Script Debugger installed to run tests in debug mode. If it is
not installed, you can use the QuickTest Additional Installation Requirements Utility to
install it. (Select Start > Programs > QuickTest Professional > Tools > Additional
Installation Requirements.)
While the test and function libraries are running in debug mode, they are read-only. You
can modify the content after you stop the debug session (not when you pause it). If
needed, you can enable the function library for editing (File > Enable Editing) after you
stop the session. For more information, see Editing a Read-Only Function Library. After
you implement your changes, you can continue debugging your test and function
libraries.
If you perform a file operation (for example, you open a different test or create a new
test), the debug session stops.
If a file is called using an ExecuteFile statement, you cannot debug the file or any of the
functions contained in the file. In addition, when debugging a test that contains an
ExecuteFile statement, the execution marker may not be displayed correctly.
In QuickTest, when you open a test, QuickTest creates a local copy of the external
resources that are saved to your Quality Center project. Therefore, any changes you apply
to any external resource that is saved in your Quality Center project, such as a function
library, will not be recognized in the test until the test is closed and reopened. (An
external resource is any resource that can be saved separately from the test, such as a
function library, a shared object repository, or a recovery scenario.)
In contrast with this, any changes you apply to external resources saved in the file
system, such as function libraries, are implemented immediately, as these files are
accessed directly and are not saved as local copies when you open your test.
After you create a test or function library (including registered user functions), you
should check that they run smoothly, without errors in syntax or logic. To debug a
function library, you must first associate it with a test and then debug it from that test.
QuickTest Professional provides different options that you can use to detect and isolate
defects in a test or function library. For example:
You can control the run session using the Pause command, breakpoints, and various step
commands that enable you to step into, over, and out of a specific step.
If QTP displays a run error message during a run session, you can click the Debug button
on the error message to suspend the run and debug the test or function library.
When a run session is paused (suspended), you can use the Debug Viewer to check and
modify the values of VBScript objects and variables and to manually run VBScript
commands.
You can use the Debug from Step command to begin (and pause) your debug session at a
specific point in your test. You can also use the Run to Step command to pause the run at
a specific point in your test. You can set breakpoints, and then enable and disable them as
you debug different parts of your test or function library.
You can also use the Run from Step command to run your test from a selected step. This
enables you to check a specific section of your application or to confirm that a certain
part of your test or function library runs smoothly.
Programming the Filesystemobject in QTP
The FSO object model is contained in the Scripting type library, which is located in the
Scrrun.dll file. Therefore, you must have Scrrun.dll in the appropriate system directory on
your Web server to use the FSO object model.
[VBScript]
Dim fso
Set fso = CreateObject("Scripting.FileSystemObject")
[JScript]
var fso;
fso = new ActiveXObject("Scripting.FileSystemObject");
In both of these examples, Scripting is the name of the type library and FileSystemObject
is the name of the object that you want to create. You can create only one instance of the
FileSystemObject object, regardless of how many times you try to create another.
Second, use the appropriate method of the FileSystemObject object. For example, to
create a new object, use either CreateTextFile or CreateFolder (the FSO object model
doesn't support the creation or deletion of drives).
To delete objects, use the DeleteFile and DeleteFolder methods of the FileSystemObject
object, or the Delete method of the File and Folder objects. You can also copy and move
files and folders, by using the appropriate methods.
GetDrive
GetFolder
GetFile
[VBScript]
Dim fso, f1
Set fso = CreateObject("Scripting.FileSystemObject")
Set f1 = fso.GetFile("c:\test.txt")
[JScript]
var fso, f1;
fso = new ActiveXObject("Scripting.FileSystemObject");
f1 = fso.GetFile("c:\\test.txt");
Do not use the "get" methods for newly created objects, since the "create" functions
already return a handle to that object. For example, if you create a new folder using the
CreateFolder method, don't use the GetFolder method to access its properties, such as
Name, Path, Size, and so forth. Just set a variable to the CreateFolder function to gain a
handle to the newly created folder, then access its properties, methods, and events.
[VBScript]
Sub CreateFolder
Dim fso, fldr
Set fso = CreateObject("Scripting.FileSystemObject")
Set fldr = fso.CreateFolder("C:\MyTest")
Response.Write "Created folder: " & fldr.Name
End Sub
[JScript]
function CreateFolder()
{
var fso, fldr;
fso = new ActiveXObject("Scripting.FileSystemObject");
fldr = fso.CreateFolder("C:\\MyTest");
Response.Write("Created folder: " + fldr.Name);
}
[VBScript]
Set fldr = fso.GetFolder("c:\")
[JScript]
var fldr = fso.GetFolder("c:\\");
Now that you have a handle to a Folder object, you can check its Name property.
[VBScript]
Response.Write "Folder name is: " & fldr.Name
[JScript]
Response.Write("Folder name is: " + fldr.Name);
To find out the last time a file was modified, use the following syntax:
[VBScript]
Dim fso, f1
Set fso = CreateObject("Scripting.FileSystemObject")
' Get a File object to query.
Set f1 = fso.GetFile("c:\detlog.txt")
' Print information.
Response.Write "File last modified: " & f1.DateLastModified
[JScript]
var fso, f1;
fso = new ActiveXObject("Scripting.FileSystemObject");
// Get a File object to query.
f1 = fso.GetFile("c:\\detlog.txt");
// Print information.
Response.Write("File last modified: " + f1.DateLastModified);
The FileSystemObject (FSO) object model allows you to use the familiar object.method
syntax with a rich set of properties, methods, and events to process folders and files.
Because use of the FSO on the client side raises serious security issues about providing
potentially unwelcome access to a client's local file system, this documentation assumes
use of the FSO object model to create scripts executed by Internet Web pages on the
server side. Since the server side is used, the Internet Explorer default security settings do
not allow client-side use of the FileSystemObject object. Overriding those defaults could
subject a local computer to unwelcome access to the file system, which could result in
total destruction of the file system's integrity, causing loss of data, or worse.
The FSO object model gives your server-side applications the ability to create, alter,
move, and delete folders, or to detect if particular folders exist, and if so, where. You can
also find out information about folders, such as their names, the date they were created or
last modified, and so forth.
The FSO object model also makes it easy to process files. When processing files, the
primary goal is to store data in a space- and resource-efficient, easy-to-access format.
You need to be able to create files, insert and change the data, and output (read) the data.
Since storing data in a database, such as Access or SQL Server, adds a significant amount
of overhead to your application, storing your data in a binary or text file may be the most
efficient solution. You may prefer not to have this overhead, or your data access
requirements may not require all the extra features associated with a full-featured
database
The FSO object model, which is contained in the Scripting type library (Scrrun.dll),
supports text file creation and manipulation through the TextStream object. Although it
does not yet support the creation or manipulation of binary files, future support of binary
files is planned.
1. In QTP, Keyword-driven testing enables you to design your tests at a business level
rather than at the object level. For example, QTP may recognize a single option selection
in your application as several steps: a click on a button object, a mouse operation on a list
object, and then a keyboard operation on a list sub-item. You can create an appropriately-
named function to represent all of these lower-level operations in a single, business-level
keyword.
4. When you record tests, you may not notice that new objects are being added to the
local object repository. This may result in many testers maintaining local object
repositories with copies of the same objects. When using a keyword-driven methodology,
you select the objects for your steps from the existing object repository. When you need a
new object, you can add it to your local object repository temporarily, but you are also
aware that you need to add it to the shared object repository for future use.
5. When you record a test, QTP enters the correct objects, methods, and argument values
for you. Therefore, it is possible to create a test with little preparation or planning.
Although this makes it easier to create tests quickly, such tests are harder to maintain
when the application changes and often require re-recording large parts of the test.
6. When you use a keyword-driven methodology, you select from existing objects and
operation keywords. Therefore, you must be familiar with both the object repositories and
the function libraries that are available. You must also have a good idea of what you want
your test to look like before you begin inserting steps. This usually results in well-
planned and better-structured tests, which also results in easier long-term maintenance.
7. Automation experts can add objects and functions based on detailed product
specifications even before a feature has been added to a product. Using keyword-driven
testing, you can begin to develop tests for a new product or feature earlier in the
development cycle
1. How will you automate a window which while spying is not returning any property
value ??
2. How do you find the color and font of all the links on the page???
6.What are the basic prerequisites required in automating an infragistics controls based
application?
7.Can i record a web based application on Mozilla??
9.How to copy Virtual Object Manager from one computer to another computer??
EX use win32 query to get the handle or processid of the app and use some api to act on
it...this will be a work around not a solution.
Answer 2: Ans: use DHTML properties ....uses object.attributes...u will get all DHTML
properties of that particular element in a collection.
Answer 3: Disadvantages of Smart Identification: There are many out of which is time
consuming it eats lot of time and some times it yields wrong results also in case of
dynamic environment.
If disable smart identification qtp will through error in that particular statement
Answer 4: I think Space and time may be the constraints, because i never used it. it is
pretty waste of time to use it.
Create a new String value with name AltProgID and value "Mercury.JSScriptMgr" and
change the value of "Create" to 1
Open
C:\Program Files\Mercury Interactive\QuickTest Professional\bin\QTEditor.ini
Add the below parameter to [General options]
AllowJavaScript = 1
DisableVBScript = 1
Answer 7: U can record but not as a web application but a standard windows application
ex:
Window("Mozilla Firefox").WinObject("MozillaWindowClass").Type "naveen"
Answer 8: Repository parameters enable you to specify that certain property values
should be parameterized, but leave the actual parameterization to be defined in each test
that is associated with the object repository that contains the parameterized test object
property values.
Repository parameters are useful when you want to create and run tests on an object that
changes dynamically
Answer 10: NO
QuickTest 10.00 includes a powerful set of new reporting options that help you analyze
and manage your run results more thoroughly and efficiently. These include:
Jump to step. When you want to know more about a particular node in the Test Results
window, right-click it and select Jump to Step in QuickTest. The QuickTest main
window comes into focus, and the cursor jumps to the relevant step. For more
information, see Jumping to a Step.
Add Images to the Test Results. When you use the Reporter.ReportEvent method to
add information to the run results, you can now specify an image file as the fourth
argument. When you view the results, the image is displayed in the Result Details tab of
the Test Results window. For example, you can include an image returned by a
CaptureBitmap step in the run results. For more information, see ReportEvent Method
in the Utility section .
Include Images in Exported and Printed Test Results. When you choose the Detailed
option for printing or exporting, the document now includes all images. These include
screen captures of steps, expected, actual, and difference bitmaps for bitmap checkpoints,
and any images sent to the run results using the ReportEvent method. For more
information, see Printing Test Results.
Additional Quality Center Details. The run results for tests and components that are run
as part of a Quality Center test set now include the Quality Center server and project
name
NEW To Do pane
The new To Do pane that is now available in the QTP, enables you to create and manage
self-defined tasks, and to view a compiled set of the TODO comments from your tests,
components, and associated function libraries.
For example, you can use the Tasks tab to provide instructions to someone else during a
handover, or to create reminders for yourself. The Tasks tab provides check boxes in
which you can mark off each task as you complete it. In the Comments tab, you can
view and sort all your TODO comments. You can also jump directly to a selected TODO
comment in the testing document.
If you use the Maintenance Run Wizard to detect updates needed to your steps or object
repository, then you can use the To Do pane to track and manage the TODO comments
added during the maintenance run session.
You can also export your tasks and TODO comments from the To Do pane to an XLS
(Excel), CSV (comma separated), or XML file
Custom Bitmap checkpoint comparision algorithm in QTP 10
You (or a third party) can now develop custom comparers for bitmap checkpoints. A
custom comparer is a COM object that performs the bitmap comparison for the
checkpoint according to your testing requirements. For example, you could define a
custom comparer that allows a bitmap checkpoint to pass even if the image in the
application shifts by an amount specified when the checkpoint is defined.
After you install and register a custom comparer on the QTP computer, your comparer is
available for selection in the Bitmap Checkpoint Properties dialog box. The dialog box
provides space for specifying additional configuration preferences expected by your
comparer.
When QTP a bitmap checkpoint that uses a custom comparer, it supplies the expected
and actual bitmaps to the custom comparer object. It then receives and reports the results
that the custom compares returns
Load and run actions- Call Actions Dynamically During the Test Run
Generally, when you insert a call to an external action, the action call becomes part of the
test, and the called action is loaded each time you open the test.
In some situations, you may want to take advantage of the new LoadAndRunAction
statement to load an action only when the step runs, and then run that action.
This is useful, for example, if you use many conditional statements that call external
actions, and you do not want to load all of these actions each time you open the test, since
these actions may not be necessary during the run session.
Improve Portability by Saving Copies of Tests Together with Their Resource Files
Tests and their resource files are often stored on a network drive or in Quality Center.
However, you may need to open or run a test when you do not have access to the network
drive or QC. For example, you may need to create a portable copy of a test for use when
traveling to other sites.
You can save a standalone copy of your test and its resource files to a local drive or to
another storage device using the File > Save Test with Resources command. When you
save a test in this manner, QTP a copy of your test, all associated resource files, and any
called actions.
local system monitoring in QTP
The new local system monitoring feature in QTP (File > Settings > Local System
Monitor) enables you to monitor the local (client-side) computer resources used by the
application instance you are testing during a run session.
You can monitor a number of different system counters to view the effects your
application has on the system. You can also define upper limits for the counters. If any of
the specified counters exceed these limits, the test run will fail.
Additionally, you can export the data from the System Monitor tab to a variety of file
types.
The results generated for the counters you monitor are displayed as a line chart in a
special System Monitor tab in the Test Results window.
The System Monitor tab in the Test Results window
The points in the chart are synchronized with the steps in the Run Results tree. When you
select a step in the tree, the (red) Current Step line jumps to the corresponding location
in the chart.
You can also export the data from the chart so it can be further analyzed in other
programs
New resources and dependencies of model of QC with QTP
The new Quality Center resources and dependencies model enables you to store your
tests, components, and resources such that you can manage the relationships between
them and you can analyze the impact on all your assets when one asset changes.
If you are working with a Premier edition Quality Center server, then you can also import
and share your resources across different projects. You can synchronize these assets in
both projects when changes are made. This functionality also enables you to reuse your
existing assets instead of creating new assets whenever you create a new project. For
example, you can create a set of template assets to use as a basis for new projects.
In previous versions of QTP and Quality Center, a test's associated resource files (such as
shared object repositories, function libraries, recovery scenarios, and external data
tables), were stored in Quality Center as attachments, while files associated with an
application area were stored in a standalone Resources folder in the Business
Components module.
Quality Center 10.00 introduces a new Test Resources module. This module enables you
to store all of these resources as separate entities that are linked to their owners and
marked as dependencies. Tests or actions that call other tests are also linked as
dependencies.
When you select a QTP test, business process test, or individual component in the Quality
Center test or component tree, you can view these dependent resources and tests in a new
Dependencies tab. The Dependencies tab shows all Quality Center entities that are used
by your testing document as well as all entities that are using it. For example, if your
QTP test is associated with two function libraries, and the actions in your test are
associated with three object repositories, these entities will be displayed in the Using
table of the test's Dependencies tab. If one of the actions in your test is called by another
test, then that calling test will be displayed in the Used by table.
In QTP, you can also view the action-specific dependencies in the Used By tab of the
Action Properties dialog box.
Quality Center recognizes assets that are linked as owned by or owner dependencies and
ensures that these important relationships are maintained when you import or create
baselines, rename or move resources, select to delete resources, or perform other
operations that can impact these relationships.
Note: If required, you can continue using the previous attachments model for all or some
of your QTP assets. However, if you use the old model, you will not be able to take
advantage of many of the features associated with the resources and dependencies model.
Ques:How can we associate an excel file from QTP 10.0 to QC 10.0 - Where can i add it
in QC or QTP to make it dependent on the particular business component or particular
test.
Ans:To export testscript/Excel from QTP to QC, you first need to establish QTP-QC
connection
Next you can select the save the QTP Script in QC.
4 ) Select the Folder in QC where you wan to save the QTP Script
6) Click OK to Save