OLD | NEW |
1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "net/base/dns_util.h" | 5 #include "net/base/dns_util.h" |
6 #include "testing/gtest/include/gtest/gtest.h" | 6 #include "testing/gtest/include/gtest/gtest.h" |
7 | 7 |
8 namespace net { | 8 namespace net { |
9 | 9 |
10 class DNSUtilTest : public testing::Test { | 10 class DNSUtilTest : public testing::Test { |
(...skipping 26 matching lines...) Expand all Loading... |
37 // Label is too long: invalid | 37 // Label is too long: invalid |
38 EXPECT_FALSE(DNSDomainFromDot("123456789a123456789a123456789a123456789a1234567
89a123456789a1234", &out)); | 38 EXPECT_FALSE(DNSDomainFromDot("123456789a123456789a123456789a123456789a1234567
89a123456789a1234", &out)); |
39 | 39 |
40 // 253 characters in the name: still valid | 40 // 253 characters in the name: still valid |
41 EXPECT_TRUE(DNSDomainFromDot("abcdefghi.abcdefghi.abcdefghi.abcdefghi.abcdefgh
i.abcdefghi.abcdefghi.abcdefghi.abcdefghi.abcdefghi.abcdefghi.abcdefghi.abcdefgh
i.abcdefghi.abcdefghi.abcdefghi.abcdefghi.abcdefghi.abcdefghi.abcdefghi.abcdefgh
i.abcdefghi.abcdefghi.abcdefghi.abcdefghi.abc", &out)); | 41 EXPECT_TRUE(DNSDomainFromDot("abcdefghi.abcdefghi.abcdefghi.abcdefghi.abcdefgh
i.abcdefghi.abcdefghi.abcdefghi.abcdefghi.abcdefghi.abcdefghi.abcdefghi.abcdefgh
i.abcdefghi.abcdefghi.abcdefghi.abcdefghi.abcdefghi.abcdefghi.abcdefghi.abcdefgh
i.abcdefghi.abcdefghi.abcdefghi.abcdefghi.abc", &out)); |
42 EXPECT_EQ(out, IncludeNUL("\011abcdefghi\011abcdefghi\011abcdefghi\011abcdefgh
i\011abcdefghi\011abcdefghi\011abcdefghi\011abcdefghi\011abcdefghi\011abcdefghi\
011abcdefghi\011abcdefghi\011abcdefghi\011abcdefghi\011abcdefghi\011abcdefghi\01
1abcdefghi\011abcdefghi\011abcdefghi\011abcdefghi\011abcdefghi\011abcdefghi\011a
bcdefghi\011abcdefghi\011abcdefghi\003abc")); | 42 EXPECT_EQ(out, IncludeNUL("\011abcdefghi\011abcdefghi\011abcdefghi\011abcdefgh
i\011abcdefghi\011abcdefghi\011abcdefghi\011abcdefghi\011abcdefghi\011abcdefghi\
011abcdefghi\011abcdefghi\011abcdefghi\011abcdefghi\011abcdefghi\011abcdefghi\01
1abcdefghi\011abcdefghi\011abcdefghi\011abcdefghi\011abcdefghi\011abcdefghi\011a
bcdefghi\011abcdefghi\011abcdefghi\003abc")); |
43 | 43 |
44 // 254 characters in the name: invalid | 44 // 254 characters in the name: invalid |
45 EXPECT_FALSE(DNSDomainFromDot("123456789.123456789.123456789.123456789.1234567
89.123456789.123456789.123456789.123456789.123456789.123456789.123456789.1234567
89.123456789.123456789.123456789.123456789.123456789.123456789.123456789.1234567
89.123456789.123456789.123456789.123456789.1234", &out)); | 45 EXPECT_FALSE(DNSDomainFromDot("123456789.123456789.123456789.123456789.1234567
89.123456789.123456789.123456789.123456789.123456789.123456789.123456789.1234567
89.123456789.123456789.123456789.123456789.123456789.123456789.123456789.1234567
89.123456789.123456789.123456789.123456789.1234", &out)); |
46 | 46 |
47 // Zero length labels should be dropped. | 47 // Zero length labels should fail, except that one trailing dot is allowed |
| 48 // (to disable suffix search): |
| 49 EXPECT_FALSE(DNSDomainFromDot(".google.com", &out)); |
| 50 EXPECT_FALSE(DNSDomainFromDot("www..google.com", &out)); |
| 51 |
48 EXPECT_TRUE(DNSDomainFromDot("www.google.com.", &out)); | 52 EXPECT_TRUE(DNSDomainFromDot("www.google.com.", &out)); |
49 EXPECT_EQ(out, IncludeNUL("\003www\006google\003com")); | 53 EXPECT_EQ(out, IncludeNUL("\003www\006google\003com")); |
50 | |
51 EXPECT_TRUE(DNSDomainFromDot(".google.com", &out)); | |
52 EXPECT_EQ(out, IncludeNUL("\006google\003com")); | |
53 | |
54 EXPECT_TRUE(DNSDomainFromDot("www..google.com", &out)); | |
55 EXPECT_EQ(out, IncludeNUL("\003www\006google\003com")); | |
56 } | 54 } |
57 | 55 |
58 TEST_F(DNSUtilTest, DNSDomainToString) { | 56 TEST_F(DNSUtilTest, DNSDomainToString) { |
59 EXPECT_EQ("", DNSDomainToString(IncludeNUL(""))); | 57 EXPECT_EQ("", DNSDomainToString(IncludeNUL(""))); |
60 EXPECT_EQ("foo", DNSDomainToString(IncludeNUL("\003foo"))); | 58 EXPECT_EQ("foo", DNSDomainToString(IncludeNUL("\003foo"))); |
61 EXPECT_EQ("foo.bar", DNSDomainToString(IncludeNUL("\003foo\003bar"))); | 59 EXPECT_EQ("foo.bar", DNSDomainToString(IncludeNUL("\003foo\003bar"))); |
62 EXPECT_EQ("foo.bar.uk", | 60 EXPECT_EQ("foo.bar.uk", |
63 DNSDomainToString(IncludeNUL("\003foo\003bar\002uk"))); | 61 DNSDomainToString(IncludeNUL("\003foo\003bar\002uk"))); |
64 | 62 |
65 // It should cope with a lack of root label. | 63 // It should cope with a lack of root label. |
66 EXPECT_EQ("foo.bar", DNSDomainToString("\003foo\003bar")); | 64 EXPECT_EQ("foo.bar", DNSDomainToString("\003foo\003bar")); |
67 | 65 |
68 // Invalid inputs should return an empty string. | 66 // Invalid inputs should return an empty string. |
69 EXPECT_EQ("", DNSDomainToString(IncludeNUL("\x80"))); | 67 EXPECT_EQ("", DNSDomainToString(IncludeNUL("\x80"))); |
70 EXPECT_EQ("", DNSDomainToString("\x06")); | 68 EXPECT_EQ("", DNSDomainToString("\x06")); |
71 } | 69 } |
72 | 70 |
73 } // namespace net | 71 } // namespace net |
OLD | NEW |