测试开发 | 接口自动化测试框架 RESTAssured 实践(三):对 Response 结果导出

图片
本文为霍格沃兹测试学院优秀学员课程学习笔记,想一起系统进阶的同学文末加群交流。

rest-assured对response结果的导出

图片

上一篇文章中介绍了rest-assured对返回结果的断言,最后说明了对于Response结果导出的需求。可查看往期文章进行查看。

这里将继续研究rest-assured对response结果的导出获取,现有一个登录接口auth/oauth/token,接口的部分返回值如下:

HTTP/1.1 200 OK
Server: nginx/1.12.2
Date: Mon, 13 Jan 2020 02:15:11 GMT
Content-Type: application/json;charset=UTF-8
Transfer-Encoding: chunked
Expires: 0
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
X-XSS-Protection: 1; mode=block
Pragma: no-cache
X-Frame-Options: DENY
X-Content-Type-Options: nosniff
Proxy-Connection: keep-alive

{
“code”: 1,
“msg”: null,
“data”: {
“tenant_id”: 6,
“userType”: “1”,
“dept_id”: 0,
“user_id”: 6,
“username”: “xxx”,
“jti”: “afeb93f8-e4e4-4c15-955b-90cee130c4c7”,
“access_token”: “eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.exxxzciLCJjbGllbnRfaWQiOiJzeXN0ZW0iLCJ1c2VybmFtZSI6InFpbnpoZW4ifQ.6NQmjJp_9XSveOaATNLjtTktWe6_WjHY0o9NbBUdDx8”,
“expires_in”: 9999999,
“token_type”: “bearer”
}

}

语法演示

图片
注:因这篇文章主要目的是演示返回值的导出功能,所以演示代码中将省略请求参数部分,如需了解可参考文章往期文章。

extract().path()
extract是我们获取返回值的核心,通过它来指明后面需要获取的内容,path()中的语法同断言时的JsonPath一致,例如我们现在要获取user_id,写法如下:

@Test
void login(){
… .
when()
.log().all().post(“http://47.xxx.xxx.133/auth/oauth/token”).
then()
.log().all().statusCode(200).body(“code”,equalTo(1))
.extract().path(“data.user_id”);
System.out.println(“返回id的值是:”+id);
}

运行结果:

图片

extract().asString()
有时候我们可能需要获取ResponseBody中的多个值,例如我们现在想要获取返回体body中的dept_id和user_id,我们就可以利用extract().asString()先将响应结果以json字符串的形式保存下来,再一一根据需要获取,具体写法如下:

@Test
void login(){
… .
when()
.log().all().post(“http://47.xxx.xxx.133/auth/oauth/token”).
then()
.log().all().statusCode(200).body(“code”,equalTo(1))
.extract().asString();
System.out.println(“返回body的值是:”+json);
System.out.println(“获取user_id的值是:”+ from(json).get(“data.user_id”));
System.out.println(“获取dept_id的值是:”+ from(json).get(“data.dept_id”));
}

运行结果:

图片

注:这里用到的from是rest-assured的,不要导错包了:import static io.restassured.path.json.JsonPath.from;

extract().response()
上面都是对响应体的结果进行导出,但是实际工作中我们的需求远不止于此,我们可能还需要响应头等信息,例如一些接口的Token、就可能会在响应信息的Header中返回;

这个时候就可以利用extract().response()来讲所有的response信息都保存成一个Response对象:

@Test
void login(){
… .
when()
.log().all().post(“http://47.xxx.xxx.133/auth/oauth/token”).
then()
.log().all().statusCode(200).body(“code”,equalTo(1))
.extract().response();
System.out.println(“返回response是:”+response);
}

运行结果:

图片

然后再利用各种Response.get方法来获取。

1)获取所有的Headers

@Test
void login(){
… .
when()
.log().all().post(“http://47.xxx.xxx.133/auth/oauth/token”).
then()
.log().all().statusCode(200).body(“code”,equalTo(1))
.extract().response();
System.out.println(“返回headers是:\n”+response.getHeaders());
}

运行结果:

图片

2)获取某一个header值
类似key,value的结构,使用getHeader(“headerName”)即可,例如我们这里要获取Content-type的值:

@Test
void login(){
… .
when()
.log().all().post(“http://47.xxx.xxx.133/auth/oauth/token”).
then()
.log().all().statusCode(200).body(“code”,equalTo(1))
.extract().response();
System.out.println(“返回Content-Type是:\n”+response.getHeader(“Content-Type”));
}

运行结果:

图片

3)获取status line——getStatusLine()

@Test
void login(){
… .
when()
.log().all().post(“http://47.xxx.xxx.133/auth/oauth/token”).
then()
.log().all().statusCode(200).body(“code”,equalTo(1))
.extract().response();
System.out.println(“返回StatusLine是:\n”+response.getStatusLine());
}

运行结果:

图片

4)获取status code——getStatusCode()

@Test
void login(){
… .
when()
.log().all().post(“http://47.xxx.xxx.133/auth/oauth/token”).
then()
.log().all().statusCode(200).body(“code”,equalTo(1))
.extract().response();
System.out.println(“返回StatusCode是:\n”+response.getStatusCode());
}

运行结果:

图片

5)获取cookies——getCookies()、getCookie(“cookieName”)
rest-assured还为我们提供了方便获取cookie的方法;因本例中无cookies返回,所以仅展示代码语法,有需要的可自行测试或参考官方文档

// Get all cookies as simple name-value pairs
Map<String, String> allCookies = response.getCookies();
// Get a single cookie value:
String cookieValue = response.getCookie(“cookieName”);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值