Added DNS response TC
This commit is contained in:
parent
31a47f52cd
commit
ea206cc5b5
4 changed files with 90 additions and 19 deletions
|
|
@ -25,9 +25,14 @@
|
|||
package zutil.net.dns;
|
||||
|
||||
import org.junit.Test;
|
||||
import zutil.converter.Converter;
|
||||
import zutil.parser.binary.BinaryStructOutputStream;
|
||||
import static zutil.net.dns.DNSPacketQuestion.*;
|
||||
|
||||
import static org.junit.Assert.assertTrue;
|
||||
import static zutil.net.dns.DNSPacketQuestion.*;
|
||||
import static zutil.net.dns.DNSPacketResource.*;
|
||||
|
||||
import java.io.ByteArrayInputStream;
|
||||
import java.io.ByteArrayOutputStream;
|
||||
import java.io.IOException;
|
||||
|
||||
|
|
@ -40,7 +45,7 @@ import static org.junit.Assert.assertEquals;
|
|||
public class DNSPacketTest {
|
||||
|
||||
@Test
|
||||
public void writeHeaderTest() throws IOException {
|
||||
public void writeRequestHeaderTest() throws IOException {
|
||||
DNSPacketHeader header = new DNSPacketHeader();
|
||||
header.setDefaultQueryData();
|
||||
header.countQuestion = 1;
|
||||
|
|
@ -54,7 +59,7 @@ public class DNSPacketTest {
|
|||
}
|
||||
|
||||
@Test
|
||||
public void readHheaderTest() throws IOException {
|
||||
public void readResponseHeaderTest() throws IOException {
|
||||
DNSPacketHeader header = new DNSPacketHeader();
|
||||
header.setDefaultResponseData();
|
||||
header.countAnswerRecord = 1;
|
||||
|
|
@ -68,7 +73,7 @@ public class DNSPacketTest {
|
|||
}
|
||||
|
||||
@Test
|
||||
public void writeDnsPacketHeaderTest() throws IOException {
|
||||
public void writeRequestDnsPacketHeaderTest() throws IOException {
|
||||
DNSPacket packet = new DNSPacket();
|
||||
packet.getHeader().setDefaultQueryData();
|
||||
|
||||
|
|
@ -87,7 +92,7 @@ public class DNSPacketTest {
|
|||
}
|
||||
|
||||
@Test
|
||||
public void writeDnsPacketTest() throws IOException {
|
||||
public void writeRequestDnsPacketTest() throws IOException {
|
||||
DNSPacket packet = new DNSPacket();
|
||||
packet.getHeader().setDefaultQueryData();
|
||||
packet.addQuestion(new DNSPacketQuestion("appletv.local", QTYPE_A, QCLASS_IN));
|
||||
|
|
@ -97,17 +102,72 @@ public class DNSPacketTest {
|
|||
byte[] data = buffer.toByteArray();
|
||||
|
||||
byte[] expected = {
|
||||
0x00, 0x00, 0x00, 0x00,
|
||||
// HEADER
|
||||
0x00, 0x00, // ID
|
||||
0x00, 0x00, // FLAGS
|
||||
0x00, 0x01, // QDCOUNT
|
||||
0x00, 0x00, // ANCOUNT
|
||||
0x00, 0x00, // NSCOUNT
|
||||
0x00, 0x00, // ARCOUNT
|
||||
// QUESTION
|
||||
0x07, 0x61, 0x70, 0x70, 0x6c, 0x65, 0x74, 0x76, // "apple"
|
||||
0x05, 0x6c, 0x6f, 0x63, 0x61, 0x6c, // "local"
|
||||
0x00, // NULL
|
||||
0x00, 0x01, // QTYPE
|
||||
0x00, 0x01 // QCLASS
|
||||
0x00, 0x01 // QCLASS
|
||||
};
|
||||
assertArrayEquals(expected, data);
|
||||
}
|
||||
|
||||
public void readRespnseDnsPacketTest() throws IOException {
|
||||
char[] input = {
|
||||
// HEADER
|
||||
0x00, 0x00, // ID
|
||||
0x84, 0x00, // FLAGS
|
||||
0x00, 0x00, // QDCOUNT
|
||||
0x00, 0x01, // ANCOUNT
|
||||
0x00, 0x00, // NSCOUNT
|
||||
0x00, 0x02, // ARCOUNT
|
||||
// ANSWER RECORD
|
||||
0x07, 0x61, 0x70, 0x70, 0x6c, 0x65, 0x74, 0x76, // FQDN: "apple"
|
||||
0x05, 0x6c, 0x6f, 0x63, 0x61, 0x6c, // FQDN: "local"
|
||||
0x00, // FQDN: NULL
|
||||
0x00, 0x01, // TYPE: A/IPv4
|
||||
0x80, 0x01, // CLASS: IPv4
|
||||
0x00, 0x00, 0x78, 0x00, // TTL: 30720 seconds
|
||||
0x00, 0x04, // IPv4 length
|
||||
0x99, 0x6d, 0x07, 0x5a, // IPv4: 153.109.7.90
|
||||
// ADDITIONAL RECORD
|
||||
0xc0, 0x0c, // FQDN
|
||||
0x00, 0x1c, // TYPE: AAAA/IPv6
|
||||
0x80, 0x01, // CLASS: IPv6
|
||||
0x00, 0x00, 0x78, 0x00, // TTL: 30720 seconds
|
||||
0x00, 0x10, // IPv6 length
|
||||
0xfe, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // IPv6
|
||||
0x02, 0x23, 0x32, 0xff, 0xfe, 0xb1, 0x21, 0x52, // IPv6
|
||||
// ADDITIONAL RECORD
|
||||
0xc0, 0x0c, // FQDN
|
||||
0x00, 0x2f, // TYPE: NSEC
|
||||
0x80, 0x01, // CLASS: NSEC
|
||||
0x00, 0x00, 0x78, 0x00, // TTL
|
||||
0x00, 0x08, // NSEC length
|
||||
0xc0, 0x0c, 0x00, 0x04, 0x40, 0x00, 0x00, 0x08 // NSEC
|
||||
};
|
||||
ByteArrayInputStream buffer = new ByteArrayInputStream(Converter.toBytes(input));
|
||||
DNSPacket packet = DNSPacket.read(buffer);
|
||||
|
||||
// Assert Header
|
||||
assertTrue("flagQueryResponse", packet.getHeader().flagQueryResponse);
|
||||
assertTrue("flagAuthoritativeAnswer", packet.getHeader().flagAuthoritativeAnswer);
|
||||
assertEquals("ANCOUNT", 1, packet.getHeader().countAnswerRecord);
|
||||
assertEquals("ARCOUNT", 2, packet.getHeader().countAdditionalRecord);
|
||||
// Assert Answer
|
||||
assertEquals("No Of Answer records", 1, packet.getAnswerRecords().size());
|
||||
DNSPacketResource answer = packet.getAnswerRecords().get(0);
|
||||
assertEquals("TYPE", TYPE_A, answer.type);
|
||||
assertEquals("CLASS", CLASS_IN, answer.clazz);
|
||||
assertEquals("TTL", 30720, answer.ttl);
|
||||
assertEquals("IPv4", new char[]{0x99, 0x6d, 0x07, 0x5a}, answer.data);
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue