OLD | NEW |
---|---|
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 The Chromium Authors. All rights reserved. |
eroman
2015/03/31 21:11:12
As an aside: This test is named *_test.cc. Note th
tyoshino (SeeGerritForStatus)
2015/04/01 04:57:57
Will do renaming.
tyoshino (SeeGerritForStatus)
2015/04/01 06:52:17
Hmm, all of the unit test files are named _test.cc
| |
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/websockets/websocket_extension_parser.h" | 5 #include "net/websockets/websocket_extension_parser.h" |
6 | 6 |
7 #include <string> | 7 #include <string> |
8 | 8 |
9 #include "net/websockets/websocket_extension.h" | 9 #include "net/websockets/websocket_extension.h" |
10 #include "testing/gtest/include/gtest/gtest.h" | 10 #include "testing/gtest/include/gtest/gtest.h" |
11 | 11 |
12 namespace net { | 12 namespace net { |
13 | 13 |
14 namespace { | 14 namespace { |
15 | 15 |
16 TEST(WebSocketExtensionParserTest, ParseEmpty) { | 16 TEST(WebSocketExtensionParserTest, ParseEmpty) { |
17 WebSocketExtensionParser parser; | 17 WebSocketExtensionParser parser; |
18 parser.Parse("", 0); | 18 parser.Parse("", 0); |
19 | 19 |
20 EXPECT_TRUE(parser.has_error()); | 20 EXPECT_TRUE(parser.has_error()); |
21 EXPECT_EQ(0U, parser.extensions().size()); | |
21 } | 22 } |
22 | 23 |
23 TEST(WebSocketExtensionParserTest, ParseSimple) { | 24 TEST(WebSocketExtensionParserTest, ParseSimple) { |
24 WebSocketExtensionParser parser; | 25 WebSocketExtensionParser parser; |
25 WebSocketExtension expected("foo"); | 26 WebSocketExtension expected("foo"); |
26 | 27 |
27 parser.Parse("foo"); | 28 parser.Parse("foo"); |
28 | 29 |
29 ASSERT_FALSE(parser.has_error()); | 30 ASSERT_FALSE(parser.has_error()); |
30 EXPECT_TRUE(expected.Equals(parser.extension())); | 31 ASSERT_EQ(1U, parser.extensions().size()); |
32 EXPECT_TRUE(expected.Equals(parser.extensions()[0])); | |
33 } | |
34 | |
35 TEST(WebSocketExtensionParserTest, ParseMoreThanOnce) { | |
36 WebSocketExtensionParser parser; | |
37 WebSocketExtension expected("foo"); | |
38 | |
39 parser.Parse("foo"); | |
40 ASSERT_FALSE(parser.has_error()); | |
41 ASSERT_EQ(1U, parser.extensions().size()); | |
42 EXPECT_TRUE(expected.Equals(parser.extensions()[0])); | |
43 | |
44 parser.Parse(""); | |
45 EXPECT_TRUE(parser.has_error()); | |
46 EXPECT_EQ(0U, parser.extensions().size()); | |
47 | |
48 parser.Parse("foo"); | |
49 ASSERT_FALSE(parser.has_error()); | |
50 ASSERT_EQ(1U, parser.extensions().size()); | |
51 EXPECT_TRUE(expected.Equals(parser.extensions()[0])); | |
31 } | 52 } |
32 | 53 |
33 TEST(WebSocketExtensionParserTest, ParseOneExtensionWithOneParamWithoutValue) { | 54 TEST(WebSocketExtensionParserTest, ParseOneExtensionWithOneParamWithoutValue) { |
34 WebSocketExtensionParser parser; | 55 WebSocketExtensionParser parser; |
35 WebSocketExtension expected("foo"); | 56 WebSocketExtension expected("foo"); |
36 expected.Add(WebSocketExtension::Parameter("bar")); | 57 expected.Add(WebSocketExtension::Parameter("bar")); |
37 | 58 |
38 parser.Parse("\tfoo ; bar"); | 59 parser.Parse("\tfoo ; bar"); |
39 | 60 |
40 ASSERT_FALSE(parser.has_error()); | 61 ASSERT_FALSE(parser.has_error()); |
41 EXPECT_TRUE(expected.Equals(parser.extension())); | 62 ASSERT_EQ(1U, parser.extensions().size()); |
63 EXPECT_TRUE(expected.Equals(parser.extensions()[0])); | |
42 } | 64 } |
43 | 65 |
44 TEST(WebSocketExtensionParserTest, ParseOneExtensionWithOneParamWithValue) { | 66 TEST(WebSocketExtensionParserTest, ParseOneExtensionWithOneParamWithValue) { |
45 WebSocketExtensionParser parser; | 67 WebSocketExtensionParser parser; |
46 WebSocketExtension expected("foo"); | 68 WebSocketExtension expected("foo"); |
47 expected.Add(WebSocketExtension::Parameter("bar", "baz")); | 69 expected.Add(WebSocketExtension::Parameter("bar", "baz")); |
48 | 70 |
49 parser.Parse("foo ; bar= baz\t"); | 71 parser.Parse("foo ; bar= baz\t"); |
50 | 72 |
51 ASSERT_FALSE(parser.has_error()); | 73 ASSERT_FALSE(parser.has_error()); |
52 EXPECT_TRUE(expected.Equals(parser.extension())); | 74 ASSERT_EQ(1U, parser.extensions().size()); |
75 EXPECT_TRUE(expected.Equals(parser.extensions()[0])); | |
53 } | 76 } |
54 | 77 |
55 TEST(WebSocketExtensionParserTest, ParseOneExtensionWithParams) { | 78 TEST(WebSocketExtensionParserTest, ParseOneExtensionWithParams) { |
56 WebSocketExtensionParser parser; | 79 WebSocketExtensionParser parser; |
57 WebSocketExtension expected("foo"); | 80 WebSocketExtension expected("foo"); |
58 expected.Add(WebSocketExtension::Parameter("bar", "baz")); | 81 expected.Add(WebSocketExtension::Parameter("bar", "baz")); |
59 expected.Add(WebSocketExtension::Parameter("hoge", "fuga")); | 82 expected.Add(WebSocketExtension::Parameter("hoge", "fuga")); |
60 | 83 |
61 parser.Parse("foo ; bar= baz;\t \thoge\t\t=fuga"); | 84 parser.Parse("foo ; bar= baz;\t \thoge\t\t=fuga"); |
62 | 85 |
63 ASSERT_FALSE(parser.has_error()); | 86 ASSERT_FALSE(parser.has_error()); |
64 EXPECT_TRUE(expected.Equals(parser.extension())); | 87 ASSERT_EQ(1U, parser.extensions().size()); |
88 EXPECT_TRUE(expected.Equals(parser.extensions()[0])); | |
89 } | |
90 | |
91 TEST(WebSocketExtensionParserTest, ParseTwoExtensions) { | |
92 WebSocketExtensionParser parser; | |
93 | |
94 WebSocketExtension expected0("foo"); | |
95 expected0.Add(WebSocketExtension::Parameter("alpha", "x")); | |
96 | |
97 WebSocketExtension expected1("bar"); | |
98 expected1.Add(WebSocketExtension::Parameter("beta", "y")); | |
99 | |
100 parser.Parse(" foo ; alpha = x , bar ; beta = y "); | |
101 | |
102 ASSERT_FALSE(parser.has_error()); | |
103 ASSERT_EQ(2U, parser.extensions().size()); | |
104 | |
105 EXPECT_TRUE(expected0.Equals(parser.extensions()[0])); | |
106 EXPECT_TRUE(expected1.Equals(parser.extensions()[1])); | |
65 } | 107 } |
66 | 108 |
67 TEST(WebSocketExtensionParserTest, InvalidPatterns) { | 109 TEST(WebSocketExtensionParserTest, InvalidPatterns) { |
68 const char* const patterns[] = { | 110 const char* const patterns[] = { |
69 "fo\ao", // control in extension name | 111 ",", // just a comma |
70 "fo\x01o", // control in extension name | 112 "foo,", // second extension is incomplete |
eroman
2015/03/31 21:11:12
I suggest adding a couple more invalid variations
tyoshino (SeeGerritForStatus)
2015/04/01 04:57:57
Done.
| |
71 "fo<o", // separator in extension name | 113 "fo\ao", // control in extension name |
72 "foo/", // separator in extension name | 114 "fo\x01o", // control in extension name |
73 ";bar", // empty extension name | 115 "fo<o", // separator in extension name |
74 "foo bar", // missing ';' | 116 "foo/", // separator in extension name |
75 "foo;", // extension parameter without name and value | 117 ";bar", // empty extension name |
76 "foo; b\ar", // control in parameter name | 118 "foo bar", // missing ';' |
77 "foo; b\x7fr", // control in parameter name | 119 "foo;", // extension parameter without name and value |
78 "foo; b[r", // separator in parameter name | 120 "foo; b\ar", // control in parameter name |
79 "foo; ba:", // separator in parameter name | 121 "foo; b\x7fr", // control in parameter name |
80 "foo; =baz", // empty parameter name | 122 "foo; b[r", // separator in parameter name |
81 "foo; bar=", // empty parameter value | 123 "foo; ba:", // separator in parameter name |
82 "foo; =", // empty parameter name and value | 124 "foo; =baz", // empty parameter name |
83 "foo; bar=b\x02z", // control in parameter value | 125 "foo; bar=", // empty parameter value |
84 "foo; bar=b@z", // separator in parameter value | 126 "foo; =", // empty parameter name and value |
85 "foo; bar=b\\z", // separator in parameter value | 127 "foo; bar=b\x02z", // control in parameter value |
86 "foo; bar=b?z", // separator in parameter value | 128 "foo; bar=b@z", // separator in parameter value |
87 "\"foo\"", // quoted extension name | 129 "foo; bar=b\\z", // separator in parameter value |
88 "foo; \"bar\"", // quoted parameter name | 130 "foo; bar=b?z", // separator in parameter value |
89 "foo; bar=\"\a2\"", // control in quoted parameter value | 131 "\"foo\"", // quoted extension name |
90 "foo; bar=\"b@z\"", // separator in quoted parameter value | 132 "foo; \"bar\"", // quoted parameter name |
91 "foo; bar=\"b\\\\z\"", // separator in quoted parameter value | 133 "foo; bar=\"\a2\"", // control in quoted parameter value |
92 "foo; bar=\"\"", // quoted empty parameter value | 134 "foo; bar=\"b@z\"", // separator in quoted parameter value |
93 "foo; bar=\"baz", // unterminated quoted string | 135 "foo; bar=\"b\\\\z\"", // separator in quoted parameter value |
94 "foo; bar=\"baz \"", // space in quoted string | 136 "foo; bar=\"\"", // quoted empty parameter value |
95 "foo; bar baz", // mising '=' | 137 "foo; bar=\"baz", // unterminated quoted string |
96 "foo; bar - baz", // '-' instead of '=' (note: "foo; bar-baz" is valid). | 138 "foo; bar=\"baz \"", // space in quoted string |
97 "foo; bar=\r\nbaz", // CRNL not followed by a space | 139 "foo; bar baz", // mising '=' |
98 "foo; bar=\r\n baz", // CRNL followed by a space | 140 "foo; bar - baz", // '-' instead of '=' (note: "foo; bar-baz" is valid). |
99 "foo, bar" // multiple extensions | 141 "foo; bar=\r\nbaz", // CRNL not followed by a space |
142 "foo; bar=\r\n baz", // CRNL followed by a space | |
100 }; | 143 }; |
101 | 144 |
102 for (size_t i = 0; i < arraysize(patterns); ++i) { | 145 for (size_t i = 0; i < arraysize(patterns); ++i) { |
103 WebSocketExtensionParser parser; | 146 WebSocketExtensionParser parser; |
104 parser.Parse(patterns[i]); | 147 parser.Parse(patterns[i]); |
105 EXPECT_TRUE(parser.has_error()); | 148 EXPECT_TRUE(parser.has_error()); |
149 EXPECT_EQ(0U, parser.extensions().size()); | |
106 } | 150 } |
107 } | 151 } |
108 | 152 |
109 TEST(WebSocketExtensionParserTest, QuotedParameterValue) { | 153 TEST(WebSocketExtensionParserTest, QuotedParameterValue) { |
110 WebSocketExtensionParser parser; | 154 WebSocketExtensionParser parser; |
111 WebSocketExtension expected("foo"); | 155 WebSocketExtension expected("foo"); |
112 expected.Add(WebSocketExtension::Parameter("bar", "baz")); | 156 expected.Add(WebSocketExtension::Parameter("bar", "baz")); |
113 | 157 |
114 parser.Parse("foo; bar = \"ba\\z\" "); | 158 parser.Parse("foo; bar = \"ba\\z\" "); |
115 | 159 |
116 ASSERT_FALSE(parser.has_error()); | 160 ASSERT_FALSE(parser.has_error()); |
117 EXPECT_TRUE(expected.Equals(parser.extension())); | 161 ASSERT_EQ(1U, parser.extensions().size()); |
162 EXPECT_TRUE(expected.Equals(parser.extensions()[0])); | |
118 } | 163 } |
119 | 164 |
120 } // namespace | 165 } // namespace |
121 | 166 |
122 } // namespace net | 167 } // namespace net |
OLD | NEW |