【发布时间】:2021-07-17 19:04:08
【问题描述】:
每当 simpleJdbcCall.execute(namedParameters) 调用时,我都会尝试抛出异常,但我发现它没有抛出错误,这里有什么我遗漏的吗?
这是我的课
class A {
@Autowired
JdbcTemplate jdbcTemplate;
@Autowired
private SimpleJdbcCall simpleJdbcCall;
public int mymeth(){
simpleJdbcCall.withProcedureName("myproc").declareParameters(new SqlParameter("ID",
Types.VARCHAR);
SqlParameterSource namedParameters = new MapSqlParameterSource("id" , 12);
Map<String, Object> result = null;
try {
//I want Junit to throw error here
result = simpleJdbcCall.execute(namedParameters);
} catch (Exception e) {
throw new Exception(e.getMessage());
}
return (Integer) result.get("Status");
}
}
这是我的 Junit 课程
@RunWith(SpringRunner.class)
@SpringBootTest(classes = Application.class, webEnvironment = SpringBootTest.WebEnvironment.RANDOM_PORT)
@TestInstance(TestInstance.Lifecycle.PER_CLASS)
Class ATest{
@Autowired
private A obj;
@Test
public void throwExceptionFromMethod() {
try {
SimpleJdbcCall simpleJdbcCall = Mockito.mock(SimpleJdbcCall.class);
SqlParameterSource sqlParameterSource = Mockito.mock(SqlParameterSource.class);
Mockito.doThrow(new RuntimeException()).when(simpleJdbcCall ).execute((Object)
Mockito.any());
final int message = obj.mymeth(modifyLeadDispositionRequest);
Assert.assertEquals(0, message);
} catch (Exception e) {
e.printStackTrace();
}
}
}
【问题讨论】:
-
你的
obj得到了 SpringRunner 注入的SimpleJdbcCall,你的 mock 永远不会被使用 -
@Turo,你能分享任何例子吗?
标签: java spring spring-boot junit spring-boot-test