Skip to main content

HP QTP Tutorial Chapter 5

1 Insert

The Insert Menu will help you in inserting various verification points, New Steps, Function, and Call to Action etc. While describing the various commands which are available in Insert Menu, I will also be mentioning the hot keys to access some of the commands. See the below screen shot what command is available in the INSERT Menu:
clip_image002

1.1 Checkpoint

Let me first describe what a checkpoint is all about. The Checkpoints feature is provided in Automation Tool for simplifying the test case automation where you need to validate the state of the application. For e.g. You might want to test that when you open a web page or form, you will be able to see 5 Input Boxes and 2 Buttons. Out of the 5 Input Boxes, 3 should be editable, 2 should be ready only. Likewise 2 Buttons – 1 will be disabled by default and 1 will be enabled by default. In such a case you can use Tool Checkpoint feature. I hope this now clarify what is a checkpoint and its usage. If you read the QTP documentation it will talk of various checkpoint like Text, Text area, Table, Standard etc. In this tutorial I will talk about the checkpoint but not in a detail manner as I am writing another chapter dedicated to Checkpoints.
You can access Checkpoint: INSERT->CHECKPOINT (See the below screen shot)
clip_image004
The commands which are in disabled mode will be enabled when you start your script recording. There are only two commands namely Database checkpoint and XML checkpoint which are available in enabled mode by default. There is reason behind it, if you see these checkpoints they do not have dependency on AUT as they are interacting with database and XML which can be loaded from server or local directory.

1.2 Output Value

The Output Value is mainly used wherein you want to capture the value from AUT. For e.g. I am creating an Account in my application which provide me with an Account number after successful creation of an account. I want to use this account number for validating some scenario which can be done only through search module of the application. In such a scenario I can use Output feature in QTP so that the value can be used as an input in another part of AUT. You can access Output Value: INSERT->OUTPUT VALUE (See the below screen shot)
clip_image006
I will talk more about Checkpoint and Output value in the next chapter. Keep checking my blog.

1.3 Step Generator

As you start with your scripting, you need to use inbuilt functions, customized functions to design a robust testing framework. The Step Generator aids your scripting by providing help on 3 categories: Test Objects, Utility Objects, Functions. As you select any of these categories QTP allows you to add respective steps in your script. This tool is very handy for beginner as it really makes their life easy while scripting. You can access the Step Generator by pressing shortcut key of F7 or navigating to INSERT->STEP GENERATOR ( See the below screen shot of Step Generator):
clip_image008
I will talk about the details in next the chapter of this tutorial series.

1.4 Function Definition Generator

This utility or command in QTP aids you in defining the Function Skelton. You can define Function or Sub Procedure using Function Definition Generator. You can define even register your function with a Test Object so that you can achieve the desired result on the Test Object action. I will not delve into much detail at this point of time as it is more advance topic. So as of now if you are beginner and new to scripting, this is the utility for you. You can access the utility by navigating to INSERT-> Function Definition Generator. See the below screen shot:
clip_image010

1.5 Synchronization Point

This is one of very useful command in QTP. This will be used very frequently in your scripting. There might be a situation wherein you have to wait till the time page get loaded or input field get enabled, progress bar reach 100% etc. Any scenario where next action depends on the completion of previous action, you have to use Synchronization Point in your script. This command will get enabled when you are in recoding mode. Just try your hand on this utility and see the generated script. Seeing the name you will understand that you have to wait till some property get satisfied. You can access this command from INSERT-> Synchronization Point (See below screen shot)
clip_image012

1.6 New Step & New Step after Block

Suppose you have done 50% or 20% of your scripting and then you realize that you have to add some more steps which are in between of some existing steps, then you can use New Step command. This command is available to you in Keyword view only. First you need to place select the step in Keyword view, then navigate to INSERT->NEW STEP or press F8, as soon as you do this you will see a drop down from where you can select any test object , function to insert in your script. See the below screen shot:
clip_image014
Similarly if you want to add anything after a conditional block (IF ELSE) or loop (FOR, WHILE etc), then you can make use of INSERT-> New Step after Block or press SHIFT+ F8
clip_image016
See the above screen shot wherein you can see the block of If statement in blue.

1.7 Comment

If you want to insert the comment in your scripting, use this command to provide the line comments, comments before a line of code etc. Navigate to INSERT->COMMENT. You can also provide Line comments by filling the comment column of your keyword view. Please see the below screen shot:
clip_image019
clip_image021

1.8 Report

This command is used to report the Pass, Fail, Warning, Done status to execution result. To add Report statement, select the step in keyword view after which Report statement need to be added, navigate to INSERT->REPORT. See the below screen shot. You have to select the status, enter the name and description and then you are done:
clip_image023

1.9 Conditional Statement

As the name suggests, if you want to define some logic, then you have to use the Conditional statement. This is very useful command to build a robust script. The usage of conditional statement and result reporting goes hand in hand. One has to ensure that wherever they are using Report statement, it should always be inside conditional statement. For e.g If I have to validate that button exists or not, then I will use conditional statement to report my result. See below pseudo code:

IF BUTTON EXIST
REPORT PASS
ELSE
REPORT FAIL
END IF
You can access the Conditional statement command from INSERT=>Conditional Statement. See below screen shot which is self explanatory.
clip_image025

1.10 Loop Statement

