QTP自动化测试培训:描述编程之WebElement

QTP自动化测试培训:描述编程之WebElement

通过描述性编程技术,来描述出来输入框:

set po=browser("creationtime:=0").page("micclass:=page")

set desc=description.creatre()

odesc("micclass").value="WebEdit"

odesc("html tag").value="input"

…………

在html中输入框的html tag除了input其实还有textarea等

<textarea rows="3" cols="20">
    内容.........内容
</textarea>

description的item属性支持正则表达式,默认开关打开

odesc.Item.RegularExpression=true

因此,可以修改成:

odesc("micclass").value="WebEdit"

odesc.Item.RegularExpression=true

odesc("html tag").value="input|textarea",

这样就支持input和testarea两种文本框的形式

但在一些js框架中,输入框的tag就不至于这些了,可能就是div,而且用qtp识别出来就是webelement,而并非webedit,我们知道,webedit和webelement属于继承关系,可以修改成这样

set desc=description.creatre()

‘odesc.Item.RegularExpression=true

odesc("micclass").value="WebElement"

odesc("html tag").value="input|textarea|div"

完整脚本

‘文本框输入

function sendkeys(propertyname,propertyvalue,value)

set po=browser("creationtime:=0").page("micclass:=page")

‘po也可以写为方法的参数

set desc=description.creatre()

  odesc("micclass").value="WebElement"

      odesc("html tag").value="input|textarea|div"   

‘把所需要的tag标记都可以写进去

odesc(propertyname).value=propertyvalue

set child=po.childobject(odesc)

ochild(0).set value

’多个元素时,index也可以作为参数

end function

这样一来,只需要封装操作类型,而对于元素的类型,则都可以用WebElement来代替,然后html tag则使用正则表达式符号“|”来匹配任意tag的其中的一个

调用:

call sendkeys("xpath","//input[@name=‘username‘]","test001")

可以看出,所有网页元素,它的micclass其实都可以写成webelement。

如果qtp识别不出的web元素,可以通过其他的辅助工具来帮助来识别

时间: 2024-11-08 19:13:04

QTP自动化测试培训:描述编程之WebElement的相关文章

linux网络编程之shutdown() 与 close()函数详解

linux网络编程之shutdown() 与 close()函数详解 参考TCPIP网络编程和UNP: shutdown函数不能关闭套接字,只能关闭输入和输出流,然后发送EOF,假设套接字为A,那么这个函数会关闭所有和A相关的套接字,包括复制的:而close能直接关闭套接字. 1.close()函数 [cpp] view plain copy print? <span style="font-size:13px;">#include<unistd.h> int 

C++混合编程之idlcpp教程Python篇(8)

上一篇在这 C++混合编程之idlcpp教程Python篇(7) 第一篇在这 C++混合编程之idlcpp教程(一) 与前面的工程相似,工程PythonTutorial6中,同样加入了四个文件:PythonTutorial6.cpp, Tutorial6.cpp, Tutorial6.i, tutorial6.py.其中PythonTutorial6.cpp的内容基本和PythonTutorial5.cpp雷同,不再赘述.首先看一下Tutorial6.i的内容: #import "../../p

Linux/Unix C编程之的perror函数,strerror函数,errno

#include <stdio.h> // void perror(const char *msg); #include <string.h> // char *strerror(int errnum); #include <errno.h> //errno ? errno 是错误代码,在 errno.h头文件中: perror是错误输出函数,输出格式为:msg:errno对应的错误信息(加上一个换行符): strerror?是通过参数 errnum (就是errno)

C++混合编程之idlcpp教程Lua篇(8)

上一篇在这 C++混合编程之idlcpp教程Lua篇(7) 第一篇在这 C++混合编程之idlcpp教程(一) 与前面的工程相似,工程LuaTutorial6中,同样加入了四个文件:LuaTutorial6.cpp, Tutorial6.cpp, Tutorial6.i, tutorial6.lua.其中LuaTutorial6.cpp的内容基本和LuaTutorial5.cpp雷同,不再赘述. 首先看一下Tutorial6.i的内容: namespace tutorial { template

Linux环境编程之IPC进程间通信(五):Posix消息队列1

对于管道和FIFO来说,必须应该先有读取者存在,否则先有写入者是没有意义的.而消息队列则不同,它是一个消息链表,有足够写权限的线程可往别的队列中放置消息,有足够读权限的线程可从队列中取走消息.每个消息都是一个记录,它由发送者赋予一个优先级.在某个进程往一个队列写入消息之前,并不需要另外某个进程在该队列上等待消息的到达.消息队列是随内核的持续性,一个进程可以往某个队列写入一些消息,然后终止,再让另外一个进程在以后的某个时刻读出这些消息.这跟管道和FIFO不一样,当一个管道或FIFO的最后一次关闭时

编程之美2.14 求数组的子数组之和的最大值

问题描述: 一个有N个整数元素的一维数组(A[0], A[1], A[2],...,A[n-1]),这个数组当然有很多子数组,那么子数组之和的最大值是什么呢? 解法: 1. 暴力解法-------O(N^3) 2. 改进版暴力解法-------O(N^2) *3. 分治算法-------O(NlogN)(暂时未去实现) 4. 数组间关系法-------O(N) 具体思路和代码: 1.暴力解法 思路:Sum[i,...,j]为数组第i个元素到第j个元素的和,遍历所有可能的Sum[i,...,j].

C++混合编程之idlcpp教程Python篇(7)

上一篇在这 C++混合编程之idlcpp教程Python篇(6) 第一篇在这 C++混合编程之idlcpp教程(一) 与PythonTutorial4工程相似,工程PythonTutorial5中,同样加入了四个文件:PythonTutorial5.cpp, Tutorial5.cpp, Tutorial5.i, tutorial5.py.其中PythonTutorial5.cpp的内容基本和PythonTutorial4.cpp雷同,不再赘述.首先看一下Tutorial5.i的内容: #imp

Java编程之Map中分拣思想。

题目:给定一个字符串,求出字符串中每一个单词在字符串中出现的次数 旨意:map的分拣思想. 每一个key的包装类,存放出现的次数 1 /** 2 * 作为包装类,用来存放英文单词,和该英文单词出现的次数 3 * @ClassName: Str 4 * @Description: TODO(这里用一句话描述这个类的作用) 5 * @author 尚晓飞 6 * @date 2014-7-30 下午6:57:29 7 * 8 */ 9 public class Str { 10 private St

编程之美2.17 数组循环移位

问题描述: 设计一个算法,把一个含有N元素的数组循环左移或者右移K位. 解决方法: 1. 暴力解法------O(KN) 2. 颠倒位置------O(N) 具体思路和代码: 1. 暴力解法------O(KN) 思路:循环K次,每次移动一位 代码: 1 //右移 2 void s1(int A[], int n, int k) 3 { 4 k = k % n; 5 for(int i = 0; i < k; i++) 6 { 7 int t = A[n-1]; 8 for(int j = n-