Невозможно покрыть функцию вызовом метода 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() метод не проверяется и как таковой не регистрируется во время состояния записи в ожидании вызова.

Другие вопросы по тегам