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)指定一个匹配器。一旦你有一个参数的匹配器,你就需要为所有的参数匹配一个(出于技术原因)。

经过一些简化的完整代码如下。

  1. 我假设你要测试的是ConfigurationDAO
  2. 您可以 replayAll 因为您正在扩展 EasyMockSupport
  3. 你可以使用 @Mock 因为亚军
  4. 您不需要漂亮的模拟。事实上,在这里不使用它会显示一个关于意外调用的很好的异常,这对你来说真的很有帮助
  5. 模拟现在也由 EasyMockRunner
  6. 注入
  7. 我更喜欢在我的大部分测试结束时添加一个 verifyAll。它确保所有期望都被使用
  8. 静态导入,因为我觉得读起来更清晰

代码:

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();
  }
}