我有代码在其中使用CallableStatement.executeQuery()填充Resultset。我嘲笑了ResultSet和CallableStatement,但为了测试我必须填充ResultSet的方法。如何模拟结果集并使用Java中的Mockito填充它
这里是从方法我测试
ResultSet rset = cs.executeQuery();
while (rset.next()) {
IndexVolatilityImpl tsImpl = new IndexVolatilityImpl();
tsImpl.setTradeDate(rset.getString("trade_date"));
tsImpl.setTradeTime(rset.getString("trade_time"));
tsImpl.setExprDate(rset.getString("expr_date"));
tsImpl.setSymbol(rset.getString("symbol"));
tsImpl.setTradePrice(rset.getDouble("trade_price"));
tsImpl.setContractMonth(rset.getString("contract_month"));
tsImpl.setMilliSecs(rset.getString("trade_time_thou"));
colIndexVolatilityImpl.add(tsImpl);
的代码,我嘲笑的CallableStatement和ResultSet,因为现在他们嘲笑我的RSET出现空。我想填充Resultset并按如下方式执行:
resultSetMock = Mockito.mock(ResultSet.class);
Mockito.when(resultSetMock.getString("trade_date")).thenReturn("03/10/2011");
Mockito.when(resultSetMock.getString("trade_time")).thenReturn("12:24:56");
Mockito.when(resultSetMock.getString("expr_date")).thenReturn("03/19/2011");
Mockito.when(resultSetMock.getString("symbol")).thenReturn("VIX1");
Mockito.when(resultSetMock.getDouble("trade_price")).thenReturn(Double.valueOf("20.96"));
Mockito.when(resultSetMock.getString("contract_month")).thenReturn("1");
Mockito.when(resultSetMock.getString("trade_time_thou")).thenReturn("165");
Mockito.doReturn(resultSetMock).when(callableStatementMock).executeQuery();
但是结果集签出为空。
因此,任何帮助将不胜感激,以帮助如何填充模拟结果集。
感谢 Tejas的
最好的答案是在底部,并拥有超过24 upvotes通过@proactif – nanospeck 2017-06-23 05:26:08