testNG优雅的使用注解让你的测试项目开发更高效!
testNG大部分是通过xml配置测试类和监听类
- 但是这种方法就像传统的spring框架一样需要引入大量的xml配置信息,而且在各层之间也需要通过new对象传递。如果testNG能使用注解注入bean对象,那么完成一个自动化项目的开发周期必然会缩短很多。于是在spring官网看到支持TestNG Support Classes。大致说明如下:

官方文档地址
可以通过抽象类AbstractTestNGSpringContextTests,实现bean查找或测试整个上下文的状态。
现在大部分后端项目是springboot框架,下面就以springboot框架结合testNG实现注解注入bean实例介绍:
- 首先想要通过注解注入bean对象,需要基础的测试类继承抽象AbstractTestNGSpringContextTests类,同时基础测试类还需要加上@SpringBootTest注解和通用@Component注解,这样就能在各层通过@Component通用注解实现bean对象的传递。
- 基础测试类注入如下:
@Slf4j
@Component
@SpringBootTest
public class BaseTest extends AbstractTestNGSpringContextTests{
/**
* 驱动基类
*/
@Autowired
private BaseChromeDriver baseDriver;
/**
* 驱动
* 对外暴露
*/
public WebDriver driver;
}
- testcase层使用注解注入元素操作层对象,示例如下:
@Listeners(com.iwebui.listener.AssertListener.class)
public class BaiduLoginCase extends BaseTest {
@Autowired
private BaiDuCaseEasypoiHandle baiDuCaseEasypoiHandle;
@Autowired
BaiDuCaseJpaHandle baiDuCaseJpaHandle;
/**
* easypoi实现excel数据驱动
*/
@Severity( SeverityLevel.NORMAL)
@Description("百度登录测试示例--使用easypoi实现")
@Test
public void baibaiDuCaseEasypoiHandle(){
//初始化ticketElement,获取驱动
baiDuCaseEasypoiHandle.serchBaidu(driver);
//excel数据驱动测试-使用easypoi实现
baiDuCaseEasypoiHandle.loginCase(driver);
}
/**
* JPA实现数据库数据驱动示例
*/
@Severity( SeverityLevel.NORMAL)
@Description("百度登录测试示例--使用springDataJPA实现")
@Test
public void baiDuCaseJpaHandle(){
//进入被测网址
baiDuCaseJpaHandle.serchBaidu(driver);
//数据库驱动,使用jpa实现
baiDuCaseJpaHandle.getAll(driver);
}
}
- 元素操作层同样可以使用注解注入dao层对象,示例如下:
@Component
public class BaiDuCaseJpaHandle extends BaseBrowser {
@Autowired
private BaiDuLoginDao baiDuLoginDao;
@Autowired
private BaiDuUrlDao baiDuUrlDao;
public void serchBaidu(WebDriver driver){
log.info("开始进入被测页面");
enterPage(driver,AccountData.BAIDUURL);
}
public List<Logincase> getAll(WebDriver driver) {
UIElementUtil.clickButton("百度登录","点击右上角登录按钮",driver);
UIElementUtil.clickButton("百度登录","点击账号密码登录按钮",driver);
List<Logincase> logincaseList = baiDuLoginDao.findAll();
List<UrlMessage> urlMessageList = baiDuUrlDao.findAll();
//2.使用自定义写的sql方法操作数据库
Map<Long, UrlMessage> map = new HashMap<>();
urlMessageList.forEach(urlMessage -> {
map.put(urlMessage.getId(), urlMessage);
});
logincaseList.forEach(logincase -> {
String address = "";
String actual = "";
if (logincase.getCaseStatus().equals(1)) {
UrlMessage urlMessage = map.get(logincase.getUrlId());
if (urlMessage != null) {
address = urlMessage.getAddress();
}
if (!address.equals("")) {
baiDuLoginDao.updateLogincase(address, logincase.getId());
}
UIElementUtil.sendInput("百度登录","登录账号",driver,logincase.getName());
UIElementUtil.sendInput("百度登录","登录密码",driver,logincase.getPwd());
UIElementUtil.clickButton("百度登录","登录按钮",driver);
actual = driver.findElement(AccountData.TIPS).getText();
baiDuLoginDao.updateActual(actual,logincase.getId());
}else {
UrlMessage urlMessage = map.get(logincase.getUrlId());
address = urlMessage.getAddress();
baiDuLoginDao.updateLogincase(address, logincase.getId());
}
});
return null;
}
}
- 由于使用springDataJPA大大简化了书写sql语句,直接继承JpaRepository接口即可。
@Repository
public interface BaiDuUrlDao extends JpaRepository<UrlMessage, Long> {
}
另外大多数testNG配置文件也是通过xml、config.properties来完成配置文件的加载,这种配置流程繁琐。而yaml文件的配置更简单上手,这里通过yaml配置文件完成配置参数的加载。testNG通过yaml文件配置如下:
- 通过key|value形式加载配置文件,编写加载工具类如下:
public class LoadStaticConfigUtil {
public static Object getCommonYml(Object key){
Resource resource = new ClassPathResource("/application-dev.yml");
Properties properties = null;
try {
YamlPropertiesFactoryBean yamlFactory = new YamlPropertiesFactoryBean();
yamlFactory.setResources(resource);
properties = yamlFactory.getObject();
} catch (Exception e) {
e.printStackTrace();
return null;
}
return properties.get(key);
}
}
yaml配置信息如下:

