Chromium Code Reviews| 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 |