summaryrefslogtreecommitdiffstats
path: root/lisp/lisp2vpp/src/test/java/io
diff options
context:
space:
mode:
authorJan Srnicek <jsrnicek@cisco.com>2017-01-12 09:59:30 +0100
committerMarek Gradzki <mgradzki@cisco.com>2017-01-12 09:23:36 +0000
commitfd7cd756fe7e13e0bddde7be8ef7afecd2ba9fb7 (patch)
tree762e9c569f20a3e04fc615b735f0069802e2a233 /lisp/lisp2vpp/src/test/java/io
parent43a552b675e1c1a8f8cc618f91289cbee8be0ee2 (diff)
HONEYCOMB-296 - Reference checking in Locator set
Reference must be checked while removing to prevent dead references Change-Id: I37cb426f73a3fa64d4e6795062d8d7affc0cbb2b Signed-off-by: Jan Srnicek <jsrnicek@cisco.com>
Diffstat (limited to 'lisp/lisp2vpp/src/test/java/io')
-rwxr-xr-xlisp/lisp2vpp/src/test/java/io/fd/hc2vpp/lisp/translate/write/LocatorSetCustomizerTest.java89
1 files changed, 86 insertions, 3 deletions
diff --git a/lisp/lisp2vpp/src/test/java/io/fd/hc2vpp/lisp/translate/write/LocatorSetCustomizerTest.java b/lisp/lisp2vpp/src/test/java/io/fd/hc2vpp/lisp/translate/write/LocatorSetCustomizerTest.java
index b29e1a018..734dddd6c 100755
--- a/lisp/lisp2vpp/src/test/java/io/fd/hc2vpp/lisp/translate/write/LocatorSetCustomizerTest.java
+++ b/lisp/lisp2vpp/src/test/java/io/fd/hc2vpp/lisp/translate/write/LocatorSetCustomizerTest.java
@@ -40,6 +40,14 @@ import java.util.Arrays;
import java.util.concurrent.ExecutionException;
import org.junit.Test;
import org.mockito.ArgumentCaptor;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.lisp.rev161214.Lisp;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.lisp.rev161214.dp.subtable.grouping.LocalMappingsBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.lisp.rev161214.dp.subtable.grouping.local.mappings.LocalMappingBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.lisp.rev161214.eid.table.grouping.EidTable;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.lisp.rev161214.eid.table.grouping.EidTableBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.lisp.rev161214.eid.table.grouping.eid.table.VniTableBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.lisp.rev161214.eid.table.grouping.eid.table.vni.table.VrfSubtableBuilder;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.lisp.rev161214.lisp.feature.data.grouping.LispFeatureData;
import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.lisp.rev161214.locator.sets.grouping.LocatorSets;
import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.lisp.rev161214.locator.sets.grouping.locator.sets.LocatorSet;
import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.lisp.rev161214.locator.sets.grouping.locator.sets.LocatorSetBuilder;
@@ -49,6 +57,15 @@ import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
public class LocatorSetCustomizerTest extends WriterCustomizerTest {
+ private static final InstanceIdentifier<EidTable>
+ EID_TABLE_ID = InstanceIdentifier.create(Lisp.class)
+ .child(LispFeatureData.class)
+ .child(EidTable.class);
+
+ private static final LocatorSet LOCATOR_SET_TO_DELETE = new LocatorSetBuilder()
+ .setName("Locator")
+ .build();
+
private LocatorSetCustomizer customizer;
@Override
@@ -126,10 +143,25 @@ public class LocatorSetCustomizerTest extends WriterCustomizerTest {
@Test
public void testDeleteCurrentAttributes() throws InterruptedException, ExecutionException, WriteFailedException {
- LocatorSet locatorSet = new LocatorSetBuilder()
- .setName("Locator")
- .build();
+ when(writeContext.readAfter(EID_TABLE_ID)).thenReturn(Optional.absent());
+ verifySuccessfullDelete(LOCATOR_SET_TO_DELETE);
+ }
+
+ @Test
+ public void testDeleteCurrentAttributesWithoutLocalMappingContainer()
+ throws InterruptedException, ExecutionException, WriteFailedException {
+ when(writeContext.readAfter(EID_TABLE_ID)).thenReturn(eidTableDataWithoutLocalMappingContainer());
+ verifySuccessfullDelete(LOCATOR_SET_TO_DELETE);
+ }
+
+ @Test
+ public void testDeleteCurrentAttributesWithoutLocalMappingValues()
+ throws InterruptedException, ExecutionException, WriteFailedException {
+ when(writeContext.readAfter(EID_TABLE_ID)).thenReturn(eidTableDataWithoutLocalMappingValues());
+ verifySuccessfullDelete(LOCATOR_SET_TO_DELETE);
+ }
+ private void verifySuccessfullDelete(final LocatorSet locatorSet) throws WriteFailedException {
ArgumentCaptor<LispAddDelLocatorSet> locatorSetCaptor = ArgumentCaptor.forClass(LispAddDelLocatorSet.class);
when(api.lispAddDelLocatorSet(any(LispAddDelLocatorSet.class)))
@@ -145,4 +177,55 @@ public class LocatorSetCustomizerTest extends WriterCustomizerTest {
assertEquals("Locator", new String(request.locatorSetName));
assertEquals(0, request.isAdd);
}
+
+ @Test
+ public void testDeleteReferenced() throws InterruptedException, ExecutionException, WriteFailedException {
+ when(writeContext.readAfter(EID_TABLE_ID))
+ .thenReturn(eidTableData());
+
+ ArgumentCaptor<LispAddDelLocatorSet> locatorSetCaptor = ArgumentCaptor.forClass(LispAddDelLocatorSet.class);
+
+ when(api.lispAddDelLocatorSet(any(LispAddDelLocatorSet.class)))
+ .thenReturn(future(new LispAddDelLocatorSetReply()));
+
+ try {
+ customizer.deleteCurrentAttributes(null, LOCATOR_SET_TO_DELETE, writeContext);
+ } catch (IllegalStateException e) {
+ verify(api, times(0)).lispAddDelLocatorSet(locatorSetCaptor.capture());
+ return;
+ }
+ fail("testDeleteReferenced should have failed");
+ }
+
+ private static Optional<EidTable> eidTableData() {
+ return Optional.of(new EidTableBuilder()
+ .setVniTable(
+ Arrays.asList(new VniTableBuilder()
+ .setVrfSubtable(new VrfSubtableBuilder()
+ .setLocalMappings(new LocalMappingsBuilder()
+ .setLocalMapping(Arrays.asList(
+ new LocalMappingBuilder().setLocatorSet("Locator")
+ .build(),
+ new LocalMappingBuilder()
+ .setLocatorSet("OtherLocatorSet").build()
+ )).build()).build()).build())).build());
+ }
+
+ private static Optional<EidTable> eidTableDataWithoutLocalMappingValues() {
+ return Optional.of(new EidTableBuilder()
+ .setVniTable(
+ Arrays.asList(new VniTableBuilder()
+ .setVrfSubtable(new VrfSubtableBuilder()
+ .setLocalMappings(new LocalMappingsBuilder().build()).build()).build()))
+ .build());
+ }
+
+ private static Optional<EidTable> eidTableDataWithoutLocalMappingContainer() {
+ return Optional.of(new EidTableBuilder()
+ .setVniTable(
+ Arrays.asList(new VniTableBuilder().setVrfSubtable(new VrfSubtableBuilder().build()).build()))
+ .build());
+ }
+
+
}