0

尝试对定义为的方法进行单元测试:

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[] 结果为空。我的理解是它应该从模拟中的存根中得到结果。请帮助我理解我做错了什么。

4

2 回答 2

0

它通过将演员添加到参数匹配器来工作:更新代码:

    when(namedParameterJdbcTemplate.batchUpdate(anyString(), (SqlParameterSource[]) any())).thenReturn(rowsAffected);
于 2021-02-08T16:57:01.947 回答
0

似乎您没有使用正确的导入,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()with 的返回类型:

// 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);
于 2021-02-06T15:43:09.203 回答