Miałem ten sam problem, w którym prywatna wartość nie została ustawiona, ponieważ Mockito nie wywołuje super konstruktorów. Oto jak potęguję kpiny refleksją.
Najpierw utworzyłem klasę TestUtils, która zawiera wiele pomocnych narzędzi, w tym metody odbicia. Dostęp do refleksji jest za każdym razem nieco trudny do wdrożenia. Stworzyłem te metody, aby przetestować kod w projektach, które z jakiegoś powodu nie miały pakietu symulującego i nie zostałem zaproszony do włączenia go.
public class TestUtils {
public static Object reflectValue(Class<?> classToReflect, String fieldNameValueToFetch) {
try {
Field reflectField = reflectField(classToReflect, fieldNameValueToFetch);
reflectField.setAccessible(true);
Object reflectValue = reflectField.get(classToReflect);
return reflectValue;
} catch (Exception e) {
fail("Failed to reflect "+fieldNameValueToFetch);
}
return null;
}
public static Object reflectValue(Object objToReflect, String fieldNameValueToFetch) {
try {
Field reflectField = reflectField(objToReflect.getClass(), fieldNameValueToFetch);
Object reflectValue = reflectField.get(objToReflect);
return reflectValue;
} catch (Exception e) {
fail("Failed to reflect "+fieldNameValueToFetch);
}
return null;
}
public static Field reflectField(Class<?> classToReflect, String fieldNameValueToFetch) {
try {
Field reflectField = null;
Class<?> classForReflect = classToReflect;
do {
try {
reflectField = classForReflect.getDeclaredField(fieldNameValueToFetch);
} catch (NoSuchFieldException e) {
classForReflect = classForReflect.getSuperclass();
}
} while (reflectField==null || classForReflect==null);
reflectField.setAccessible(true);
return reflectField;
} catch (Exception e) {
fail("Failed to reflect "+fieldNameValueToFetch +" from "+ classToReflect);
}
return null;
}
public static void refectSetValue(Object objToReflect, String fieldNameToSet, Object valueToSet) {
try {
Field reflectField = reflectField(objToReflect.getClass(), fieldNameToSet);
reflectField.set(objToReflect, valueToSet);
} catch (Exception e) {
fail("Failed to reflectively set "+ fieldNameToSet +"="+ valueToSet);
}
}
}
Następnie mogę przetestować klasę za pomocą takiej zmiennej prywatnej. Jest to przydatne do wyszydzania głęboko w drzewach klas, nad którymi również nie masz kontroli.
@Test
public void testWithRectiveMock() throws Exception {
ClassToMock mock = Mockito.mock(ClassToMock.class);
TestUtils.refectSetValue(mock, "privateVariable", "newValue");
Mockito.when(mock.somthingElse()).thenReturn("anotherThing");
}
Zmodyfikowałem mój kod z mojego aktualnego projektu tutaj, na stronie. Mogą wystąpić problemy z kompilacją lub dwa. Myślę, że masz ogólny pomysł. Możesz pobrać kod i użyć go, jeśli uznasz to za przydatne.