对于自动化测试,尤其是UI的自动化测试。是很多做黑盒功能测试的同学,入门自动化测试一个最为直观的或者说最容易理解的途径之一。

 对于手工测试和自动化测试的优劣,网上有很多论述,在这里不作展开讨论。但是,让测试人员解放生产力,提高效率,把精力关注与最为重要的核心业务逻辑与测试设计上,是每个测试团队所必需要关注的。因此,在适当的范围内开展自动化测试,是可以提高整个测试团队的生产率的。

 对于Selenium,这个东西是一个浏览器应用程序测试工具。之所以选择它做WebUI的自动化测试主要是因为它有以下两大优势:

1.直接在浏览器中运行,就像真实用户所做的一样,可以模拟终端用户的操作,从最终客户的角度来测试应用程序。(这一点和黑盒功能测试很像吧。)

2.可以在 Windows、Linux 和 Macintosh上的 Internet Explorer、Chrome和 Firefox 中运行。其他测试工具都不能覆盖如此多的平台。(嗯,多面能手)

对于Java语言,我只想说你用你最拿手的就好。一个好的测试人员,不应该被开发语言所束缚。不管是Java/Python/Ruby/C#.........只要你熟悉,就尽量把它用起来吧。语言只是工具。

接下来,我们好好的慢慢的理解一些东西,然后来逐步的去写一点东西,来认识一下自动化测试框架是个什么东西。

 PS:阅读本文的同学,希望拥有JAVA语言编程基础,了解基本的JAVA语法与数据结构,同时,对Selenium的基本API有所了解。

 在写这个框架之前,我们要明确我们主要操作的对象是什么。------->页面元素。

我们要了解java在使用selenium时的基本操作。例如,使用以下代码:

driver.findElement(By.xpath("/html/body/div/div/div[2]/form/button")).click();

在这里,driver的意思是定义的WebDriver,findElement是driver这个对象调用的方法----->寻找页面元素,By.xpath是定位页面元素的方式,(“/html/body/div/div/div[2]/form/button”)是定位页面元素的参数,

.click()是找到页面元素后的动作------->点击。

那么,我们在这里考虑一下。对于通常的黑盒功能测试中,我们想在网页上面去找一个地方,进行点击或者输入文字等操作的时候,

我们一般会这样说:“用户名输入admin,密码是abcd”。

但是对于测试的代码来说,实际上有可能是:“找到页面元素ID是UserId的元素,使用sendKeys方法,参数为admin,找到页面元素ID是Password的元素,使用sendKeys方法,参数是abcd”。

需要解决的问题:

用户名(我们说的)--------->找到页面元素ID是UserId的元素(代码),输入admin(我们说的)--------->使用sendKeys方法,参数为admin。(代码)

一个页面元素的寻找需要几个要素,寻找的方式,寻找的参数,等待的时间。另外,为了我们说的话,代码能够明白,需要加上一个名字,用来告诉代码。

我们需要自己定义一个类,这个类就是页面元素类。通过上面的说明,我们知道这个类中需要定义的基本变量。(定位方法,路径,名字),另外,寻找路径需要时间,我们再加上一个时间。

package webui.xUtils;

public class Position {
  private String path; //----->路径
//位置名字,就是我们通常意义上叫的名字。例如:用户名输入框
  private String positionName;
  private ByType type;//定位方法
  private int waitSec;//等待时间   //selenium的基本八种定位方法。
  public enum ByType{
   xpath,id,name,className, cssSelector,tagName, partialLinkText,linkText
  }   public String getPath() {
    return path;
  }   public void setPath(String path) {
    this.path = path;
  }   public String getPositionName() {
    return positionName;
  }   public void setPositionName(String positionName) {
    this.positionName = positionName;
  }   public ByType getType() {
    return type;
  }   public void setType(ByType type) {
    this.type = type;
  }   public Position(String path, ByType type, String positionName) {
    super();
    this.path = path;
    this.positionName = positionName;
    this.type = type;
  }
  //这种可以看作是针对iframe的情况
  public Position(String path,String positionName) {
    super();
    this.path = path;
    this.positionName = positionName;
  }   public Position(String path, int waitSec, ByType type, String positionName) {
    super();
    this.path = path;
    this.waitSec = waitSec;
    this.positionName = positionName;
    this.type = type;
  }   public int getWaitSec() {
    return waitSec;
  }   public void setWaitSec(int waitSec) {
    this.waitSec = waitSec;
  }
}

使用上面的代码,我们就定义了最初的一个Position类,这就是我们要寻找的页面元素。

