Chromium Code Reviews| Index: net/websockets/websocket_deflate_parameters_test.cc |
| diff --git a/net/websockets/websocket_deflate_parameters_test.cc b/net/websockets/websocket_deflate_parameters_test.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..5c3d3faa430033c56822c62dc1f7fb5aa3c465a8 |
| --- /dev/null |
| +++ b/net/websockets/websocket_deflate_parameters_test.cc |
| @@ -0,0 +1,256 @@ |
| +// Copyright 2015 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "net/websockets/websocket_deflate_parameters.h" |
| + |
| +#include <string> |
| + |
|
tyoshino (SeeGerritForStatus)
2015/09/10 09:06:19
base/macros.h
yhirano
2015/09/10 11:20:13
Done.
|
| +#include "net/websockets/websocket_extension_parser.h" |
| +#include "testing/gtest/include/gtest/gtest.h" |
| + |
| +namespace net { |
| + |
| +namespace { |
| + |
| +void CheckExtension(const WebSocketDeflateParameters& params, |
| + const std::string& name, |
| + const std::string& value) { |
| + WebSocketExtension e = params.AsExtension(); |
| + EXPECT_EQ("permessage-deflate", e.name()); |
| + if (e.parameters().size() != 1) |
| + FAIL() << "parameters must have one element."; |
| + EXPECT_EQ(name, e.parameters()[0].name()); |
| + EXPECT_EQ(value, e.parameters()[0].value()); |
| +} |
| + |
| +TEST(WebSocketDeflateParametersTest, Empty) { |
| + WebSocketDeflateParameters r; |
| + |
| + EXPECT_EQ(WebSocketDeflater::TAKE_OVER_CONTEXT, |
| + r.server_context_take_over_mode()); |
| + EXPECT_EQ(WebSocketDeflater::TAKE_OVER_CONTEXT, |
| + r.client_context_take_over_mode()); |
| + EXPECT_FALSE(r.is_server_max_window_bits_specified()); |
| + EXPECT_FALSE(r.is_client_max_window_bits_specified()); |
| + EXPECT_TRUE(r.IsValidAsRequest()); |
| + EXPECT_TRUE(r.IsValidAsResponse()); |
| + WebSocketExtension e = r.AsExtension(); |
| + EXPECT_EQ("permessage-deflate", e.name()); |
| + EXPECT_TRUE(e.parameters().empty()); |
| +} |
| + |
| +TEST(WebSocketDeflateParametersTest, ServerContextTakeover) { |
| + WebSocketDeflateParameters r; |
| + |
| + r.SetServerNoContextTakeOver(); |
| + CheckExtension(r, "server_no_context_takeover", ""); |
| + EXPECT_TRUE(r.IsValidAsRequest()); |
| + EXPECT_TRUE(r.IsValidAsResponse()); |
| +} |
| + |
| +TEST(WebSocketDeflateParametersTest, ClientContextTakeover) { |
| + WebSocketDeflateParameters r; |
| + |
| + r.SetClientNoContextTakeOver(); |
| + CheckExtension(r, "client_no_context_takeover", ""); |
| + EXPECT_TRUE(r.IsValidAsRequest()); |
| + EXPECT_TRUE(r.IsValidAsResponse()); |
| +} |
| + |
| +TEST(WebSocketDeflateParametersTest, ServerMaxWindowBits) { |
| + WebSocketDeflateParameters r; |
| + |
| + r.SetServerMaxWindowBits(13); |
| + CheckExtension(r, "server_max_window_bits", "13"); |
| + EXPECT_TRUE(r.IsValidAsRequest()); |
| + EXPECT_TRUE(r.IsValidAsResponse()); |
| +} |
| + |
| +TEST(WebSocketDeflateParametersTest, ClientMaxWindowBitsWithoutValue) { |
| + WebSocketDeflateParameters r; |
| + std::string failure_message; |
| + |
| + r.SetClientMaxWindowBits(); |
| + CheckExtension(r, "client_max_window_bits", ""); |
| + EXPECT_TRUE(r.IsValidAsRequest()); |
| + EXPECT_FALSE(r.IsValidAsResponse(&failure_message)); |
| + EXPECT_EQ("client_max_window_bits must have value", failure_message); |
| +} |
| + |
| +TEST(WebSocketDeflateParametersTest, ClientMaxWindowBitsWithValue) { |
| + WebSocketDeflateParameters r; |
| + |
| + r.SetClientMaxWindowBits(12); |
| + CheckExtension(r, "client_max_window_bits", "12"); |
| + EXPECT_TRUE(r.IsValidAsRequest()); |
| + EXPECT_TRUE(r.IsValidAsResponse()); |
| +} |
| + |
| +struct InitializeTestParameter { |
| + const std::string query; |
| + struct Expectation { |
| + bool result; |
| + std::string failure_message; |
| + } const expected; |
| +}; |
| + |
| +void PrintTo(const InitializeTestParameter& p, std::ostream* o) { |
| + *o << p.query; |
| +} |
| + |
| +class WebSocketDeflateParametersInitializeTest |
| + : public ::testing::TestWithParam<InitializeTestParameter> {}; |
| + |
| +TEST_P(WebSocketDeflateParametersInitializeTest, Initialize) { |
| + const std::string query = GetParam().query; |
| + const bool expected = GetParam().expected.result; |
| + const std::string expected_failure_message = |
| + GetParam().expected.failure_message; |
| + |
| + WebSocketExtensionParser parser; |
| + ASSERT_TRUE(parser.Parse("permessage-deflate" + query)); |
| + ASSERT_EQ(1u, parser.extensions().size()); |
| + WebSocketExtension extension = parser.extensions()[0]; |
| + |
| + WebSocketDeflateParameters parameters; |
| + std::string failure_message; |
| + bool actual = parameters.Initialize(extension, &failure_message); |
| + |
| + if (expected) { |
| + EXPECT_TRUE(actual); |
| + EXPECT_TRUE(extension.Equals(parameters.AsExtension())); |
| + } else { |
| + EXPECT_FALSE(actual); |
| + } |
| + EXPECT_EQ(expected_failure_message, failure_message); |
| +} |
| + |
| +struct CompatibilityTestParameter { |
| + const char* request_query; |
| + const char* response_query; |
| + const bool expected; |
| +}; |
| + |
| +void PrintTo(const CompatibilityTestParameter& p, std::ostream* o) { |
| + *o << "req = \"" << p.request_query << "\", res = \"" << p.response_query |
| + << "\""; |
| +} |
| + |
| +class WebSocketDeflateParametersCompatibilityTest |
| + : public ::testing::TestWithParam<CompatibilityTestParameter> {}; |
| + |
| +TEST_P(WebSocketDeflateParametersCompatibilityTest, CheckCompatiblity) { |
| + const std::string request_query = GetParam().request_query; |
| + const std::string response_query = GetParam().response_query; |
| + const bool expected = GetParam().expected; |
| + |
| + std::string message; |
| + WebSocketDeflateParameters request, response; |
| + |
| + WebSocketExtensionParser request_parser; |
| + ASSERT_TRUE(request_parser.Parse("permessage-deflate" + request_query)); |
| + ASSERT_EQ(1u, request_parser.extensions().size()); |
| + ASSERT_TRUE(request.Initialize(request_parser.extensions()[0], &message)); |
| + ASSERT_TRUE(request.IsValidAsRequest(&message)); |
| + |
| + WebSocketExtensionParser response_parser; |
| + ASSERT_TRUE(response_parser.Parse("permessage-deflate" + response_query)); |
| + ASSERT_EQ(1u, response_parser.extensions().size()); |
| + ASSERT_TRUE(response.Initialize(response_parser.extensions()[0], &message)); |
| + ASSERT_TRUE(response.IsValidAsResponse(&message)); |
| + |
| + EXPECT_EQ(expected, request.IsCompatibleWith(response)); |
| +} |
| + |
| +InitializeTestParameter::Expectation Duplicate(const std::string& name) { |
| + return {false, |
| + "Received duplicate permessage-deflate extension parameter " + name}; |
| +} |
| + |
| +InitializeTestParameter::Expectation Invalid(const std::string& name) { |
| + return {false, "Received invalid " + name + " parameter"}; |
| +} |
| + |
| +// We need to this function in order to avoid global non-pod variables. |
| +std::vector<InitializeTestParameter> InitializeTestParameters() { |
| + const InitializeTestParameter::Expectation kInitialized = {true, ""}; |
| + const InitializeTestParameter::Expectation kUnknownParameter = { |
| + false, "Received an unexpected permessage-deflate extension parameter"}; |
| + |
| + const InitializeTestParameter parameters[] = { |
| + {"", kInitialized}, |
| + {"; server_no_context_takeover", kInitialized}, |
| + {"; server_no_context_takeover=0", Invalid("server_no_context_takeover")}, |
| + {"; server_no_context_takeover; server_no_context_takeover", |
| + Duplicate("server_no_context_takeover")}, |
| + {"; client_no_context_takeover", kInitialized}, |
| + {"; client_no_context_takeover=0", Invalid("client_no_context_takeover")}, |
| + {"; client_no_context_takeover; client_no_context_takeover", |
| + Duplicate("client_no_context_takeover")}, |
| + {"; server_max_window_bits=8", kInitialized}, |
| + {"; server_max_window_bits=15", kInitialized}, |
| + {"; server_max_window_bits=15; server_max_window_bits=15", |
| + Duplicate("server_max_window_bits")}, |
| + {"; server_max_window_bits=a", Invalid("server_max_window_bits")}, |
| + {"; server_max_window_bits=09", Invalid("server_max_window_bits")}, |
| + {"; server_max_window_bits=+9", Invalid("server_max_window_bits")}, |
| + {"; server_max_window_bits=9a", Invalid("server_max_window_bits")}, |
| + {"; server_max_window_bits", Invalid("server_max_window_bits")}, |
| + {"; server_max_window_bits=7", Invalid("server_max_window_bits")}, |
| + {"; server_max_window_bits=16", Invalid("server_max_window_bits")}, |
| + {"; client_max_window_bits=15; client_max_window_bits=15", |
|
tyoshino (SeeGerritForStatus)
2015/09/10 09:06:20
include the client_max_window_bits version of L191
yhirano
2015/09/10 11:20:13
Done.
|
| + Duplicate("client_max_window_bits")}, |
| + {"; client_max_window_bits=a", Invalid("client_max_window_bits")}, |
| + {"; client_max_window_bits=09", Invalid("client_max_window_bits")}, |
| + {"; client_max_window_bits=+9", Invalid("client_max_window_bits")}, |
| + {"; client_max_window_bits=9a", Invalid("client_max_window_bits")}, |
| + {"; client_max_window_bits", kInitialized}, |
| + {"; client_max_window_bits=7", Invalid("client_max_window_bits")}, |
| + {"; client_max_window_bits=16", Invalid("client_max_window_bits")}, |
| + {"; server_no_context_takeover; client_no_context_takeover" |
| + "; server_max_window_bits=12; client_max_window_bits=13", |
| + kInitialized}, |
| + {"; hogefuga", kUnknownParameter}, |
| + }; |
| + return std::vector<InitializeTestParameter>( |
| + parameters, parameters + arraysize(parameters)); |
| +} |
| + |
| +const CompatibilityTestParameter kCompatibilityTestParameters[] = { |
| + {"", "", true}, |
| + // server_no_context_takeover |
| + {"", "; server_no_context_takeover", true}, |
| + {"; server_no_context_takeover", "", false}, |
| + {"; server_no_context_takeover", "; server_no_context_takeover", true}, |
| + // client_no_context_takeover |
| + {"", "; client_no_context_takeover", true}, |
| + {"; client_no_context_takeover", "", true}, |
| + {"; client_no_context_takeover", "; client_no_context_takeover", true}, |
| + // server_max_window_bits |
| + {"", "; server_max_window_bits=14", true}, |
| + {"; server_max_window_bits=12", "", false}, |
| + {"; server_max_window_bits=12", "; server_max_window_bits=12", true}, |
| + {"; server_max_window_bits=12", "; server_max_window_bits=11", true}, |
| + {"; server_max_window_bits=12", "; server_max_window_bits=13", false}, |
| + // client_max_window_bits |
| + {"", "; client_max_window_bits=14", false}, |
| + {"; client_max_window_bits", "", true}, |
| + {"; client_max_window_bits", "; client_max_window_bits=15", true}, |
| + {"; client_max_window_bits=12", "", true}, |
| + {"; client_max_window_bits=12", "; client_max_window_bits=12", true}, |
| + {"; client_max_window_bits=12", "; client_max_window_bits=11", true}, |
| + {"; client_max_window_bits=12", "; client_max_window_bits=13", false}, |
|
tyoshino (SeeGerritForStatus)
2015/09/10 09:06:19
this response is fine
yhirano
2015/09/10 11:20:13
Done.
|
| +}; |
| + |
| +INSTANTIATE_TEST_CASE_P(WebSocketDeflateParametersInitializeTest, |
| + WebSocketDeflateParametersInitializeTest, |
| + ::testing::ValuesIn(InitializeTestParameters())); |
| + |
| +INSTANTIATE_TEST_CASE_P(WebSocketDeflateParametersCompatibilityTest, |
| + WebSocketDeflateParametersCompatibilityTest, |
| + ::testing::ValuesIn(kCompatibilityTestParameters)); |
| + |
| +} // namespace |
| + |
| +} // namespace net |