Ошибка утверждения EasyMock для JdbcTemplate - неожиданный вызов метода - PullRequest
0 голосов
/ 07 августа 2020

Я пытаюсь протестировать вызов jdbctemplate.queryForObject() с помощью Easymock, но получаю Assertion error: Unexpected method call JdbcTemplate.queryForObject : expected: 1, actual: 0

Я пытался сослаться на другие ответы на SO, у которых была похожая проблема, и попытался их реализовать, но это не помогло, и я все еще застрял на том же месте. Я также попытался передать значения как EasyMock.isA() или eq(), но все равно ошибка. Подскажите, пожалуйста, что я делаю неправильно.

Я использую EasyMock 3.5.1

AuthenticationDaoImpl. java

public boolean checkIfCallExist(String ucid){
        String decision = null;
        String sql = "select count(*) from tablename where ucid=?"
        decision = jdbcTemplate.queryForObject(sql, new Object[]{ucid}, String.class);
        return (Integer.parseInt(decision)>0);
    }

AuthenticationDaoImplTest. java

@RunWith(EasyMockRunner.class)
public class AuthenticationDaoImplTest {

    @TestSubject
    private AuthenticationDaoImpl authenticationDaoImpl = new AuthenticationDaoImpl();

    @Mock
    JdbcTemplate jdbcTemplateObject;

    @Test
    public void checkIfCallExistTest(){
        String sql = "select count(*) from tablename where ucid=?";
        Object[] params = new Object[] { "testucid" };
        EasyMock.expect(this.jdbcTemplateObject.queryForObject(sql, params, String.class)).andReturn("0");
        EasyMock.replay(this.jdbcTemplateObject);
        boolean res = this.authenticationDaoImpl.checkIfCallExist("testUcid");
        assertEquals(false, res);
    }
}

Error Stacktrace

java.lang.AssertionError: 
  Unexpected method call JdbcTemplate.queryForObject("select count(*) from tablename where ucid=?", ["testUcid"], class java.lang.String):
    JdbcTemplate.queryForObject("select count(*) from tablename where ucid=?", ["testucid"], class java.lang.String): expected: 1, actual: 0
    at org.easymock.internal.MockInvocationHandler.invoke(MockInvocationHandler.java:44)
    at org.easymock.internal.ObjectMethodsFilter.invoke(ObjectMethodsFilter.java:94)
    at org.easymock.internal.ClassProxyFactory$MockMethodInterceptor.intercept(ClassProxyFactory.java:95)
    at org.springframework.jdbc.core.JdbcTemplate$$EnhancerByCGLIB$$a2fb2844.queryForObject(<generated>)
    at org.authenticationint.dao.AuthenticationDaoImpl.checkIfCallExist(AuthenticationDaoImpl.java:53)
    at org.authenticationint.dao.AuthenticationDaoImplTest.checkIfCallExistTest(AuthenticationDaoImplTest.java:83)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    ...

1 Ответ

1 голос
/ 07 августа 2020

Ошибка в параметре.

Object[] params = new Object[] { "testucid" }

this.authenticationDaoImpl.checkIfCallExist("testUcid"); // should be testucid
...