Как имитировать jdbcTemplate.query с параметрами (Object [] {})

Я пытаюсь использовать mockito для имитации jdbcTemplate и вызвать запрос метода, передав ему параметры с помощью Object [] {}.

Я делаю модульный тест для своего уровня DAO. Я хочу имитировать jdbcTemplate, вызвать метод query и передать строку sql, RowMapper и параметры с помощью Object [] {}

public List<EntityType> myDaoMethod(Date fechaInicio, Date fechaFin)
            throws NotDataFoundException {
        log.info("entering => myDaoMethod");
        log.info("param => fechaInicio :" +  fechaInicio);
        log.info("param => fechaFin :" +  fechaFin);

        log.debug("Se ejecutando consulta...");
        try {

            List<EntityType> query = jdbcTemplate.query(QueryStrs.MY_QUERY,
                    new Object[] {fechaInicio, fechaFin},
                    new BeanPropertyRowMapper<EntityType>(EntityType.class));
            log.debug("Se ejecuto consulta. ");

            return query;
        }catch(DataAccessException e) {
            log.error("No se encontro informacion en la consulta myDaoMethod (2)", e);
            throw new NotDataFoundException(e);
        }finally {
            log.info("exiting => myDaoMethod");
        }
    }
    @Mock
    private JdbcTemplate jdbcTemplate;

        @Test
    public void myTestMethod() throws NotDataFoundException {

        List<EntityType> listValue = new ArrayList<>();

        listValue.add(new EntityType((short) 2, "modem 2"));
        listValue.add(new EntityType((short) 1, "modem"));

        when(jdbcTemplate.query(any(String.class),any(Object[].class), any(BeanPropertyRowMapper.class))).thenReturn(listValue);

        MyDao dao = new MyDaoImpl(jdbcTemplate);
        List<EntityType> otrasAdicionalesPorRangoFecha = dao.myDaoMethod(any(Date.class), any(Date.class));

        Assert.assertNotNull(otrasAdicionalesPorRangoFecha);
        Assert.assertTrue(!otrasAdicionalesPorRangoFecha.isEmpty());
//      Assert.assertArrayEquals(listValue.toArray(), otrasAdicionalesPorRangoFecha.toArray());

    }

Результат трассировки

org.mockito.exceptions.misusing.InvalidUseOfMatchersException: недопустимое использование сопоставителей аргументов! Ожидается 3 совпадения, 2 записано: -> в com.oracle.reporter.tddtest.rrhhcomision.OtrasAdicionalesDaoTest.testBuscarOtrasAdicionalesPorFecha (OtrasAdicionalesDaoTest.java:80) -> в com.oracle.reporter.tdddestravelsaoTest.Java: 80 : 80)

Это исключение может возникнуть, если сопоставители комбинируются с необработанными значениями: // неверно: someMethod (anyObject (), "raw String"); При использовании сопоставителей все аргументы должны предоставляться сопоставителями. Например: // правильно: someMethod (anyObject (), eq ("String by matcher"));


person getzels    schedule 26.06.2019    source источник


Ответы (1)


Проблема в том, что ваш dao не является имитируемым объектом, поэтому на этом этапе вы не должны передавать сопоставители.

Неправильный:

dao.myDaoMethod(any(Date.class), any(Date.class));

Правильный:

dao.myDaoMethod(new Date(1), new Date(2));
person second    schedule 27.06.2019
comment
Спасибо @second, это решение. - person getzels; 27.06.2019