diff options
author | Marek Gradzki <mgradzki@cisco.com> | 2017-02-27 09:54:18 +0100 |
---|---|---|
committer | Marek Gradzki <mgradzki@cisco.com> | 2017-02-27 12:07:31 +0100 |
commit | 691dfba001163ebad7d43f287bf9e6ffe6bf451d (patch) | |
tree | 1b6757c3b79742f7e8c9542d0db7b82623dc6ba8 /dhcp/dhcp-impl/src/test/java/io/fd/hc2vpp/dhcp/read/DhcpRelayCustomizerTest.java | |
parent | 06e02d8840109eaa8a97946529a37003dd9e6059 (diff) |
HC2VPP-85: DHCP relay initializing reader
Change-Id: Iab91aab6103b9d837a5a0c73e2836807f24d1f14
Signed-off-by: Marek Gradzki <mgradzki@cisco.com>
Diffstat (limited to 'dhcp/dhcp-impl/src/test/java/io/fd/hc2vpp/dhcp/read/DhcpRelayCustomizerTest.java')
-rw-r--r-- | dhcp/dhcp-impl/src/test/java/io/fd/hc2vpp/dhcp/read/DhcpRelayCustomizerTest.java | 120 |
1 files changed, 120 insertions, 0 deletions
diff --git a/dhcp/dhcp-impl/src/test/java/io/fd/hc2vpp/dhcp/read/DhcpRelayCustomizerTest.java b/dhcp/dhcp-impl/src/test/java/io/fd/hc2vpp/dhcp/read/DhcpRelayCustomizerTest.java new file mode 100644 index 000000000..79a1f44c8 --- /dev/null +++ b/dhcp/dhcp-impl/src/test/java/io/fd/hc2vpp/dhcp/read/DhcpRelayCustomizerTest.java @@ -0,0 +1,120 @@ +/* + * Copyright (c) 2017 Cisco and/or its affiliates. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at: + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package io.fd.hc2vpp.dhcp.read; + +import static org.hamcrest.MatcherAssert.assertThat; +import static org.hamcrest.Matchers.containsInAnyOrder; +import static org.junit.Assert.assertArrayEquals; +import static org.junit.Assert.assertEquals; +import static org.mockito.Mockito.when; + +import io.fd.hc2vpp.common.test.read.InitializingListReaderCustomizerTest; +import io.fd.honeycomb.translate.read.ReadFailedException; +import io.fd.honeycomb.translate.spi.read.ReaderCustomizer; +import io.fd.vpp.jvpp.core.dto.DhcpProxyDetails; +import io.fd.vpp.jvpp.core.dto.DhcpProxyDetailsReplyDump; +import io.fd.vpp.jvpp.core.dto.DhcpProxyDump; +import java.util.List; +import org.junit.Test; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vpp.dhcp.rev170315.Dhcp; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vpp.dhcp.rev170315.Ipv4; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vpp.dhcp.rev170315.Ipv6; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vpp.dhcp.rev170315.dhcp.attributes.Relays; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vpp.dhcp.rev170315.dhcp.attributes.RelaysBuilder; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vpp.dhcp.rev170315.dhcp.attributes.relays.Relay; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vpp.dhcp.rev170315.dhcp.attributes.relays.RelayBuilder; +import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.vpp.dhcp.rev170315.dhcp.attributes.relays.RelayKey; +import org.opendaylight.yangtools.yang.binding.InstanceIdentifier; +import org.opendaylight.yangtools.yang.binding.KeyedInstanceIdentifier; + +public class DhcpRelayCustomizerTest extends InitializingListReaderCustomizerTest<Relay, RelayKey, RelayBuilder> { + public DhcpRelayCustomizerTest() { + super(Relay.class, RelaysBuilder.class); + } + + private static InstanceIdentifier<Relays> RELAYS = InstanceIdentifier.create(Dhcp.class).child(Relays.class); + + private KeyedInstanceIdentifier<Relay, RelayKey> IP4_IID = RELAYS.child(Relay.class, new RelayKey(Ipv4.class, 123L)); + private KeyedInstanceIdentifier<Relay, RelayKey> IP6_IID = RELAYS.child(Relay.class, new RelayKey(Ipv6.class, 321L)); + + @Override + protected ReaderCustomizer<Relay, RelayBuilder> initCustomizer() { + return new DhcpRelayCustomizer(api); + } + + @Override + protected void setUp() throws Exception { + final DhcpProxyDetailsReplyDump ip4 = new DhcpProxyDetailsReplyDump(); + final DhcpProxyDetails ip4Proxy = new DhcpProxyDetails(); + ip4Proxy.rxVrfId = 123; + ip4Proxy.dhcpSrcAddress = new byte[]{1,2,3,4}; + ip4Proxy.serverVrfId = 11; + ip4Proxy.dhcpServer = new byte[]{8,8,8,8}; + ip4.dhcpProxyDetails.add(ip4Proxy); + when(api.dhcpProxyDump(new DhcpProxyDump())).thenReturn(future(ip4)); + + final DhcpProxyDetailsReplyDump ip6 = new DhcpProxyDetailsReplyDump(); + final DhcpProxyDetails ip6Proxy = new DhcpProxyDetails(); + ip6Proxy.rxVrfId = 321; + // 2001:0db8:0a0b:12f0:0000:0000:0000:0001 + ip6Proxy.dhcpSrcAddress = new byte[] {0x20, 0x01, 0x0d, (byte) 0xb8, 0x0a, 0x0b, 0x12, (byte) 0xf0, 0 ,0 ,0 ,0 ,0 ,0 ,0 ,0x01}; + ip6Proxy.serverVrfId = 22; + ip6Proxy.isIpv6 = 1; + // 2001:0db8:0a0b:12f0:0000:0000:0000:0002 + ip6Proxy.dhcpServer = new byte[] {0x20, 0x01, 0x0d, (byte) 0xb8, 0x0a, 0x0b, 0x12, (byte) 0xf0, 0 ,0 ,0 ,0 ,0 ,0 ,0 ,0x02}; + + final DhcpProxyDump ip6Dump = new DhcpProxyDump(); + ip6Dump.isIp6 = 1; + ip6.dhcpProxyDetails.add(ip6Proxy); + when(api.dhcpProxyDump(ip6Dump)).thenReturn(future(ip6)); + } + + @Test + public void testGetAllIds() throws ReadFailedException { + final List<RelayKey> allIds = getCustomizer().getAllIds(RELAYS.child(Relay.class), ctx); + assertEquals(2, allIds.size()); + assertThat(allIds, containsInAnyOrder(IP4_IID.getKey(), IP6_IID.getKey())); + } + + @Test + public void testReadIp4() throws ReadFailedException { + final RelayBuilder builder = new RelayBuilder(); + getCustomizer().readCurrentAttributes(IP4_IID, builder, ctx); + assertEquals(IP4_IID.getKey().getAddressType(), builder.getAddressType()); + assertEquals(IP4_IID.getKey().getRxVrfId(), builder.getRxVrfId()); + assertEquals(11L, builder.getServerVrfId().longValue()); + assertArrayEquals("1.2.3.4".toCharArray(), builder.getGatewayAddress().getValue()); + assertArrayEquals("8.8.8.8".toCharArray(), builder.getServerAddress().getValue()); + } + + @Test + public void testReadIp6() throws ReadFailedException { + final RelayBuilder builder = new RelayBuilder(); + getCustomizer().readCurrentAttributes(IP6_IID, builder, ctx); + assertEquals(IP6_IID.getKey().getAddressType(), builder.getAddressType()); + assertEquals(IP6_IID.getKey().getRxVrfId(), builder.getRxVrfId()); + assertEquals(22L, builder.getServerVrfId().longValue()); + assertArrayEquals("2001:db8:a0b:12f0::1".toCharArray(), builder.getGatewayAddress().getValue()); + assertArrayEquals("2001:db8:a0b:12f0::2".toCharArray(), builder.getServerAddress().getValue()); + } + + @Test + public void testInit() { + final Relay data = new RelayBuilder().build(); + invokeInitTest(IP4_IID, data, IP4_IID, data); + } +}
\ No newline at end of file |