У меня есть главный класс вроде: -
class Main
{
String str = "";
protected String getStr(JavaRDD<String> obj)
{
return "Main";
}
}
class Child extends Main
{
String str = "";
protected String getStr(Dataset<Row> records )
{
return "Child";
}
}
//My test class :-
class mainTest extends Child
{
Child child;
@Test
public void testGetStr()
{
child = Mockito.mock(Child .class);
Mockito.when(child.getStr(anyObject())).thenCallRealMethod();//Compilation Error
}
}
Я получаю следующую ошибку:
The method getStr(Dataset<Row>) is ambiguous for the type Child
Пожалуйста, дайте мне знать решение для этого, поскольку я не уполномочен изменять классы Основной и Ребенок. Когда я издеваюсь над дочерний класс, getStr() не вызывается.




Похоже, что Child на самом деле не отменяет метод getStrMain, потому что сигнатура метода отличается.
Следовательно, компилятор не может сказать, какой метод действительно следует вызывать при вызове Child.getStr(anyObject()). Это должен быть getStr(Dataset<Row> records ) или должен быть getStr(JavaRDD<String> obj)? Методы anyObject предоставляют объект, соответствующий классу любой.
Я предлагаю либо переименовать один из методов, либо использовать any(Dataset.class), который скажет компилятору использовать метод Child, например:
Mockito.when(child.getStr(any(Dataset.class))).thenCallRealMethod();
не могли бы вы опубликовать версию с любым (Dataset.class)?
Mockito.any (Child.class) .getStr (anyObject ()). ThenCallRealMet hod ();
О, я вижу. Он должен заменить метод anyObject (). Я отредактирую свой пост, включив в него всю строку.
возможно, использовать частичную имитацию. тогда вы можете издеваться, но для этого конкретного метода использование может вызвать реальный метод.