HC2VPP-156: fix unnumbered sub-interface handling 81/6781/1
authorMarek Gradzki <[email protected]>
Fri, 19 May 2017 08:56:22 +0000 (10:56 +0200)
committerMarek Gradzki <[email protected]>
Fri, 19 May 2017 08:56:22 +0000 (10:56 +0200)
Change-Id: I3c6f4dcd972834543b4fd1193540b5052c787d78
Signed-off-by: Marek Gradzki <[email protected]>
v3po/v3po2vpp/src/main/java/io/fd/hc2vpp/v3po/interfaces/SubInterfaceUnnumberedCustomizer.java
v3po/v3po2vpp/src/test/java/io/fd/hc2vpp/v3po/interfaces/AbstractUnnumberedCustomizerTest.java
v3po/v3po2vpp/src/test/java/io/fd/hc2vpp/v3po/interfaces/InterfaceUnnumberedCustomizerTest.java
v3po/v3po2vpp/src/test/java/io/fd/hc2vpp/v3po/interfaces/SubInterfaceUnnumberedCustomizerTest.java

index ef03f1a..6cec617 100644 (file)
 
 package io.fd.hc2vpp.v3po.interfaces;
 
+import static io.fd.hc2vpp.v3po.util.SubInterfaceUtils.subInterfaceFullNameConfig;
+
 import io.fd.hc2vpp.common.translate.util.NamingContext;
 import io.fd.honeycomb.translate.write.WriteContext;
 import io.fd.honeycomb.translate.write.WriteFailedException;
 import io.fd.vpp.jvpp.core.future.FutureJVppCore;
 import javax.annotation.Nonnull;
-import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.interfaces.rev140508.interfaces.Interface;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.unnumbered.interfaces.rev170510.unnumbered.config.attributes.Unnumbered;
 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
 
@@ -36,7 +37,7 @@ public final class SubInterfaceUnnumberedCustomizer extends AbstractUnnumberedCu
     public void writeCurrentAttributes(@Nonnull final InstanceIdentifier<Unnumbered> id,
                                        @Nonnull final Unnumbered dataAfter,
                                        @Nonnull final WriteContext writeContext) throws WriteFailedException {
-        setUnnumbered(id, id.firstKeyOf(Interface.class).getName(), dataAfter, writeContext);
+        setUnnumbered(id, subInterfaceFullNameConfig(id), dataAfter, writeContext);
     }
 
     @Override
@@ -44,13 +45,13 @@ public final class SubInterfaceUnnumberedCustomizer extends AbstractUnnumberedCu
                                         @Nonnull final Unnumbered dataBefore, @Nonnull final Unnumbered dataAfter,
                                         @Nonnull final WriteContext writeContext)
         throws WriteFailedException {
-        setUnnumbered(id, id.firstKeyOf(Interface.class).getName(), dataAfter, writeContext);
+        setUnnumbered(id, subInterfaceFullNameConfig(id), dataAfter, writeContext);
     }
 
     @Override
     public void deleteCurrentAttributes(@Nonnull final InstanceIdentifier<Unnumbered> id,
                                         @Nonnull final Unnumbered dataBefore,
                                         @Nonnull final WriteContext writeContext) throws WriteFailedException {
-        disableUnnumbered(id, id.firstKeyOf(Interface.class).getName(), dataBefore, writeContext);
+        disableUnnumbered(id, subInterfaceFullNameConfig(id), dataBefore, writeContext);
     }
 }
index 715f487..ac547de 100644 (file)
@@ -25,10 +25,6 @@ import io.fd.hc2vpp.common.translate.util.ByteDataTranslator;
 import io.fd.vpp.jvpp.core.dto.SwInterfaceSetUnnumbered;
 import io.fd.vpp.jvpp.core.dto.SwInterfaceSetUnnumberedReply;
 import org.junit.Test;
-import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.interfaces.rev140508.Interfaces;
-import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.interfaces.rev140508.interfaces.Interface;
-import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.interfaces.rev140508.interfaces.InterfaceKey;
-import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.unnumbered.interfaces.rev170510.InterfaceUnnumberedAugmentation;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.unnumbered.interfaces.rev170510.unnumbered.config.attributes.Unnumbered;
 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.unnumbered.interfaces.rev170510.unnumbered.config.attributes.UnnumberedBuilder;
 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
