RestAssured接口自动化从入门到框架搭建-15-RequestSpecBuilder和ResponseSpecBuilder和日志打印使用

本篇来学习一下RequestSpecBuilder和ResponseSpecBuilder,这个在这个系列第二篇文章,阅读RestAssured.java源码的时候可能提到过这个类或者相关接口。

 

1.RequestSpecBuilder举例

场景:浏览器打开 http://jsonplaceholder.typicode.com/posts?userId=2

下面是请求头截图

下面用代码来写这个过程,主要是请求发送之前,利用RequestSpecification对象来封装一些请求数据,例如参数,例如Header。

package demo;

import org.testng.annotations.BeforeClass;
import org.testng.annotations.Test;

import io.restassured.specification.RequestSpecification;
import io.restassured.builder.RequestSpecBuilder;
import static io.restassured.RestAssured.*;


public class RequestSpecBuilderTest {
	RequestSpecification requestSpc;
	
	@BeforeClass
	public void setup() {
		RequestSpecBuilder builder = new RequestSpecBuilder();
		builder.addParam("userId", "2");
		builder.addHeader("Accept-Encoding", "gzip, deflate");
		requestSpc = builder.build();
	}
	
	@Test
	public void test1() {
		given().
			spec(requestSpc).log().all().
		when().
			get("http://jsonplaceholder.typicode.com/posts").
		then().
			statusCode(200).log().all();
	}

}

如果这样运行,这个请求地址端口默认是8080,好奇怪。

[RemoteTestNG] detected TestNG version 6.14.3
Request method:	GET
Request URI:	http://jsonplaceholder.typicode.com:8080/posts?userId=2
Proxy:			<none>
Request params:	userId=2
Query params:	<none>
Form params:	<none>
Path params:	<none>
Headers:		Accept-Encoding=gzip, deflate
				Accept=*/*

所以,需要在上面代码get中,改成http://jsonplaceholder.typicode.com:80/posts

才能运行通过。

 

2.RespondeSpecBuilder举例

上面这种请求封装过程,在响应这块,同样也有类似的类去支持这么做。

场景:我们把一些确定每次请求回来响应数据中那些不变的内容,可以一次性封装到响应期待对象中。例如每次状态码是200,某一些Header字段等。直接来看代码

package demo;

import org.testng.annotations.BeforeClass;
import org.testng.annotations.Test;
import static io.restassured.RestAssured.*;
import io.restassured.builder.ResponseSpecBuilder;
import io.restassured.specification.ResponseSpecification;
import static org.hamcrest.Matchers.*;

public class ResponseSpecBuilderTest {
	ResponseSpecification responseSpc;
	
	@BeforeClass
	public void setup() {
		ResponseSpecBuilder builder = new ResponseSpecBuilder();
		builder.expectStatusCode(200);
		builder.expectHeader("Content-Type", "application/json; charset=utf-8");
		builder.expectHeader("Cache-Control", "public, max-age=14400");
		responseSpc = builder.build();
	}
	
	@Test
	public void test1( ) {
		when().
			get("http://jsonplaceholder.typicode.com/posts?userId=2").
		then().
			spec(responseSpc).
			time(lessThan(3000L));
	}

}

这种响应期待一起封装的作用还是使用比较多。上面我写只写了一个测试用例,使用这种模式,写多个测试用例就可以看出好处多多。

 

3.日志打印

我们前面多次使用了在请求或者响应之后使用log().all(), 这个是打印全部信息,现在我们来细分学习下log()这个方法用法。

第一种,只打印header 或者只打印cookes 或者只打印body

        /**
	 * 日志打印1
	 */
	@Test
	public void testLogOnly() {
		given().
			get("http://jsonplaceholder.typicode.com/photos/").
		then().
			//log().headers();
			//log().body();
		    log().cookies();
	}

分别放开上面注释,一个一个分别测试下,打印日志和浏览器手动访问对比看看是不是一致。

第二种情况,只有发生错误情况下打印日志

        /**
	 * 只有发生错误 情况下才打印日志
	 */
	@Test
	public void testLogOnlyError() {
		given().
		get("http://jsonplaceholder.typicode.com/phot/").
	then().
		log().ifError();
	}

我想这个方法好,特别是自动化测试报告中,并不想每个执行过程都打印日志,出错才打印日志。

第三张情况,只有满足一些特定条件才打印日志,下面模拟响应状态码等于200才打印日志。

        /**
	 * 在特定条件下才打印日志
	 */
	@Test
	public void testLogUnderConditional() {
		given().
		get("http://jsonplaceholder.typicode.com/photos/").
	then().
		log().ifStatusCodeIsEqualTo(200);
	}

关于日志打印,这里我们来一个总结,如果是在写代码过程,我们建议使用log().all(), 全部打印出来,方便我们debug。如果是写好了接口用例,我们建议写只打印需要和必要的日志就行。例如遇到错误才打印等。

 

 

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
TestNG 是一种流行的测试框架,它提供了丰富的功能来进行单元测试、集成测试和端到端测试。TestNG 结合 TestAssured 可以进行接口自动化测试,以下是 TestNG TestAssured 接口自动化测试框架的优点: 1. 简单易用:TestNG TestAssured 框架易于学习和使用。TestNG 的注解可以方便地对测试用例进行分组、依赖、优先级等操作,而 TestAssured 提供了直观的 API,可以轻松地完成接口测试。 2. 支持多种验证方式:TestAssured 提供了多种验证方式,如 body、header、cookie、statusCode、responseTime 等,可以全面地验证接口的正确性。 3. 支持数据驱动:TestNG TestAssured 框架可以通过数据驱动的方式进行接口测试,可以通过 Excel、CSV、JSON 等数据源进行参数化测试,提高了测试效率和覆盖率。 4. 支持并发测试:TestNG TestAssured 框架支持并发测试,可以提高测试效率。可以通过 TestNG 的 parallel 属性来设置并发线程数,也可以通过 TestAssured 的 RestAssured.config() 方法来设置并发连接数。 5. 集成度高:TestNG TestAssured 框架可以与其他测试工具和框架集成,如 Maven、Jenkins、ExtentReports 等,可以方便地进行持续集成和测试报告生成。 总之,TestNG TestAssured 接口自动化测试框架具有易用性高、多种验证方式、数据驱动、并发测试、集成度高等优点,是进行接口自动化测试的不二选择。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值