怎么创建WebTestClient


本篇内容介绍了“怎么创建WebTestClient”的有关知识,在实际案例的操作过 香港云主机程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!WebTestClient是围绕WebClient的薄壳,可用于执行请求并公开专用的流利API来验证响应。 WebTestClient通过使用模拟请求和响应绑定到WebFlux应用程序,或者它可以通过HTTP连接测试任何Web服务器。3.7.1 安装要创建WebTestClient,必须选择多个服务器设置选项之一。实际上,你是在配置WebFlux应用程序以绑定到该URL,还是使用URL连接到正在运行的服务器。绑定到控制器以下示例显示如何创建服务器设置以一次测试一个@Controller:前面的示例加载WebFlux Java配置并注册给定的控制器。使用模拟请求和响应对象,可以在没有HTTP服务器的情况下测试生成的WebFlux应用程序。构建器上有更多方法可以定制默认WebFlux Java配置。绑定到路由器功能以下示例显示了如何通过RouterFunction设置服务器:在内部,配置被传递到RouterFunctions.toWebHandler。使用模拟请求和响应对象,可以在没有HTTP服务器的情况下测试生成的WebFlux应用程序。绑定到ApplicationContext以下示例显示了如何通过应用程序或其部分子集的Spring配置来设置服务器:指定要加载的配置注入配置创建WebTestClient在内部,配置被传递到WebHttpHandlerBuilder以建立请求处理链。有关更多详细信息,请参见WebHandler API。使用模拟请求和响应对象,可以在没有HTTP服务器的情况下测试生成的WebFlux应用程序。绑定到服务器以下服务器设置选项使你可以连接到正在运行的服务器:客户端构建者除了前面介绍的服务器设置选项之外,你还可以配置客户端选项、包括基本URL、默认标头,客户端过滤器等。这些选项在bindToServer之后很容易获得。对于所有其他服务器,你需要使用configureClient()从服务器配置过渡到客户端配置,如下所示:3.7.2 写测试WebTestClient提供了与WebClient相同的API,直到使用exchange()执行请求为止。 exchange()之后是链接的API工作流,用于验证响应。通常,首先声明响应状态和标头,如下所示:然后,你指定如何解码和使用响应主体:ExpectBody(Class ):解码为单个对象。ExpectBodyList(Class ):解码并将对象收集到List ExpectBody():解码为byte []以获取JSON内容或一个空的正文。然后,你可以为主体使用内置的断言。以下示例显示了一种方法:你还可以超越内置的断言并创建自己的断言,如以下示例所示:你还可以退出工作流程并获得结果,如下所示:当你需要使用泛型解码为目标类型时,请寻找接受ParameterizedTypeReference而不是Class 的重载方法。无内容如果响应没有内容(或者你不在乎),请使用Void.class,以确保释放资源。以下示例显示了如何执行此操作:或者,如果要断言没有响应内容,则可以使用类似于以下内容的代码:JSON内容当你使用ExpectBody()时,响应以byte[]的形式使用。这对于原始内容声明很有用。例如,你可以使用JSONAssert来验证JSON内容,如下所示:你还可以使用JSONPath表达式,如下所示:流式响应要测试无限流(例如,“ text/event-stream”或“ application/stream + json”),你需要在响应状态和响应头断言之后立即退出链接的API(通过使用returnResult),如下所示示例显示:现在,你可以使用Flux ,在到达解码对象时对其进行断言,然后在达到测试目标时在某个时候取消。我们建议使用反应堆测试模块中的StepVerifier进行此操作,如以下示例所示:请求体当涉及到构建请求时,WebTestClient提供了与WebClient相同的API,实现主要是简单的传递。“怎么创建WebTestClient”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注开发云网站,小编将为大家输出更多高质量的实用文章!

相关推荐: 怎么用Python制作一份可视化的旅行攻略

这篇文章主要介绍“怎么用Python制作一份可视化的旅行攻略”,在日常操作中,相信很多人在怎么用Python制作一份可视化的旅行攻略问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用Python制作一份可视化的旅行攻略”的疑惑…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 10/07 10:51
下一篇 10/07 10:51

相关推荐