Невозможно покрыть функцию вызовом метода org.openide.nodes.Node с помощью EasyMock
Недавно я столкнулся со странной проблемой с EasyMock. Вот класс, который я тестирую
package com.test.junits;
import org.openide.nodes.Node;
public class IsRoot {
public boolean isRoot(Node node) {
Node parentNode = node.getParentNode();
return (parentNode == null);
}
}
А вот и класс Junit
package com.test.junits
import static org.junit.Assert.assertNotNull;
import org.easymock.EasyMock;
import org.junit.Before;
import org.junit.Test;
import org.openide.nodes.Node;
public class IsRootTest {
private IsRoot isroot;
private Node node;
@Before
public void setUp() {
isroot = new IsRoot();
node = EasyMock.createMock(Node.class);
}
@Test
public void gettingExpectationsForGetParentFromNode() {
Node node = EasyMock.createMock(Node.class);
Node parentNode = EasyMock.createMock(Node.class);
EasyMock.expect(node.getParentNode()).andReturn(parentNode);
EasyMock.replay(node);
isroot.isRoot(node);
EasyMock.verify(node);
}
Когда я пытаюсь запустить его, я получаю следующее исключение (с maven и eclipse)
java.lang.IllegalStateException: no last call on a mock available
at org.easymock.EasyMock.getControlForLastCall(EasyMock.java:521)
at org.easymock.EasyMock.expect(EasyMock.java:499)
at com.test.junits.IsRootTest.gettingExpectationsForGetParentFromNode(IsRootTest.java:47)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at org.junit.internal.runners.TestMethodRunner.executeMethodBody(TestMethodRunner.java:99)
at org.junit.internal.runners.TestMethodRunner.runUnprotected(TestMethodRunner.java:81)
at org.junit.internal.runners.BeforeAndAfterRunner.runProtected(BeforeAndAfterRunner.java:34)
at org.junit.internal.runners.TestMethodRunner.runMethod(TestMethodRunner.java:75)
at org.junit.internal.runners.TestMethodRunner.run(TestMethodRunner.java:45)
at org.junit.internal.runners.TestClassMethodsRunner.invokeTestMethod(TestClassMethodsRunner.java:71)
at org.junit.internal.runners.TestClassMethodsRunner.run(TestClassMethodsRunner.java:35)
at org.junit.internal.runners.TestClassRunner$1.runUnprotected(TestClassRunner.java:42)
at org.junit.internal.runners.BeforeAndAfterRunner.runProtected(BeforeAndAfterRunner.java:34)
at org.junit.internal.runners.TestClassRunner.run(TestClassRunner.java:52)
at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:50)
at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:467)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390)
at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197)
Я что-то здесь упускаю? Любая помощь будет оценена.
1 ответ
Вероятно, это связано с тем, что у вас есть локальное поле с именем node
и переменная класса называется node
оба из которых являются Node
классы и оба из которых являются издевательствами.
Я бы снял тест местный node
или переименуйте его, если вы действительно хотите использовать локальный тестовый макет node
РЕДАКТИРОВАТЬ
Мой предыдущий ответ был неправильным, и действительно должен был быть комментарием. Скрытые объекты не вызывали никаких проблем. (Хотя я все еще думаю, что они должны были быть удалены / переименованы)
Проблема в том, что метод, который вы пытаетесь final
и как таковой, не может быть осмеяно.
Когда EasyMock имитирует метод / классы, он делает это, расширяя и переопределяя их. Таким образом, финальные классы и финальные методы не могут быть смоделированы с EasyMock, поскольку они не могут быть переопределены.
Призыв к getParentNode()
метод не проверяется и как таковой не регистрируется во время состояния записи в ожидании вызова.