Like Conditional Statement you can also use Loop Statement where you have to use different set of data for your script. Without Loop statement, you can make your data driven framework (wait till advance version of tutorial get released). To insert Loop statement, select the step after which you want to have Loop statement, and then navigate to INSERT->Loop Statement. See below screen shot:
clip_image027

1.11 Call to New Action

As in my previous chapter I mentioned about action. Call to New Action is the command which can be accessed from INSERT-> Call to New Action. The call to new action command is calling a new action which does not have any script written. The new action is blank without any commands. You have to define the New Action after which it will perform the desired action and make your requirement fulfilled. See the below screen shots:
clip_image029
After you define the New Action, you can make it reusable if you wish to use it in other Actions.

1.12 Call to Copy of Action

This is calling an existing action but with a copy of it so that you can customized as per your need. When saved a copy of previous action will be saved. This is the same thing wherein you are making use of existing code with some modification to speed up the scripting process. To access Call to Copy of Action, navigate to INSERT->Call to Copy of Action (See below screen shot)
clip_image031

1.13 Call to Existing Action

This is very frequently used while doing scripting. Your test script is a combination of multiple actions like Login, Logout, Navigation, Specific Function etc. As a best practice what we normally do is we identify actions which get used most of the time. We make such action reusable and ask other scripter to call this Action without making any changes. The same is called Call to Existing Action. You cannot make any changes in Original Action. To add existing action, navigate to INSERT->Call to Existing Action (See below screen shot)
clip_image033

1.14 Call to Winrunner

As the name suggest that you can call Winrunner Test or Function as well. This utility is given by HP so that any organization which has major enterprise automation library developed in Winrunner 8.2, they can make most use out of it without rewriting the library from scratch. This command will normally not used when doing fresh automation in QTP. Another pre-requisite to access this command is that you must have WinRunner 8.2 or higher version installed in your machine.

1.15 Start Transaction and End Transaction

Suppose I want to measure the time taken in inserting 1 record in the database. This information will tell me the transaction time. This is useful only when I want to make this information available to LoadRunner or Business Availability Center for measuring the performance of the application. You can insert Transaction time by putting the start time and end time between 2 points. To access the above command navigate to INSERT->Start Transaction and End Transaction. This measures the time taken to complete the required piece of transaction. For e.g. how much time system is taking to return the search result. Here I will start transaction wherein I am inserting search text and clicking the search button, I will end my transaction when I got the required search result. When I run this script, I will have my search timings.
I hope you must have got it what I intend to say.

2 References

Quick Test Professional Tool.

3 Additional information

You can email me on Sachin.vasudha@gmail.com with any query.

Comments

QPT said…
QTP Tutorial 5 is excellent and useful for all.
QTPbook
custom software said…
nicely written...quite detailed.. helpful both in terms of knowledge and use....custom software
Unknown said…
software testing firm offers software QA outsourcing, software testing services including web application testing and dedicated QA team creation.
search engine optimization india

Popular posts from this blog

Mantis - Defect Management Tool - User Guide

Introduction This white paper contains information related to an open source defect management tool called Mantis which is freely available for managing all your defects. Where to Download One can download the latest version of Mantis from http://sourceforge.net/project/showfiles.php?group_id=14963 Download the “mantis-stable” and then “mantis-x.y.z.zip”.1.1 PRE-REQUISITE Operating System Windows 2003 Server, MacOS, OS/2, Linux, Solaris Database MySQL database 3.23.2 and higher Software PHP 4.0.6 and higher Application Server Apache 1.3, Apache 2.0.54, IIS 6.0 with Web Services Extension Browser IE6 and above, Mozilla Firefox STEPS FOR INSTALLATION – FOR WINDOWS MySQL Installation Install MySQL by downloading it from http://dev.mysql.com/get/Downloads/MySQLGUITools/mysql-gui-tools-5.0-r6-win32.msi/from/http:/www.mirrorservice.org/sites/ftp.mysql.com/ . Please follow the below mentioned steps while installing MySQL: (Please remember the password for “root” account...

Why to do Software Testing?

Regardless of the limitations, testing is an integral part in software development. It is broadly deployed in every phase in the software development cycle. Typically, more than 50% percent of the development time is spent in testing. Testing is usually performed for the following purposes: To improve quality. As computers and software are used in critical applications, the outcome of a bug can be severe. Bugs can cause huge losses. Bugs in critical systems have caused airplane crashes, allowed space shuttle missions to go awry, halted trading on the stock market, and worse. Bugs can kill. Bugs can cause disasters. The so-called year 2000 (Y2K) bug has given birth to a cottage industry of consultants and programming tools dedicated to making sure the modern world doesn't come to a screeching halt on the first day of the next century. [Bugs] In a computerized embedded world, the quality and reliability of software is a matter of life and death. Quality means the conformance to the ...

Is BCI (Brain Computer Interface) a road to immortality?

What is a Brain-Computer Interface? Brain-computer interface is a technology which can read your mind and display it on a device - a mobile, laptop or TV screen. It means what data is being carried by our billion neurons are prone to hack.  When combined with other mechanical devices, can also be used to control the device.  So in future, if you want to switch on your TV or light, you just have to think and that's all.  Google and Alexa home will be replaced by BMI controlled devices.  I am not an expert in this field but based on my research and analysis, I can predict that when BMI tech will get matured, the human can do brain to brain talk and many other magical things - in future Telepathy will be a day to day affair. BCI can give you all kind of experience from the comfort of your home.  You can go on vacation without leaving your bedroom. You can have romantic experience without having a partner and many more such experiences. ...