Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(338)

Side by Side Diff: net/base/dns_util_unittest.cc

Issue 919023003: DNSDomainFromDot: Reject empty labels. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: rebase Created 5 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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
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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698