import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull;
+import static org.junit.Assert.assertThrows;
import static org.junit.Assert.assertTrue;
import static org.mockito.ArgumentMatchers.any;
import static org.mockito.Mockito.doReturn;
+import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.verify;
+import static org.mockito.Mockito.when;
import com.google.common.util.concurrent.Futures;
import java.util.Collection;
+import java.util.concurrent.ExecutionException;
import org.junit.AfterClass;
import org.junit.Before;
import org.junit.BeforeClass;
import org.mockito.ArgumentCaptor;
import org.mockito.Mock;
import org.mockito.MockitoAnnotations;
-import org.opendaylight.binding.runtime.spi.BindingRuntimeHelpers;
+import org.opendaylight.mdsal.binding.runtime.spi.BindingRuntimeHelpers;
import org.opendaylight.mdsal.dom.api.DOMRpcAvailabilityListener;
import org.opendaylight.mdsal.dom.api.DOMRpcIdentifier;
import org.opendaylight.mdsal.dom.api.DOMRpcResult;
import org.opendaylight.netconf.api.NetconfMessage;
import org.opendaylight.netconf.api.xml.XmlUtil;
+import org.opendaylight.netconf.sal.connect.api.MessageTransformer;
import org.opendaylight.netconf.sal.connect.api.RemoteDeviceCommunicator;
import org.opendaylight.netconf.sal.connect.netconf.AbstractBaseSchemasTest;
import org.opendaylight.netconf.sal.connect.netconf.schema.mapping.NetconfMessageTransformer;
import org.opendaylight.yangtools.yang.data.impl.schema.Builders;
import org.opendaylight.yangtools.yang.model.api.EffectiveModelContext;
import org.opendaylight.yangtools.yang.model.api.RpcDefinition;
-import org.opendaylight.yangtools.yang.model.api.SchemaPath;
import org.w3c.dom.Node;
public class NetconfDeviceRpcTest extends AbstractBaseSchemasTest {
private RemoteDeviceCommunicator<NetconfMessage> communicator;
private NetconfDeviceRpc rpc;
- private SchemaPath path;
+ private QName type;
private DOMRpcResult expectedReply;
@BeforeClass
.when(communicator).sendRequest(any(NetconfMessage.class), any(QName.class));
rpc = new NetconfDeviceRpc(SCHEMA_CONTEXT, communicator, transformer);
- path = SchemaPath
- .create(true, QName.create("urn:ietf:params:xml:ns:netconf:base:1.0", "2011-06-01", "get-config"));
- expectedReply = transformer.toRpcResult(reply, path);
+ type = QName.create("urn:ietf:params:xml:ns:netconf:base:1.0", "2011-06-01", "get-config");
+ expectedReply = transformer.toRpcResult(reply, type);
+ }
+
+ @Test
+ public void testDeadlock() throws Exception {
+ // when rpc is successful, but transformer fails for some reason
+ final MessageTransformer<NetconfMessage> failingTransformer = mock(MessageTransformer.class);
+ final RemoteDeviceCommunicator<NetconfMessage> communicatorMock = mock(RemoteDeviceCommunicator.class);
+ final NetconfMessage msg = null;
+ final RpcResult<NetconfMessage> result = RpcResultBuilder.success(msg).build();
+ when(communicatorMock.sendRequest(any(), any())).thenReturn(Futures.immediateFuture(result));
+ when(failingTransformer.toRpcResult(any(), any())).thenThrow(new RuntimeException("FAIL"));
+ final NetconfDeviceRpc failingRpc = new NetconfDeviceRpc(SCHEMA_CONTEXT, communicatorMock, failingTransformer);
+ assertThrows(ExecutionException.class, () -> failingRpc.invokeRpc(type, mock(ContainerNode.class)).get());
+ assertThrows(ExecutionException.class, () -> failingRpc.invokeRpc(type, null).get());
}
@Test
public void testInvokeRpc() throws Exception {
ContainerNode input = createNode("urn:ietf:params:xml:ns:netconf:base:1.0", "2011-06-01", "filter");
- final DOMRpcResult result = rpc.invokeRpc(path, input).get();
+ final DOMRpcResult result = rpc.invokeRpc(type, input).get();
assertEquals(expectedReply.getResult().getIdentifier(), result.getResult().getIdentifier());
assertEquals(resolveNode(expectedReply), resolveNode(result));
}
final Collection<? extends RpcDefinition> operations = SCHEMA_CONTEXT.getOperations();
assertEquals(argValue.size(), operations.size());
for (RpcDefinition operation : operations) {
- final DOMRpcIdentifier domRpcIdentifier = DOMRpcIdentifier.create(operation.getPath());
+ final DOMRpcIdentifier domRpcIdentifier = DOMRpcIdentifier.create(operation.getQName());
assertTrue(argValue.contains(domRpcIdentifier));
}