Mam kod podobny do tego poniżej:
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;
}
}
Teraz piszę test dla A.myMethod(someargs)
. Chcę pominąć prawdziwą metodę query.getNextId()
i zamiast tego zwrócić wartość zastępczą. Zasadniczo chcę kpić MyQueryClass
.
Więc w moim przypadku testowym użyłem:
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
Użyłem @RunWith(PowerMockRunner.class)
i @PrepareForTest({MyQueryClass.class})
na początku mojej klasy testowej.
Ale kiedy debugowania test, to wciąż wywołując prawdziwą metodę getNextId()
z MyQueryClass
klasy.
Czego tu brakuje? Czy ktoś może pomóc, ponieważ jestem nowy w Mockito i PowerMockito.
Jak @TrueDub wspomniał w swojej zaakceptowanej odpowiedzi, musisz dodać klasę, w której konstruktor jest wywoływany, do pliku
@PrepareForTest
.Jeśli jednak to zrobisz, pokrycie dla tej klasy zgłoszone przez eclemma i Sonar będzie wynosić zero dla tej klasy
Powermockito wiki
Tak więc rozwiązaniem tutaj byłoby zrefaktoryzowanie rzeczywistego kodu, aby używał statycznej fabryki, która zwróciłaby instancję tej klasy, a następnie statycznie z niej mockowała.
źródło
Być może możesz po prostu użyć
źródło