在许多测试用例当中,为了帮助我们创建正确的断言和发送正确的请求,打印出详细的响应和请求数据是非常有用的。为此我们可以使用rest-assured提供的预定义过滤器或者使用其中的一些快捷方法。

一、请求日志

  从1.5版本开始,rest-assured支持请求在发送到服务器之前打印特定请求日志的功能(通过使用RequestLoggingFilter过滤器的方式),这里我们注意到在打印的日志中HTTP Builder 和HTTP Client 会添加额外的头部信息(header)。这个过滤器支持只记录指定请求(RequestSpecification)的指定细节的日志,换句话说,我们可以不关注RequestLoggingFilter过滤器记录的实际发送到服务端的内容,因为在记录完日志之后,过滤器可能会修改请求(request)。如果想要记录实际发送到服务端的内容,可以参考 HTTP Client logging docs 或者使用第三方工具,比如Wireshark。例子如下:

 // 打印指定请求所有的请求细节日志,包括请求参数、请求头部以及请求体(body)等
given().log().all(). ..
//只打印请求参数日志
given().log().params(). ..
//只打印请求体日志
given().log().body(). ..
//只打印请求头部日志
given().log().headers(). ..
//只打印请求cookies
given().log().cookies(). ..
//只打印请求方法
given().log().method(). ..
//只打印请求路径
given().log().path(). ..

二、响应日志

  同样rest-assured也支持响应体日志的打印,比如:我们这里打印除了状态码之外的所有响应体信息,我们可以这样做:

 get("/x").then().log().body() ..

上面的做法无论是否有异常错误发生响应体都会被打印,如果我们只想当异常错误发生时,才打印响应体信息,我们可以这样做:

 get("/x").then().log().ifError(). .. 

同样我们也可以打印出所有的响应体信息,包括状态行(status line)、响应头(header)、cookies:

 get("/x").then().log().all(). .. 

也可以只打印状态行(status line)、响应头(header)、cookies:

 //只打印状态行
get("/x").then().log().statusLine(). ..
//只打印响应头
get("/x").then().log().headers(). ..
//只打印响应cookies
get("/x").then().log().cookies(). ..

我们也可以配置只有当响应状态码等于匹配某个值时,才打印响应信息:

 //只有当响应状态码等于302时,才会打印响应信息
get("/x").then().log().ifStatusCodeIsEqualTo(302). ..
//只有当响应状态码匹配提供的Hamcrest matcher,才会打印响应信息
get("/x").then().log().ifStatusCodeMatches(matcher). ..

三、验证失败日志

  从rest-assured的2.3.1版本开始,rest-assured支持只有当验证失败时才打印请求信息或响应信息的功能。

当验证失败时,打印请求日志,我们可以这样做:

 given().log().ifValidationFails(). ..

当验证失败时,打印响应日志,我们可以这样做:

 get("/x").then().log().ifValidationFails(). ..

我们通过使用 LogConfig 可以做到同时启用当验证失败时打印请求信息和响应信息:

 given().config(RestAssured.config().logConfig(logConfig().enableLoggingOfRequestAndResponseIfValidationFails(HEADERS))). ..

上面的做法只会打印当验证失败时的请求头部信息以及响应头部信息(header)。

这里还有一种针对 同时启用当验证失败时打印请求信息和响应信息 的简单方法:

 RestAssured.enableLoggingOfRequestAndResponseIfValidationFails();

