基于Java汇总Spock框架Mock静态资源经验
作者:FunTester 发布时间:2023-11-25 04:42:29
前面讲了 Spock框架Mock对象方法经验总结
一、静态方法
Mock静态方法我们使用PowerMock
结合Mockito
的方案,首先在测试类增加如 * 解:
@RunWith(PowerMockRunner.class)
@PowerMockRunnerDelegate(Sputnik.class)
@PrepareForTest([NewUtil.class, HttpBase.class])
@PowerMockIgnore(["javax.management.*"])
@SuppressStaticInitializationFor(["com.funtester.util.NewUtil", "com.funtester.util.HttpBase"])
@RunWith
和@PowerMockRunnerDelegate
注解内容不用改动,直接复制即可,@PrepareForTest
注解后面的类就是需要被Mock的类。@PowerMockIgnore这个注解用于忽略一些检查和异常。@SuppressStaticInitializationFor
这个注解处理类的初始化,这个注解后面跟的是不需要进行初始化的类的包路径,在现在的实践中通常和@PrepareForTest
后面的类是一致的。
其次我们需要在类初始化代码中对这个类进行Mock,语法如下:
PowerMockito.mockStatic(HttpBase.class)
PowerMockito.mockStatic(NewUtil.class)
下面演示一下如何自定义静态方法的行为:
PowerMockito.when(HttpBase.fetchServiceNames()).thenReturn(["service-prod", "api-pro", "prod", "service-prd", "write-pro"])
定义静态方法行为和非静态方法行为,在语法上是一致的,
二、混合场景
当一个测试用例中,既要Mock静态方法,也要Mock对象方法,就必须使用PowerMock提供的能力。原因之前提过,主要是因为增加了类注解之后,Spock
和Mockito
一的Mock对象和定义方法的功能会无法运行,这个没找到具体的文档做出区分,所以如果遇到混合场景,建议使用PowerMock进行对象的Mock。
使用语法上,就是混合了PowerMock
处理静态和非静态资源,以及行为模拟的语法。
Demo如下:
@RunWith(PowerMockRunner.class)
@PowerMockRunnerDelegate(Sputnik.class)
@PrepareForTest([NewUtil.class, HttpBase.class])
@PowerMockIgnore(["javax.management.*"])
@SuppressStaticInitializationFor(["com.funtester.util.newinterface.NewUtil", "com.funtester.util.slowapi.HttpBase"])
class TaskScheduledTest extends Specification {
@Shared
def service = PowerMockito.mock(IService)
def drive = new TaskScheduled(IService: service, cid: "")
def setupSpec() {
PowerMockito.mockStatic(HttpBase.class)
PowerMockito.mockStatic(NewUtil.class)
PowerMockito.when(HttpBase.fetch()).thenReturn(["ood", "ero"])
Mockito.when(newutil.filter(Mockito.any())).thenReturn(true)
Mockito.when(newser.selectAll()).thenReturn([new NewInterface() {
{
setUrl("/abc")
setNname("test")
setMethod("GET")
}
}, new NewInterface() {
{
setUrl("/abcd")
setNname("test")
setMethod("POST")
}
}, new NewInterface() {
{
setUrl("/abce")
setNname("test")
setMethod("GET")
}
}])
//这里因为send方法中用到了这个静态方法
PowerMockito.when(NewUtil.getsAll(anyList(), anyBoolean())).thenReturn([new NewInterface() {
{
setUrl("/abc")
setNname("test")
setMethod("GET")
}
}, new NewInterface() {
{
setUrl("/abc")
setNname("test")
setMethod("GET")
}
}])
}
def "Send"() {
given:
drive.send()
}
def "day"() {
}
}
PS:在Mockito高版本的依赖mockito-inline中,也是支持对静态类和静态方法的Mock的,但在Spock中极难使用,资料说是因为项目pom中的Spock版本与Mockito版本不一致导致的,尝试了几个组合依然无法解决,又有人言,跟Groovy依赖的版本也有关系,直接破防,放弃了这个方案。
来源:https://blog.51cto.com/FunTester/4957444
猜你喜欢
- 一般而言,Android 应用在请求数据时都是以 Get 或 Post 等方式向远程服务器发起请求,那你有没有想过其实我们也可以在 Andr
- 最近有小伙伴问我,双枚举类该怎么写,还得包括根据key取值方法。于是就手写一个案例如下:/** * 关系类型枚举 */public enum
- javax.el.ELException的解决方式failed to parse the expression [${xxx}]Tomcat
- 1.登录腾讯云点击登录选择浏览器登录。输入用户名 按回车键 然后输入 密码。2.安装java环境直接命令:yum -y install ja
- 一、什么是命令模式命令模式是一个高内聚的模式,其定义为:将一个请求封装成一个对象,从而让你使用不同的请求把客户端参数化,对请 求排队或者记录
- 简介happens-before是JMM的核心概念。理解happens-before是了解JMM的关键。1、设计意图JMM的设计需要考虑两个
- 仅供学习交流,禁止商业用途。如侵害利益,联系必删!前言最近一位小伙伴钟爱二次元文化,于是找到半次元这个app,但是很快他就遇到了问题。一、案
- 由于 Spring 拥有对象的管理权,所以我们也需要拥有较为高效的对象存储和取出的手段,下面我们来分别总结一下:存对象配置文件在存储对象之前
- 这篇文章主要介绍了java property配置文件管理工具框架过程详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考
- 前言很多时候,当你以为掌握了事实真相的时间,如果你能再深入一点,你可能会发现另外一些真相。比如面向切面编程的最佳编程实践是AOP,AOP的主
- 周末这天手痒,正好没事干,想着写一个分页的例子出来给大家分享一下。这个案例分前端和后台两部分,前端使用面向对象的方式写的,里面用到了一些回调
- 如果不知道,类的静态变量存储在那? 方法的局部变量存储在那? 赶快收藏Java内存区域主要可以分为共享内存,堆、方法区和线程私有内存,虚拟机
- 一、spring-boot-devtools在pom中直接引入依赖<dependency> <groupId&
- 前言使用SpringBoot来开发项目相对于传统模式,要快速优雅许多,相信目前国内绝大部分web项目的开发还没有使用SpringBoot来做
- 本文实例为大家分享了Java执行SQL脚本文件到数据库的具体方式,供大家参考,具体内容如下方式一:直接读取SQL脚本文件的内容,然后传递到S
- 最近由于工作要求:前端采用vue开发,后端采用springboot开发,前后端分离开发,最后前端页面又整合到后端来。经历多次采坑,总结以下方
- 问题背景通常我们开发的时候,需要联合控制台和Navicat/PLSQL等工具进行语句的拼接检查,如果只是输出了一堆???,那么将极大降低我们
- 线程状态NEW:刚创建未启动的线程RUNNABLE:正在执行状态BLOCKED:处于阻塞状态的线程WAITING:正在等待另一个线程执行特定
- Java环境配置原理详解1.Jdk安装目录文件说明:一般jdk安装目录及路径 \Java\jdk1.7.0_79\lib,里面主要包含以下文
- 大顶堆每个结点的值都大于或等于其左右孩子结点的值小顶堆每个结点的值都小于或等于其左右孩子结点的值对比图实现代码public class He