blob: fef26ed27c34d8c94eb5739375ec183e54e83563 [file] [log] [blame]
/*
* Copyright 2014-present Open Networking Laboratory
*
* 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 org.onlab.packet;
import org.apache.commons.lang3.StringUtils;
import org.junit.Before;
import org.junit.BeforeClass;
import org.junit.Test;
import java.nio.ByteBuffer;
import static org.hamcrest.Matchers.is;
import static org.junit.Assert.*;
import static org.onlab.packet.IPv6.*;
/**
* Tests for class {@link IPv6}.
*/
public class IPv6Test {
private static final byte[] SOURCE_ADDRESS = {
(byte) 0x20, (byte) 0x01, (byte) 0x0f, (byte) 0x18, (byte) 0x01, (byte) 0x13, (byte) 0x02, (byte) 0x15,
(byte) 0xca, (byte) 0x2a, (byte) 0x14, (byte) 0xff, (byte) 0xfe, (byte) 0x35, (byte) 0x26, (byte) 0xce
};
private static final byte[] DESTINATION_ADDRESS = {
(byte) 0x20, (byte) 0x01, (byte) 0x0f, (byte) 0x18, (byte) 0x01, (byte) 0x13, (byte) 0x02, (byte) 0x15,
(byte) 0xe6, (byte) 0xce, (byte) 0x8f, (byte) 0xff, (byte) 0xfe, (byte) 0x54, (byte) 0x37, (byte) 0xc8
};
private static final byte[] SOLICITATION_NODE_ADDRESS = {
(byte) 0xff, (byte) 0x02, (byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x00,
(byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x01, (byte) 0xff, (byte) 0x54, (byte) 0x37, (byte) 0xc8
};
private static final byte[] MULTICAST_ADDRESS = {
(byte) 0x33, (byte) 0x33, (byte) 0xfe, (byte) 0x54, (byte) 0x37, (byte) 0xc8
};
private static final byte[] LINK_LOCAL_ADDRESS_1 = {
(byte) 0xfe, (byte) 0x80, (byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x00,
(byte) 0x50, (byte) 0x74, (byte) 0xf2, (byte) 0xff, (byte) 0xfe, (byte) 0xb1, (byte) 0xa8, (byte) 0x7f
};
private static final byte[] MAC_ADDRESS_1 = {
(byte) 0x52, (byte) 0x74, (byte) 0xf2, (byte) 0xb1, (byte) 0xa8, (byte) 0x7f
};
private static final byte[] LINK_LOCAL_ADDRESS_2 = {
(byte) 0xfe, (byte) 0x80, (byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x00,
(byte) 0x02, (byte) 0x0c, (byte) 0x29, (byte) 0xff, (byte) 0xfe, (byte) 0x8f, (byte) 0x99, (byte) 0xd2
};
private static final byte[] MAC_ADDRESS_2 = {
(byte) 0x00, (byte) 0x0c, (byte) 0x29, (byte) 0x8f, (byte) 0x99, (byte) 0xd2
};
private static Data data;
private static UDP udp;
private static byte[] bytePacket;
private Deserializer<IPv6> deserializer;
@BeforeClass
public static void setUpBeforeClass() throws Exception {
data = new Data();
data.setData("testSerialize".getBytes());
udp = new UDP();
udp.setPayload(data);
byte[] bytePayload = udp.serialize();
byte[] byteHeader = {
(byte) 0x69, (byte) 0x31, (byte) 0x35, (byte) 0x79,
(byte) (bytePayload.length >> 8 & 0xff), (byte) (bytePayload.length & 0xff),
(byte) 0x11, (byte) 0x20,
(byte) 0x20, (byte) 0x01, (byte) 0x0f, (byte) 0x18, (byte) 0x01, (byte) 0x13, (byte) 0x02, (byte) 0x15,
(byte) 0xca, (byte) 0x2a, (byte) 0x14, (byte) 0xff, (byte) 0xfe, (byte) 0x35, (byte) 0x26, (byte) 0xce,
(byte) 0x20, (byte) 0x01, (byte) 0x0f, (byte) 0x18, (byte) 0x01, (byte) 0x13, (byte) 0x02, (byte) 0x15,
(byte) 0xe6, (byte) 0xce, (byte) 0x8f, (byte) 0xff, (byte) 0xfe, (byte) 0x54, (byte) 0x37, (byte) 0xc8,
};
bytePacket = new byte[byteHeader.length + bytePayload.length];
System.arraycopy(byteHeader, 0, bytePacket, 0, byteHeader.length);
System.arraycopy(bytePayload, 0, bytePacket, byteHeader.length, bytePayload.length);
}
@Before
public void setUp() {
deserializer = deserializer();
}
/**
* Tests serialize and setters.
*/
@Test
public void testSerialize() {
IPv6 ipv6 = new IPv6();
ipv6.setPayload(udp);
ipv6.setVersion((byte) 6);
ipv6.setTrafficClass((byte) 0x93);
ipv6.setFlowLabel(0x13579);
ipv6.setNextHeader(PROTOCOL_UDP);
ipv6.setHopLimit((byte) 32);
ipv6.setSourceAddress(SOURCE_ADDRESS);
ipv6.setDestinationAddress(DESTINATION_ADDRESS);
assertArrayEquals(ipv6.serialize(), bytePacket);
}
@Test
public void testDeserializeBadInput() throws Exception {
PacketTestUtils.testDeserializeBadInput(deserializer);
}
@Test
public void testDeserializeTruncated() throws Exception {
// Run the truncation test only on the IPv6 header
byte[] ipv6Header = new byte[FIXED_HEADER_LENGTH];
ByteBuffer.wrap(bytePacket).get(ipv6Header);
PacketTestUtils.testDeserializeTruncated(deserializer, ipv6Header);
}
/**
* Tests deserialize and getters.
*/
@Test
public void testDeserialize() throws DeserializationException {
IPv6 ipv6 = deserializer.deserialize(bytePacket, 0, bytePacket.length);
assertThat(ipv6.getVersion(), is((byte) 6));
assertThat(ipv6.getTrafficClass(), is((byte) 0x93));
assertThat(ipv6.getFlowLabel(), is(0x13579));
assertThat(ipv6.getNextHeader(), is(PROTOCOL_UDP));
assertThat(ipv6.getHopLimit(), is((byte) 32));
assertArrayEquals(ipv6.getSourceAddress(), SOURCE_ADDRESS);
assertArrayEquals(ipv6.getDestinationAddress(), DESTINATION_ADDRESS);
}
/**
* Tests comparator.
*/
@Test
public void testEqual() {
IPv6 packet1 = new IPv6();
packet1.setPayload(udp);
packet1.setVersion((byte) 6);
packet1.setTrafficClass((byte) 0x93);
packet1.setFlowLabel(0x13579);
packet1.setNextHeader(PROTOCOL_UDP);
packet1.setHopLimit((byte) 32);
packet1.setSourceAddress(SOURCE_ADDRESS);
packet1.setDestinationAddress(DESTINATION_ADDRESS);
IPv6 packet2 = new IPv6();
packet2.setPayload(udp);
packet2.setVersion((byte) 6);
packet2.setTrafficClass((byte) 0x93);
packet2.setFlowLabel(0x13579);
packet2.setNextHeader(PROTOCOL_UDP);
packet2.setHopLimit((byte) 32);
packet2.setSourceAddress(DESTINATION_ADDRESS);
packet2.setDestinationAddress(SOURCE_ADDRESS);
assertTrue(packet1.equals(packet1));
assertFalse(packet1.equals(packet2));
}
/**
* Tests toString.
*/
@Test
public void testToStringIPv6() throws Exception {
IPv6 ipv6 = deserializer.deserialize(bytePacket, 0, bytePacket.length);
String str = ipv6.toString();
assertTrue(StringUtils.contains(str, "version=" + (byte) 6));
assertTrue(StringUtils.contains(str, "trafficClass=" + (byte) 0x93));
assertTrue(StringUtils.contains(str, "flowLabel=" + 0x13579));
assertTrue(StringUtils.contains(str, "nextHeader=" + PROTOCOL_UDP));
assertTrue(StringUtils.contains(str, "hopLimit=" + (byte) 32));
// TODO: test IPv6 source and destination address
}
/**
* Tests the proper operation of the solicitationNodeAddress function.
*/
@Test
public void testSolicitationNodeAddress() {
assertArrayEquals(SOLICITATION_NODE_ADDRESS, getSolicitNodeAddress(DESTINATION_ADDRESS));
}
/**
* Tests the proper operation of the multicastAddress function.
*/
@Test
public void testMulticastAddress() {
assertArrayEquals(MULTICAST_ADDRESS, getMCastMacAddress(DESTINATION_ADDRESS));
}
/**
* Tests the proper operation of the isLinkLocalAddress function.
*/
@Test
public void testIsLinkLocalAddress() {
assertFalse(isLinkLocalAddress(SOURCE_ADDRESS));
assertFalse(isLinkLocalAddress(DESTINATION_ADDRESS));
assertFalse(isLinkLocalAddress(SOLICITATION_NODE_ADDRESS));
assertTrue(isLinkLocalAddress(LINK_LOCAL_ADDRESS_1));
assertTrue(isLinkLocalAddress(LINK_LOCAL_ADDRESS_2));
}
/**
* Tests the proper operation of the linkLocalAddress function.
*/
@Test
public void testLinkLocalAddress() {
assertArrayEquals(getLinkLocalAddress(MAC_ADDRESS_1), LINK_LOCAL_ADDRESS_1);
assertArrayEquals(getLinkLocalAddress(MAC_ADDRESS_2), LINK_LOCAL_ADDRESS_2);
}
/**
* Tests the proper operation of the macAddress function.
*/
@Test
public void testMacAddress() {
assertArrayEquals(getMacAddress(LINK_LOCAL_ADDRESS_1), MAC_ADDRESS_1);
assertArrayEquals(getMacAddress(LINK_LOCAL_ADDRESS_2), MAC_ADDRESS_2);
}
}