基于Java+Selenium的WebUI自动化测试框架(一)---页面元素定位器的更多相关文章

  1. 基于Java+Selenium的WebUI自动化测试框架(十四)-----使用TestNG的Sample

    到目前为止,我们所写的东西,都是集中在如何使用Selenium和Java来定位和读取元素.那么,到底如何具体开展测试,如何实现参数化,如何实现判定呢?下面,我们来看看Java应用程序的测试框架吧. 当 ...

  2. 基于Java+Selenium的WebUI自动化测试框架(十三)-----基础页面类BasePage(Excel)

    前面,我们讲了如何使用POI进行Excel的“按需读取”.根据前面我们写的BasePageX,我们可以很轻松的写出来基于这个“按需读取”的BasePage. package webui.xUtils; ...

  3. 基于Java+Selenium的WebUI自动化测试框架(八)-----读取元素(XML文件)

    我们继续回到自动化测试框架的主线上来,在前面的文章中,我们定义一个页面元素的主要参数有:路径,找寻方式,等待时间,名称,这个四个参数.另外,我们还需要考虑一个问题,就是网站的页面. 举个例子来说,如果 ...

  4. 基于Java+Selenium的WebUI自动化测试框架(六)---浏览器初始化

    本篇我们来讨论,如何写一个浏览器初始化的类.在写之前,先思考一下,我们需要一个什么样的初始化? 先来看看使用原生的Java + selenium是怎么做的.(以firefox为例) System.se ...

  5. 基于Java+Selenium的WebUI自动化测试框架(十)-----读取Excel文件(JXL)

    之前,我们使用了读取XML文件的方式来实现页面元素的读取,并做成了基础页面类.下面,我们来进行一些扩展,通过Excel来读取页面元素. Excel的使用,大多数人应该都不陌生.那么Java读取Exce ...

  6. 基于Java+Selenium的WebUI自动化测试框架(九)-----基础页面类(BasePage)

    上篇我们写了java读取xml文件的类,实现了可以从xml文件读取元素的方式.那么,接下来我们需要考虑一个问题.我们拿了这些元素之后怎么去操作呢? 先来看看我们手工测试的时候是怎么进行的. 双击浏览器 ...

  7. 基于Java+Selenium的WebUI自动化测试框架(五)------页面操作实现类

    在编写完Log类和监听类之后,终于要回到正轨上来了.我们继续开始写UIExcutor的实现类. PS:如果你想让你的报告更加美观一些.推荐使用reportNG这个jar包. 在项目中导入reportn ...

  8. 基于Java+Selenium的WebUI自动化测试框架(二)-----页面操作接口

    在有了基础的Position类之后,我们需要考虑我们在寻找完页面元素之后,需要做什么.这个“做”什么,可以理解为我们在页面上需要对应的一系列动作.比如:点击,输入,切换窗口,寻找元素,判断元素是否存在 ...

  9. 基于Java+Selenium的WebUI自动化测试框架(十一)-----读取Excel文件(POI)(1)

    上一篇说了利用JXL的jar包来读取Excel的代码.在Java中,还可以用另外一种jar包来读取Excel的内容,那就是Apache的POI. 这里和之前一样,需要导入POI的jar包,建议导入这三 ...

随机推荐

  1. delimiter关键字

    默认的sql语句以分号";"表示结束.mysql解释器每遇到一个分号,执行一段语句.可以通过delimiter更改语句结束符 mysql>delimiter &&am ...

  2. ETF:现金替代标志

    替代标志.表示该成份证券是否可被现金替代 0 – 沪市不可被替代 1 – 沪市可以被替代 2 – 沪市必须被替代 3 – 深市退补现金替代 4 – 深市必须现金替代 5 – 非沪深市场成分证券退补现金 ...

  3. linux安装jira

    JIRA配置本地MYSQL数据库 https://blog.csdn.net/coin_one/article/details/78376238 jira7.3.6 linux安装及破解 https: ...

  4. centos7 spark2.3.1集群搭建

    1.安装jdk 2.安装scala 参照jdk的安装 3.ssh 免密码登录 4.安装hadoop 以上四步请参照   centos7 安装hadoop2.7.6(分布式) 5.安装spark  1) ...

  5. python代码git上传

    python代码git上传 1.每次上传代码之前需要先拉取线上的代码 操作如下:

  6. perl修改镜像源地址

    perl修改源地址 这里推荐中科大的源 http://mirrors.ustc.edu.cn/CPAN/ perl -MCPAN -e shell 1.执行cpan命令确认存在该命令 如果cpan执行 ...

  7. [转帖]NSA武器库知识整理

    NSA武器库知识整理 https://www.cnblogs.com/FrostDeng/p/7120812.html 美国国家安全局(NSA)旗下的“方程式黑客组织”(shadow brokers) ...

  8. LInux因为缺失网关出现Name or service not known的解决方法

    笔者使用的VMware和CentOS 7.0.在安装完镜像包后,便开始配置静态ip.命令如下 vi /etc/sysconfig/network-scripts/ifcfg-ens33 将BOOTPR ...

  9. BJFU-215-基于链式存储结构的图书信息表的排序

    这里用的是冒泡排序 #include<stdio.h> #include<stdlib.h> #define MAX 100 typedef struct Book{ doub ...

  10. Django开发之登陆和登出

    使用django自带的验证模块 1.首先使用python manage.py startapp models为当前项目添加一个应用. 2.在setting.py中INSTALLED_APPS后面添加' ...