大数跨境
0
0

UI自动化测试之元素管理

UI自动化测试之元素管理 点融黑帮
2017-12-06
4
导读:今天来聊一聊UI自动化测试中的元素管理。

自动化测试框架意义


自动化测试框架的意义在于提高脚本编写效率,降低代码的冗余度,提高脚本的可读性及降低脚本的维护成本。

框架的分层思想


自动化测试脚本从最初的线型测试,到模块驱动测试、数据驱动测试、对象驱动测试,自动化框架的分层思想一直在改进。自动化测试框架分层思想大致可归为:元素对象层、业务场景层、测试数据层、公共服务层;例如:driver管理,日志,测试报告,运行机制等,均可写在公共service层中;分层思想可以达到最大程度的减少冗余代码,降低代码的维护成本;

元素对象的管理


元素对象作为脚本执行的基础颗粒,对其的管理尤为重要。元素对象的维护成本将直接影响脚本的维护成本。本文将介绍3种元素对象的管理方式,通过比较其优缺点,表明元素对象的管理对自动化脚本的影响。


1)使用文本管理元素对象

以web端页面元素为例,使用XML或YAML等格式的文件管理元素对象,具体实现如下:


  • 元素对象管理文件---TestBaidu.yaml


  • 使用jar包:jyaml-1.3.jar解析yaml文件,生成Map<String,Map<String, String>>类型的数据elements;

  • 根据type类型将value转换成By对象;


  • 生成一个WebElement对象:

public WebElement getElement(String key) { 
    String type = elements.get(key).get("type");
    String value = elements.get(key).get("value");    return driver.findElement(this.getBy(type,value));
}

这种管理方式的优点:

  • 如果UI变了,我们只需要修改文件中对应元素的值,脚本不需要重新编译(如果是用需要编译的语言,如JAVA);

  • 只有在用到页面上的一个元素时,才会去定位这个元素,实例化该元素对象;

  • 可以用中文给元素命名,脚本可读性高;

  • 操作人员上手的门槛低;


这种管理方式的缺点:

  • 编写脚本时,输入元素对象,不能利用代码编辑器中的智能提示功能;

  • 文件中元素的命名有可能重复,导致前一个元素值被后一个同名元素值覆盖;

  • 手误导致文件中元素的名称与代码中元素名不一致;

  • 文件数量较大的时候,UI变了,修改元素对象的值的时候,定位文件比较困难,文件维护成本随着脚本量增多而增大;


2)使用代码管理元素对象,编写元素对象类:

脚本中编写页面元素对象类,可以按页面或业务来组织,其中,可以重写WebElement类的方法,来简化页面对象的定义及实例化,增强部分方法的健壮性及打Log,具体实现如下:


  • 重写WebElement类的方法 (如下,只截取部分代码);


  • 编写Locator类,优化getElement方法、等待元素加载完成方法、等待元素显示等方法,保证脚本的健壮性;

  • 按页面或业务场景编写元素对象类;


这种管理方式的优点:

  • 编写脚本时,输入元素对象,利用代码编辑器中的智能提示功能,降低输入错误的概率;

  • 没有管理元素的文件的成本;

  • UI改变后,脚本运行报错,可根据报错信息,利用代码编辑器的Go to Declaration功能找到该元素对象定义的地方,修改元素对象值,定位错误较快捷;


这种管理方式的缺点:

  • 编写脚本的测试人员需要懂代码;

  • 没有1中的元素管理方式的可读性强;

  • 对于IOS及Android应用,需要维护2套元素对象类;


3)Appium PageFactory

针对IOS及Android应用,页面元素对象值不同的问题,Appium的客户端提供了一个类AppiumFieldDecorator,FieldDecorator  顾名思义,是Page对象Field的Decorator。PageFactory主要就是在Feild上下功夫,使用注解的方式实现页面元素对象的定义。


  • 脚本的元素层:


  • 元素层的父类PageObjectBase,使用PageFactory初始化field;


这种管理方式的优点

  • IOS与android自动化脚本可以合并为一份,减少脚本的维护量;

  • 自己决定是否缓存找到的元素。默认情况下,每次调用方法时,都会重新去定位页面元素,这对于处理使用AJAX技术的页面很有用;处理其它的页面,可以找到元素后就缓存起来。

  • 使用注解的方式的方式定义页面元素,简洁;

  • 只有在用到页面上的一个元素时,才会去定位这个元素;


这种管理方式的缺点

  • 编写脚本的测试人员需要懂代码;


文章到这里就结束了,欢迎大家一起交流探讨。



点击回顾往期精彩内容

苏海德受邀出席世界互联网大会,畅谈金融科技服务多层次经济

【译文】Adobe XD产品经理教你如何进行设计思考

点融网登录背后那些事儿

交换网络环境的故障诊断

摘下NPS(净推荐值)的光环

浅谈JVM原理

单元测试之spock实践

面试环节——建立面试标准

批判性思维和互联网辩论指南

【译文】用户帮助服务的5个层级

构建私有云服务


想要了解更多请关注我们


【声明】内容源于网络
0
0
点融黑帮
点融黑帮——一个充满激情和梦想的技术团队,吸引了来自金融及信息科技领域的顶尖人才。我们正在用技术创新改变传统金融。
内容 374
粉丝 0
点融黑帮 点融黑帮——一个充满激情和梦想的技术团队,吸引了来自金融及信息科技领域的顶尖人才。我们正在用技术创新改变传统金融。
总阅读570
粉丝0
内容374