Spring jdbcTemplate 上的 EasyMock 总是返回 null 而不是模拟对象
EasyMock on Spring jdbcTemplate is always returning null rather mocked object
我正在尝试在 Java Spring 项目上使用 EasyMock 3.4。我已经成功地模拟了所有对象并测试了 类 除了使用 JDBCTemplate 的 DAO。
@RunWith(EasyMockRunner.class)
public class DummyDAOImplTest extends EasyMockSupport {
@TestSubject
private DummyDAOImpl dummyDAOImpl = new DummyDAOImpl ();
JdbcTemplate jdbcTemplateObject;
@Before
public void setUp(){
jdbcTemplateObject = EasyMock.createNiceMock(JdbcTemplate.class);
dummyDAOImpl.setJdbcTemplate(jdbcTemplateObject);
}
@Test
public void testGetApplicationConfigValueReturnNonNull(){
String query = "SELECT value FROM application_configuration WHERE tag=?";
String tag = "REFRESH_INTERVAL";
EasyMock.expect(jdbcTemplateObject.queryForObject(query,new Object[] {tag}, String.class)).andReturn("12");
EasyMock.replay(jdbcTemplateObject);
Assert.assertEquals(12,dummyDAOImpl.getApplicationConfigValue(tag));
}
}
public class ConfigurationDAOImpl implements ConfigurationDAO {
private JdbcTemplate jdbcTemplateObject;
@Override
public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
this.jdbcTemplateObject = jdbcTemplate;
}
@Override
public int getApplicationConfigValue(String tag) {
String query = "SELECT value FROM application_configuration WHERE tag=?";
String refreshTime = jdbcTemplateObject.queryForObject(query,new Object[] {tag}, String.class);
if(refreshTime != null && !"".equals(refreshTime))
return new Integer(refreshTime);
else
return 0;
}
}
尽管在方法 testGetApplicationConfigValueReturnNonNull 中 - 我试图将其模拟为 return 12 但它总是 return 为空。
第一次使用EasyMock。任何我已经尝试过但无法破解的东西!
此致,
桑达尔
可能您需要加载 Spring 上下文
@ContextConfiguration(locations = "classpath:application-context-test.xml")
@RunWith(EasyMockRunner.class) public class DummyDAOImplTest extends EasyMockSupport { ...
像这样覆盖你的appplication-context
application-context-test.xml
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/context/ http://www.springframework.org/schema/context/spring-context-3.0.xsd
http://www.springframework.org/schema/tx/ http://www.springframework.org/schema/tx/spring-tx-3.2.xsd
http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd"><import resource="application-context.xml"/><bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<property name="driverClassName" value="org.hsqldb.jdbcDriver" />
<property name="url" value="jdbc:your-db-conection" />
<property name="username" value="" />
<property name="password" value="" />
事实上,你唯一的问题是你的期望线。应该是
EasyMock.expect(jdbcTemplateObject.queryForObject(eq(query), aryEq(new Object[] {tag}), eq(String.class))).andReturn("12");
默认情况下,EasyMock 将对参数执行 equals
以匹配预期。问题是没有为数组定义 equals
。所以你需要为数组(aryEq
)指定一个匹配器。一旦你有一个参数的匹配器,你就需要为所有的参数匹配一个(出于技术原因)。
经过一些简化的完整代码如下。
- 我假设你要测试的是
ConfigurationDAO
- 您可以
replayAll
因为您正在扩展 EasyMockSupport
- 你可以使用
@Mock
因为亚军
- 您不需要漂亮的模拟。事实上,在这里不使用它会显示一个关于意外调用的很好的异常,这对你来说真的很有帮助
- 模拟现在也由
EasyMockRunner
注入
- 我更喜欢在我的大部分测试结束时添加一个
verifyAll
。它确保所有期望都被使用
- 静态导入,因为我觉得读起来更清晰
代码:
import static org.easymock.EasyMock.*;
import static org.junit.Assert.*;
@RunWith(EasyMockRunner.class)
public class DummyDAOImplTest extends EasyMockSupport {
@TestSubject
private ConfigurationDAOImpl dao = new ConfigurationDAOImpl();
@Mock
JdbcTemplate jdbcTemplateObject;
@Test
public void testGetApplicationConfigValueReturnNonNull(){
String query = "SELECT value FROM application_configuration WHERE tag=?";
String tag = "REFRESH_INTERVAL";
expect(jdbcTemplateObject.queryForObject(eq(query), aryEq(new Object[] {tag}), eq(String.class))).andReturn("12");
replayAll();
assertEquals(12, dao.getApplicationConfigValue(tag));
verifyAll();
}
}
我正在尝试在 Java Spring 项目上使用 EasyMock 3.4。我已经成功地模拟了所有对象并测试了 类 除了使用 JDBCTemplate 的 DAO。
@RunWith(EasyMockRunner.class)
public class DummyDAOImplTest extends EasyMockSupport {
@TestSubject
private DummyDAOImpl dummyDAOImpl = new DummyDAOImpl ();
JdbcTemplate jdbcTemplateObject;
@Before
public void setUp(){
jdbcTemplateObject = EasyMock.createNiceMock(JdbcTemplate.class);
dummyDAOImpl.setJdbcTemplate(jdbcTemplateObject);
}
@Test
public void testGetApplicationConfigValueReturnNonNull(){
String query = "SELECT value FROM application_configuration WHERE tag=?";
String tag = "REFRESH_INTERVAL";
EasyMock.expect(jdbcTemplateObject.queryForObject(query,new Object[] {tag}, String.class)).andReturn("12");
EasyMock.replay(jdbcTemplateObject);
Assert.assertEquals(12,dummyDAOImpl.getApplicationConfigValue(tag));
}
}
public class ConfigurationDAOImpl implements ConfigurationDAO {
private JdbcTemplate jdbcTemplateObject;
@Override
public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
this.jdbcTemplateObject = jdbcTemplate;
}
@Override
public int getApplicationConfigValue(String tag) {
String query = "SELECT value FROM application_configuration WHERE tag=?";
String refreshTime = jdbcTemplateObject.queryForObject(query,new Object[] {tag}, String.class);
if(refreshTime != null && !"".equals(refreshTime))
return new Integer(refreshTime);
else
return 0;
}
}
尽管在方法 testGetApplicationConfigValueReturnNonNull 中 - 我试图将其模拟为 return 12 但它总是 return 为空。
第一次使用EasyMock。任何我已经尝试过但无法破解的东西!
此致, 桑达尔
可能您需要加载 Spring 上下文
@ContextConfiguration(locations = "classpath:application-context-test.xml")
@RunWith(EasyMockRunner.class) public class DummyDAOImplTest extends EasyMockSupport { ...
像这样覆盖你的appplication-context
application-context-test.xml
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/context/ http://www.springframework.org/schema/context/spring-context-3.0.xsd
http://www.springframework.org/schema/tx/ http://www.springframework.org/schema/tx/spring-tx-3.2.xsd
http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd"><import resource="application-context.xml"/><bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<property name="driverClassName" value="org.hsqldb.jdbcDriver" />
<property name="url" value="jdbc:your-db-conection" />
<property name="username" value="" />
<property name="password" value="" />
事实上,你唯一的问题是你的期望线。应该是
EasyMock.expect(jdbcTemplateObject.queryForObject(eq(query), aryEq(new Object[] {tag}), eq(String.class))).andReturn("12");
默认情况下,EasyMock 将对参数执行 equals
以匹配预期。问题是没有为数组定义 equals
。所以你需要为数组(aryEq
)指定一个匹配器。一旦你有一个参数的匹配器,你就需要为所有的参数匹配一个(出于技术原因)。
经过一些简化的完整代码如下。
- 我假设你要测试的是
ConfigurationDAO
- 您可以
replayAll
因为您正在扩展 EasyMockSupport - 你可以使用
@Mock
因为亚军 - 您不需要漂亮的模拟。事实上,在这里不使用它会显示一个关于意外调用的很好的异常,这对你来说真的很有帮助
- 模拟现在也由
EasyMockRunner
注入
- 我更喜欢在我的大部分测试结束时添加一个
verifyAll
。它确保所有期望都被使用 - 静态导入,因为我觉得读起来更清晰
代码:
import static org.easymock.EasyMock.*;
import static org.junit.Assert.*;
@RunWith(EasyMockRunner.class)
public class DummyDAOImplTest extends EasyMockSupport {
@TestSubject
private ConfigurationDAOImpl dao = new ConfigurationDAOImpl();
@Mock
JdbcTemplate jdbcTemplateObject;
@Test
public void testGetApplicationConfigValueReturnNonNull(){
String query = "SELECT value FROM application_configuration WHERE tag=?";
String tag = "REFRESH_INTERVAL";
expect(jdbcTemplateObject.queryForObject(eq(query), aryEq(new Object[] {tag}), eq(String.class))).andReturn("12");
replayAll();
assertEquals(12, dao.getApplicationConfigValue(tag));
verifyAll();
}
}