@@ -41,50 +37,50 @@ abstract class AbstractUnnumberedCustomizerTest extends WriterCustomizerTest imp
     private static final int TARGET_IFC0_ID = 0;
     private static final String TARGET_IFC1_NAME = "eth1";
     private static final int TARGET_IFC1_ID = 1;
-    private static final String UNNUMBERED_IFC_NAME = "eth2";
-    private static final int UNNUMBERED_IFC_ID = 2;
-    private static final InstanceIdentifier<Unnumbered> UNNUMBERED_IFC_IID = InstanceIdentifier.create(Interfaces.class)
-        .child(Interface.class, new InterfaceKey(UNNUMBERED_IFC_NAME))
-        .augmentation(InterfaceUnnumberedAugmentation.class)
-        .child(Unnumbered.class);
+
 
     @Override
     public void setUpTest() {
         customizer = getCustomizer();
         defineMapping(mappingContext, TARGET_IFC0_NAME, TARGET_IFC0_ID, IFC_CTX_NAME);
         defineMapping(mappingContext, TARGET_IFC1_NAME, TARGET_IFC1_ID, IFC_CTX_NAME);
-        defineMapping(mappingContext, UNNUMBERED_IFC_NAME, UNNUMBERED_IFC_ID, IFC_CTX_NAME);
+        defineMapping(mappingContext, getUnnumberedIfcName(), getUnnumberedIfcId(), IFC_CTX_NAME);
         when(api.swInterfaceSetUnnumbered(any())).thenReturn(future(new SwInterfaceSetUnnumberedReply()));
     }
 
+    protected abstract int getUnnumberedIfcId();
+
+    protected abstract String getUnnumberedIfcName();
+
+    protected abstract InstanceIdentifier<Unnumbered> getUnnumberedIfcIId();
+
     protected abstract AbstractUnnumberedCustomizer getCustomizer();
 
     @Test
     public void testWrite() throws Exception {
         final Unnumbered data = new UnnumberedBuilder().setUse(TARGET_IFC0_NAME).build();
-        customizer.writeCurrentAttributes(UNNUMBERED_IFC_IID, data, writeContext);
+        customizer.writeCurrentAttributes(getUnnumberedIfcIId(), data, writeContext);
         verify(api).swInterfaceSetUnnumbered(expectedRequest(true, TARGET_IFC0_ID));
     }
-
     @Test
     public void testUpdate() throws Exception {
         final Unnumbered before = new UnnumberedBuilder().setUse(TARGET_IFC0_NAME).build();
         final Unnumbered after = new UnnumberedBuilder().setUse(TARGET_IFC1_NAME).build();
-        customizer.updateCurrentAttributes(UNNUMBERED_IFC_IID, before, after, writeContext);
+        customizer.updateCurrentAttributes(getUnnumberedIfcIId(), before, after, writeContext);
         verify(api).swInterfaceSetUnnumbered(expectedRequest(true, TARGET_IFC1_ID));
     }
 
     @Test
     public void testDelete() throws Exception {
         final Unnumbered data = new UnnumberedBuilder().setUse(TARGET_IFC0_NAME).build();
-        customizer.deleteCurrentAttributes(UNNUMBERED_IFC_IID, data, writeContext);
+        customizer.deleteCurrentAttributes(getUnnumberedIfcIId(), data, writeContext);
         verify(api).swInterfaceSetUnnumbered(expectedRequest(false, TARGET_IFC0_ID));
     }
 
     private SwInterfaceSetUnnumbered expectedRequest(final boolean isAdd, int swIfIntex) {
         final SwInterfaceSetUnnumbered request = new SwInterfaceSetUnnumbered();
         request.swIfIndex = swIfIntex;
-        request.unnumberedSwIfIndex = UNNUMBERED_IFC_ID;
+        request.unnumberedSwIfIndex = getUnnumberedIfcId();
         request.isAdd = booleanToByte(isAdd);
         return request;
     }
