如何解决Spring Boot 与 Mockito 模拟 NamedParameterJdbcTemplate
尝试对定义为的方法进行单元测试:
public void myMethod(List<? extends MyModel> model){
int[] result = namedParameterJdbcTemplate.batchUpdate("update query",sqlParameterSourceUtils.createBatch(model));
}
在我的测试类中,我将测试方法定义为
class MyTestClass{
@Mock
NamedParameterJdbcTemplate namedParameterJdbcTemplate;
@InjectMocks
MyDao dao;
@Test
public void testMyMethod() {
final int[] rowsAffected = new int[]{1,2};
when(namedParameterJdbcTemplate.batchUpdate(any(),sqlParameterSourceUtils.createBatch(Arrays.asList(anySet())))).thenReturn(rowsAffected);
List<MyModel> myModels = new ArrayList<>();
MyModel mymodel = new MyModel();
mymodel.setSomeParam("");
myModels.add(mymodel);
dao.myMethod(myModels);
}
}
在运行此测试方法时,我在调用的方法(myMethod())中收到 NullPointerException。 int[] 结果为空。我的理解是它应该从模拟中的存根中获得结果。 请帮助我理解我做错了什么。
解决方法
您似乎没有使用正确的 any()
导入,因为如果它是来自 Mockito 的正确 ArgumentMatchers.any()
,Mockito 会抱怨您没有使用 ArgumentMatcher
.batchUpdate()
的两个参数。
您可以使用 import static org.mockito.ArgumentMatchers.*;
或使用 ArgumentMatchers.any()
静态导入它。
作为第一步,请尝试以下操作:
when(namedParameterJdbcTemplate.batchUpdate(ArgumentMatchers.any(),ArgumentMatchers.any())).thenReturn(rowsAffected);
或者不那么通用并且匹配 SqlParameterSourceUtils.createBatch()
的返回类型:
// I don't know what SqlParameterSourceUtils.createBatch() returns,so you might have to adjust it
when(namedParameterJdbcTemplate.batchUpdate(ArgumentMatchers.any(),ArgumentMatchers.eq("SOME RETURN"))).thenReturn(rowsAffected);
,
它的工作原理是将演员表添加到参数匹配器中: 更新代码:
when(namedParameterJdbcTemplate.batchUpdate(anyString(),(SqlParameterSource[]) any())).thenReturn(rowsAffected);
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。