У меня есть примерно такой код ниже:
Class A {
public boolean myMethod(someargs) {
MyQueryClass query = new MyQueryClass();
Long id = query.getNextId();
// some more code
}
}
Class MyQueryClass {
....
public Long getNextId() {
//lot of DB code, execute some DB query
return id;
}
}
Сейчас пишу тест на A.myMethod(someargs)
. Я хочу пропустить реальный метод query.getNextId()
и вместо этого вернуть значение-заглушку. В принципе, я хочу поиздеваться MyQueryClass
.
Итак, в моем тестовом примере я использовал:
MyQueryClass query = PowerMockito.mock(MyQueryClass.class);
PowerMockito.whenNew(MyQueryClass.class).withNoArguments().thenReturn(query);
when(query.getNextId()).thenReturn(1000000L);
boolean b = A.getInstance().myMethod(args);
//asserts
Я использовал @RunWith(PowerMockRunner.class)
и @PrepareForTest({MyQueryClass.class})
в начале своего тестового класса.
Но когда я отлаживать тест, он по - прежнему называть реальный метод getNextId()
в MyQueryClass
классе.
Что мне здесь не хватает? Может ли кто-нибудь помочь, поскольку я новичок в Mockito и PowerMockito.
Как отметил @TrueDub в своем принятом ответе, вам нужно добавить класс, в котором вызывается конструктор, в
@PrepareForTest
.Однако, если вы сделаете это, покрытие для этого класса, как сообщает eclemma и Sonar, будет нулевым для этого класса.
Powermockito вики
Таким образом, решением здесь было бы рефакторинг фактического кода для использования статической фабрики, которая возвращала бы экземпляр этого класса, а затем статически имитировала бы его.
источник
Возможно, вы можете просто использовать
источник