index 8952f43..701cd41 100644 (file)
 package io.fd.hc2vpp.v3po.interfaces;
 
 import io.fd.hc2vpp.common.translate.util.NamingContext;
+import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.interfaces.rev140508.Interfaces;
+import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.interfaces.rev140508.interfaces.Interface;
+import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.interfaces.rev140508.interfaces.InterfaceKey;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.unnumbered.interfaces.rev170510.InterfaceUnnumberedAugmentation;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.unnumbered.interfaces.rev170510.unnumbered.config.attributes.Unnumbered;
+import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
 
 public class InterfaceUnnumberedCustomizerTest extends AbstractUnnumberedCustomizerTest {
+    private static final String UNNUMBERED_IFC_NAME = "eth2";
+    private static final int UNNUMBERED_IFC_ID = 2;
+    private static final InstanceIdentifier<Unnumbered> UNNUMBERED_IFC_IID = InstanceIdentifier.create(Interfaces.class)
+        .child(Interface.class, new InterfaceKey(UNNUMBERED_IFC_NAME))
+        .augmentation(InterfaceUnnumberedAugmentation.class)
+        .child(Unnumbered.class);
+
+    @Override
+    protected int getUnnumberedIfcId() {
+        return UNNUMBERED_IFC_ID;
+    }
+
+    @Override
+    protected String getUnnumberedIfcName() {
+        return UNNUMBERED_IFC_NAME;
+    }
+
+    @Override
+    protected InstanceIdentifier<Unnumbered> getUnnumberedIfcIId() {
+        return UNNUMBERED_IFC_IID;
+    }
 
     @Override
     protected AbstractUnnumberedCustomizer getCustomizer() {
index 040444f..8238072 100644 (file)
 package io.fd.hc2vpp.v3po.interfaces;
 
 import io.fd.hc2vpp.common.translate.util.NamingContext;
+import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.interfaces.rev140508.Interfaces;
+import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.interfaces.rev140508.interfaces.Interface;
+import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.interfaces.rev140508.interfaces.InterfaceKey;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.unnumbered.interfaces.rev170510.SubinterfaceUnnumberedAugmentation;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.unnumbered.interfaces.rev170510.unnumbered.config.attributes.Unnumbered;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vpp.vlan.rev170509.SubinterfaceAugmentation;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vpp.vlan.rev170509.interfaces._interface.SubInterfaces;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vpp.vlan.rev170509.interfaces._interface.sub.interfaces.SubInterface;
+import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vpp.vlan.rev170509.interfaces._interface.sub.interfaces.SubInterfaceKey;
+import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
 
 public class SubInterfaceUnnumberedCustomizerTest extends AbstractUnnumberedCustomizerTest {
+    private static final String PARENT_IFC_NAME = "eth2";
+    private static final String UNNUMBERED_IFC_NAME = "eth2.123";
+    private static final int UNNUMBERED_IFC_ID = 2;
+    private static final long UNNUMBERED_IFC_NUMBER = 123;
+    private static final InstanceIdentifier<Unnumbered> UNNUMBERED_IFC_IID = InstanceIdentifier.create(Interfaces.class)
+        .child(Interface.class, new InterfaceKey(PARENT_IFC_NAME))
+        .augmentation(SubinterfaceAugmentation.class).child(SubInterfaces.class)
+        .child(SubInterface.class, new SubInterfaceKey(UNNUMBERED_IFC_NUMBER)).augmentation(
+            SubinterfaceUnnumberedAugmentation.class).child(Unnumbered.class);
+
+    @Override
+    protected int getUnnumberedIfcId() {
+        return UNNUMBERED_IFC_ID;
+    }
+
+    @Override
+    protected String getUnnumberedIfcName() {
+        return UNNUMBERED_IFC_NAME;
+    }
+
+    @Override
+    protected InstanceIdentifier<Unnumbered> getUnnumberedIfcIId() {
+        return UNNUMBERED_IFC_IID;
+    }
 
     @Override
     protected AbstractUnnumberedCustomizer getCustomizer() {