Junit5+Yaml文档实现参数化驱动测试
在Junit5详解文章中提到,当前测试框架能够使用多种方式实现参数化,但是在参数格式复杂的时候,用的比较多的是Yaml文档+@MethodSource的方式实现;因为yaml文档能够很好地定义各种形式的参数,且文档比其他格式更加清晰直观。接下来就讲解下此种方式的简单实践。
案例:当前有一个登录接口,需要使用不同参数实现参数化驱动(接口就不写了~)
一、定义yaml格式参数
- desc: 正确的用户名密码
account: "Account"
password: "password"
statusCode: 200
- desc: 正确的用户名错误的密码
account: "Account"
password: "errorPassword"
statusCode: 500
- desc: 错误的用户名正确的密码
account: "errorAccount"
password: "password"
statusCode: 500
二、添加解析yaml文档的依赖
<dependency>
<groupId>com.fasterxml.jackson.dataformat</groupId>
<artifactId>jackson-dataformat-yaml</artifactId>
<version>2.12.3</version>
</dependency>
三、使用对Yaml文档进行序列化并配合@MethodSource进行用例参数化
@MethodSource("loginData")
@ParameterizedTest
void successAddPlanTest(HashMap<String,Object> loginData){
logger("用例描述:" + loginData.get(desc));
Response response = LoginApi.login(loginData.get("account"),loginData.get("password"))
assertThat(response.statusCode(),equalTo(loginData.get("statusCode")))
}
public static ArrayList<HashMap<String,Object>> loginData() throws IOException {
// 对yaml文档进行反序列化
ObjectMapper mapper = new ObjectMapper(new YAMLFactory());
// ArrayList<HashMap<String,String>> 是yaml文档中定义的参数类型
ArrayList<HashMap<String,String>> addTestData = (ArrayList<HashMap<String,String>>)mapper.readValue(new File("yamlPath"),
new ArrayList<HashMap<String,String>>().getClass());
return addTestData;
}
以上就是yaml文档进行参数化的简单实践;就以上的参数内容的话可能看不出使用yaml的好处在哪,但是需要传的参数格式比较复杂的话(比如list套map类的),就可以很明显比较出这种方式的优势了。