然后就可以通过加载配置文件工具类,传入key即可

这样就完成了yaml获取配置信息的过程,更多技术分享可以关注[Coding测试]公众号。
更多测试技术分享、学习资源以及一些其他福利可关注公众号:【Coding测试】获取:

testNG优雅的使用注解让你的测试项目开发更高效!的更多相关文章
- testNG官方文档翻译-2 注解
这里是一份TestNG中的可用注解及其属性的概述. 一.用于一个TestNG类的信息配置的注解: @BeforeSuite:被BeforeSuite注解的方法将在其所在suite中的所有test运行之 ...
- Spring + Spring MVC + Hibernate项目开发集成(注解)
在自己从事的项目中都是使用xml配置的方式来进行的,随着项目的越来越大,会发现配置文件会相当的庞大,这个不利于项目的进行和后期的维护.于是考虑使用注解的方式来进行项目的开发,前些日子就抽空学习了一下. ...
- MyBatis 项目开发中是基于 XML 还是注解?
只要你对 MyBatis 有所认识和了解,想必知道 MyBatis 有两种 SQL 语句映射模式,一种是基于注解,一种是基于XML. 基于 XML <mapper namespace=" ...
- Karmada v1.3:更优雅 更精准 更高效
摘要:最新发布的1.3版本中,Karmada重新设计了应用跨集群故障迁移功能,实现了基于污点的故障驱逐机制,并提供平滑的故障迁移过程,可以有效保障服务迁移过程的连续性(不断服). 本文分享自华为云社区 ...
- Testng之使用@DataProvider注解做数据驱动【转】
原文:http://www.jianshu.com/p/8e333a0ec42a 前两天学了一下@DataProvider,今天有时间总结一下.testng很强大,提供了很多注解,其中利用@DataP ...
- 自动化测试框架selenium+java+TestNG——TestNG注解、执行、测试结果和测试报告
TestNG是java的一个测试框架,相比较于junit,功能更强大和完善,我是直接学习和使用的TestNG就来谈下TestNG的一些特点吧. TestNG的特点 注解 TestNG使用Java和面向 ...
- testng失败截图,注解方式调用。
今天一整天都在研究testng失败截图的方法,参考网上的前辈们的资料,加上自己的理解,终于搞出来了. package com.dengnapianhuahai; /** * 自定义注释 * */ im ...
- testng基础知识:注解的执行顺序
1. 单类,无继承父子关系 code: public class basicTest { @BeforeSuite(alwaysRun = true) public void beforeSuite_ ...
- TestNG @Factory与 @DataProvider 结合使用进行参数化测试
简介 TestNG是一个设计用来简化广泛的测试需求的测试框架,从单元测试到集成测试,这个是TestNG设计的出发点,不仅仅是单元测试,而且可以用于集成测试.设计目标的不同,对比junit的只适合用于单 ...
随机推荐
- Spring与Junit测试整合
一.引入spring测试包:text包 二.@RunWith:指定spring对junit提供的一个运行器 @ContextConfiguration: locations指定spring配置文件位 ...
- Centos-退出抽取设备-eject
eject 退出抽取设备,如光驱或磁带,如果设备已经挂载,则卸载设备 相关选项 -q 退出磁盘 -r 退出光盘 -d 显示默认设备
- Centos-zip压缩-文件或目录-zip unzip
zip uzip 将一般文件或者目录进行压缩或者解压,默认以 .zip为后缀名 zip 相关选项 -r 递归压缩目录 -d 从压缩包中删除指定文件 -i 压缩指定文件列表文件 -x 压缩排除指定文件 ...
- Python练习题 049:Project Euler 022:姓名分值
本题来自 Project Euler 第22题:https://projecteuler.net/problem=22 ''' Project Euler: Problem 22: Names sco ...
- Python练习题 030:Project Euler 002:偶数斐波那契数之和
本题来自 Project Euler 第2题:https://projecteuler.net/problem=2 # Each new term in the Fibonacci sequence ...
- Power Designer建模之餐饮在线点评系统——业务处理模型
餐饮在线点评系统除查看会员促销活动.查看站内消息等简单业务流程外,相对复杂的业务流程包括管理员注册餐厅,发布餐厅信息,餐厅信息主要包括特色菜.促销活动.团购活动和优惠券信息. 餐厅信息发布后,用户可以 ...
- tomcat:tomcat安装(在一台电脑上安装两个tomcat)
1.安装前的说明 (1)在安装第二个tomcat之前,我们要知道安装一台tomcat的时候需要在电脑上添加两个系统变量 然后在path中配置: (2)这个时候我们就要思考了,当安装第二台服务器的时候首 ...
- Android设备上的逐像素碰撞检测
介绍 我正在我的Android设备上开发一款游戏,不用说,因为我想要接触到尽可能多的用户,我做到了 省略了硬件加速.因此,我需要编写能够在大多数设备上运行的最快的代码.我从一个简单的表面视图开始 并使 ...
- 跨时代的MySQL8.0新特性解读
目录 MySQL发展历程 MySQL8.0新特性 秒级加列 性能提升 文档数据库 SQL增强 共用表表达式(CTEs) 不可见索引(Invisible Indexes) 降序索引(Descending ...
- devops-jenkins部署和基本使用
1. jenkins部署和基本使用 1.1) 先关闭centos 7的自带防火墙和selinux [root@test-2 ~]# /bin/systemctl stop firewalld [ro ...