1 package io.fd.honeycomb.lisp.translate.read.dump.executor;
4 import static org.junit.Assert.assertEquals;
5 import static org.junit.Assert.assertNotNull;
6 import static org.junit.Assert.assertTrue;
7 import static org.junit.Assert.fail;
8 import static org.mockito.Mockito.any;
9 import static org.mockito.Mockito.times;
10 import static org.mockito.Mockito.verify;
12 import com.google.common.collect.ImmutableList;
13 import io.fd.honeycomb.translate.read.ReadFailedException;
14 import io.fd.honeycomb.translate.util.read.cache.EntityDumpExecutor;
15 import io.fd.honeycomb.vpp.test.read.JvppDumpExecutorTest;
16 import io.fd.vpp.jvpp.core.dto.LispLocatorSetDetails;
17 import io.fd.vpp.jvpp.core.dto.LispLocatorSetDetailsReplyDump;
18 import io.fd.vpp.jvpp.core.dto.LispLocatorSetDump;
19 import java.nio.charset.StandardCharsets;
20 import java.util.concurrent.TimeoutException;
21 import org.junit.Before;
22 import org.junit.Test;
23 import org.mockito.ArgumentCaptor;
24 import org.mockito.Captor;
25 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.lisp.rev160520.locator.sets.grouping.locator.sets.LocatorSet;
26 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
29 public class LocatorSetsDumpExecutorTest extends JvppDumpExecutorTest<LocatorSetsDumpExecutor> {
31 public static final byte[] LOCATOR_SET_NAME_BYTES = "loc-set".getBytes(StandardCharsets.UTF_8);
33 private LispLocatorSetDetailsReplyDump validDump;
36 private ArgumentCaptor<LispLocatorSetDump> requestCaptor;
38 private InstanceIdentifier identifier;
42 identifier = InstanceIdentifier.create(LocatorSet.class);
43 validDump = new LispLocatorSetDetailsReplyDump();
44 LispLocatorSetDetails detail = new LispLocatorSetDetails();
46 detail.lsName = LOCATOR_SET_NAME_BYTES;
49 validDump.lispLocatorSetDetails = ImmutableList.of(detail);
53 public void testExecuteDumpTimeout() throws Exception {
54 doThrowTimeoutExceptionWhen().lispLocatorSetDump(any());
56 getExecutor().executeDump(identifier, EntityDumpExecutor.NO_PARAMS);
57 } catch (Exception e) {
58 assertTrue(e instanceof ReadFailedException);
59 assertTrue(e.getCause() instanceof TimeoutException);
62 fail("Test should have thrown exception");
65 @Test(expected = ReadFailedException.class)
66 public void testExecuteDumpHalted() throws ReadFailedException {
67 doThrowFailExceptionWhen().lispLocatorSetDump(any());
68 getExecutor().executeDump(identifier, EntityDumpExecutor.NO_PARAMS);
72 public void testExecuteDump() throws ReadFailedException {
73 doReturnResponseWhen(validDump).lispLocatorSetDump(any());
75 final LispLocatorSetDetailsReplyDump replyDump =
76 getExecutor().executeDump(identifier, EntityDumpExecutor.NO_PARAMS);
77 verify(api, times(1)).lispLocatorSetDump(requestCaptor.capture());
79 final LispLocatorSetDump request = requestCaptor.getValue();
81 assertNotNull(request);
82 assertEquals(1, request.filter);
84 assertNotNull(replyDump);
85 assertNotNull(replyDump.lispLocatorSetDetails);
86 assertEquals(1, replyDump.lispLocatorSetDetails.size());
87 final LispLocatorSetDetails detail = replyDump.lispLocatorSetDetails.get(0);
89 assertNotNull(detail);
90 assertEquals(4, detail.context);
91 assertEquals(2, detail.lsIndex);
92 assertEquals(LOCATOR_SET_NAME_BYTES, detail.lsName);
96 protected LocatorSetsDumpExecutor initExecutor() {
97 return new LocatorSetsDumpExecutor(api);