rest-assured的日志使用介绍的更多相关文章

  1. Java常用日志框架介绍

    Java常用日志框架介绍 java日志概述 对于一个应用程序来说日志记录是必不可少的一部分.线上问题追踪,基于日志的业务逻辑统计分析等都离不日志.java领域存在多种日志框架,目前常用的日志框架包括L ...

  2. 【SpringBoot】Logback日志框架介绍和SpringBoot整合实战

    ========================11.Logback日志框架介绍和SpringBoot整合实战 2节课================================ 1.新日志框架L ...

  3. Java常用日志框架介绍(转)

    Java常用日志框架介绍 java日志概述 对于一个应用程序来说日志记录是必不可少的一部分.线上问题追踪,基于日志的业务逻辑统计分析等都离不日志.java领域存在多种日志框架,目前常用的日志框架包括L ...

  4. MySQL二进制日志功能介绍

    二进制日志记录所有更新数据的SQL语句,其中也包含可能更新数据的SQL语句,例如DELETE语句执行过程中无匹配的行.二进制日志中还包含了与执行SQL语句相关的内容,例如SQL语句执行的时间.错误代码 ...

  5. SpringBoot系列之日志框架介绍及其原理简介

    SpringBoot系列之日志框架介绍及其原理简介 1.常用日志框架简介 市面上常用日志框架:JUL.JCL.jboss-logging.logback.log4j.log4j2.slf4j.etc. ...

  6. Log4net 日志使用介绍

    概述 Log4net 有三个主要组件:loggers,appenders 和 layouts.这三个组件一起工作使得开发者能够根据信息类型和等级(Level)记录信息,以及在运行时控制信息的格式化和信 ...

  7. Linux_日志管理介绍(一)

    一.介绍 1.CentOS 6.x中日志服务已经由rsyslogd取代了原先的syslogd服务,但是rsyslogd是和syslogd服务相兼容的 2.除了系统默认的日志之外,采用RPM方式安装的系 ...

  8. .NET日志工具介绍

    最近项目需要一个日志工具来跟踪程序便于调试和测试,为此研究了一下.NET日志工具,本文介绍了一些主流的日志框架并进行了对比.发表出来与大家分享. 综述 所谓日志(这里指程序日志)就是用于记录程序执行过 ...

  9. 11、Logback日志框架介绍和SpringBoot整合实战 2节课

    1.新日志框架LogBack介绍     简介:日志介绍和新日志框架Logback讲解 1.常用处理java的日志组件 slf4j,log4j,logback,common-logging 等     ...

  10. PostgreSQL的日志文件介绍

    PostgreSQL的日志文件 pg_log:数据库活动日志(也就是数据库的操作日志): pg_xlog:事务日志: pg_clog:事务状态日志(pg_clog是pg_xlog的辅助日志). 现在主 ...

随机推荐

  1. volatile和 锁的区别

    Volatile: 当把变量声明为volatile类型后,编译器和运行时都会注意到这个变量是共享的,因此不会将该变量上的操作与其它内存操作一起重排序.volatile变量不会被缓存在寄存器或者对其他处 ...

  2. validate 不校验的解决办法

    最近使用validate.js用于项目的表单校验,调了半天,怎么都不校验,仔细对照例子发现 例子中要校验的文本框除了ID外还有name属性,而我在做的时候没有name属性,到这里终于 看到了希望,把所 ...

  3. 使用递归函数,输出n个元素的所有子集

    题目描述: 请编写一个递归函数,用来输出n个元素的所有子集.例如,三个元素{a,b,c}的所有子集是:{},{a},{b},{c},{a,c},{ac},{b,c},{a,b,c}. 解题思路: 根据 ...

  4. datatables01 安装、数据源、选中行事件、新增一行数据、删除一行数据

    1 安装 1.1 引入必要文件 要在项目中使用datatables需要引入三个文件 >DataTables CSS >jQuery >DataTables JS <!-- Da ...

  5. 453. Minimum Moves to Equal Array Elements 一次改2个数,变成统一的

    [抄题]: Given a non-empty integer array of size n, find the minimum number of moves required to make a ...

  6. JavaPersistenceWithMyBatis3笔记-第5章Configuring MyBatis in a Spring applications-001

    一. 1.Mapper /** * */ package com.mybatis3.mappers; import java.util.List; import org.apache.ibatis.a ...

  7. Luogu 3265 [JLOI2015]装备购买

    BZOJ 4004 把所有不能相互表示出来的向量都买下,一定能得到最大能买的方案数. 求解线性无关向量可以高斯消元,最后没有变成$0$向量的就是基底. 本题还要求代价最小怎么办?我们只要先把所有向量按 ...

  8. 专题1-MMU-lesson3-MMU配置与使用

    1.段方式MMU 利用虚拟地址然后找到物理地址,通过物理地址访问到led,其过程如下: 一个段的大小是[19:0]总共有1M的地址空间. 从上面可知对应GPIO的段物理基地址是0x7f000000.那 ...

  9. Sharepoint 文档知识管理系统--Word在试图打开文件时遇到错误

    在系统开发中,遇到问题:SharePoint 2010与Office 2010安装在一台服务器上,当用Office打开SharePoint文档库中的文档时,遇到“Word在试图打开文件时遇到错误,请尝 ...

  10. ApplicationContex是干啥的

    ApplicationContext就是一个百宝箱 ApplicationContext是Spring的核心,Context我们通常解释为上下文环境,我想用“容器”来表述它更容易理解一些,Applic ...