Używam EasyMock do tworzenia makiety, która jest jednym z prywatnych parametrów (bez ustawiania) w testowanej klasie. Próbowałem użyć odbicia - ale to nie działa poprawnie.Jak wstrzyknąć EasyMock do testowanego prywatnego pola klasy
public class TestedClassTest{
@Test
public void test(){
TestedClass instance = new TestedClass();
MockedClass mocked = EasyMock.createMock(MockedClass.class);
Data data = new Data();
//Void setter
DataType dataType = (myDataType.DataType) EasyMock.anyObject();
mocked.setDataType(dataType);
EasyMock.expectLastCall();
//expect
EasyMock.expect(mocked.getData()).andReturn(data);
EasyMock.replay(mocked);
Field field = instance.getClass().getDeclaredField("mockedClass")
field.setAccessible(true);
field.set(instance, mocked);
//run tested method
instance.someAction();
EasyMock.verify(mocked);
}
}
Im uzyskiwanie FAILED info:
Unexpected method call MockedClass.setDataType([email protected]):
MockedClass.getData(): expected: 1, actual: 0
junit.framework.AssertionFailedError:
Unexpected method call MockedClass.setDataType([email protected]):
MockedClass.getData(): expected: 1, actual: 0
Im na pewno metoda ta jest wypalana na "MockedClass" obiektu w trakcie badanego "instance.someAction()"
Jak rozwiązać ten problem?
Zmieniano - Odpowiedź: po skorygowaniu podwoiła replay.mocked()
znalazłem (tak prosty!), Że jeden więcej void metoda powinna zostać uznana za pomocą EasyMock.expectLastCall()
Poprawiono i nadal ma podobny problem – Marcin
r Czy błąd jest taki sam? – hvgotcodes
edytowany kod i błąd, thx! – Marcin