diff options
author | rch@chromium.org <rch@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-10-01 03:34:07 +0000 |
---|---|---|
committer | rch@chromium.org <rch@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-10-01 03:34:07 +0000 |
commit | fe2f62adb59d0ca3789312b55646e3d63ba8918f (patch) | |
tree | cdaeb552d4ffcb020b71ad1ebe9976b6b75ab175 /net/http | |
parent | d926c20f2588d7967a723f7454a0007740db0bc7 (diff) | |
download | chromium_src-fe2f62adb59d0ca3789312b55646e3d63ba8918f.zip chromium_src-fe2f62adb59d0ca3789312b55646e3d63ba8918f.tar.gz chromium_src-fe2f62adb59d0ca3789312b55646e3d63ba8918f.tar.bz2 |
Fixes the tests written for http://codereview.chromium.org/3432009/show
to use DeterministicSocketData which should avoid the flaky test
problem that 3432009 introduced.
--
Add a new class SpdyProxyClientSocket which implements ClientSocket
by sending a CONNECT request via a SPDY SYN_STREAM frame to a SPDY proxy,
and then reading/writing data to/from SPDY Data frames.
BUG=29625
TEST=none
Review URL: http://codereview.chromium.org/3578002
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@61144 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'net/http')
-rw-r--r-- | net/http/http_proxy_client_socket.cc | 33 | ||||
-rw-r--r-- | net/http/http_proxy_utils.cc | 39 | ||||
-rw-r--r-- | net/http/http_proxy_utils.h | 28 |
3 files changed, 69 insertions, 31 deletions
diff --git a/net/http/http_proxy_client_socket.cc b/net/http/http_proxy_client_socket.cc index ccc5d5d..ddefe8e 100644 --- a/net/http/http_proxy_client_socket.cc +++ b/net/http/http_proxy_client_socket.cc @@ -14,42 +14,13 @@ #include "net/base/net_util.h" #include "net/http/http_net_log_params.h" #include "net/http/http_network_session.h" +#include "net/http/http_proxy_utils.h" #include "net/http/http_request_info.h" #include "net/http/http_stream_parser.h" #include "net/socket/client_socket_handle.h" namespace net { -namespace { - -// The HTTP CONNECT method for establishing a tunnel connection is documented -// in draft-luotonen-web-proxy-tunneling-01.txt and RFC 2817, Sections 5.2 and -// 5.3. -void BuildTunnelRequest(const HttpRequestInfo* request_info, - const HttpRequestHeaders& authorization_headers, - const HostPortPair& endpoint, - std::string* request_line, - HttpRequestHeaders* request_headers) { - // RFC 2616 Section 9 says the Host request-header field MUST accompany all - // HTTP/1.1 requests. Add "Proxy-Connection: keep-alive" for compat with - // HTTP/1.0 proxies such as Squid (required for NTLM authentication). - *request_line = base::StringPrintf( - "CONNECT %s HTTP/1.1\r\n", endpoint.ToString().c_str()); - request_headers->SetHeader(HttpRequestHeaders::kHost, - GetHostAndOptionalPort(request_info->url)); - request_headers->SetHeader(HttpRequestHeaders::kProxyConnection, - "keep-alive"); - - std::string user_agent; - if (request_info->extra_headers.GetHeader(HttpRequestHeaders::kUserAgent, - &user_agent)) - request_headers->SetHeader(HttpRequestHeaders::kUserAgent, user_agent); - - request_headers->MergeFrom(authorization_headers); -} - -} // namespace - HttpProxyClientSocket::HttpProxyClientSocket( ClientSocketHandle* transport_socket, const GURL& request_url, @@ -358,7 +329,7 @@ int HttpProxyClientSocket::DoSendRequest() { auth_->AddAuthorizationHeader(&authorization_headers); std::string request_line; HttpRequestHeaders request_headers; - BuildTunnelRequest(&request_, authorization_headers, endpoint_, + BuildTunnelRequest(request_, authorization_headers, endpoint_, &request_line, &request_headers); if (net_log_.IsLoggingAll()) { net_log_.AddEvent( diff --git a/net/http/http_proxy_utils.cc b/net/http/http_proxy_utils.cc new file mode 100644 index 0000000..3e4fb8b --- /dev/null +++ b/net/http/http_proxy_utils.cc @@ -0,0 +1,39 @@ +// Copyright (c) 2010 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/http/http_proxy_utils.h" + +#include "base/string_util.h" +#include "googleurl/src/gurl.h" +#include "net/base/host_port_pair.h" +#include "net/base/net_util.h" +#include "net/http/http_request_info.h" + +namespace net { + +void BuildTunnelRequest( + const HttpRequestInfo& request_info, + const HttpRequestHeaders& auth_headers, + const HostPortPair& endpoint, + std::string* request_line, + HttpRequestHeaders* request_headers) { + // RFC 2616 Section 9 says the Host request-header field MUST accompany all + // HTTP/1.1 requests. Add "Proxy-Connection: keep-alive" for compat with + // HTTP/1.0 proxies such as Squid (required for NTLM authentication). + *request_line = StringPrintf( + "CONNECT %s HTTP/1.1\r\n", endpoint.ToString().c_str()); + request_headers->SetHeader(HttpRequestHeaders::kHost, + GetHostAndOptionalPort(request_info.url)); + request_headers->SetHeader(HttpRequestHeaders::kProxyConnection, + "keep-alive"); + + std::string user_agent; + if (request_info.extra_headers.GetHeader(HttpRequestHeaders::kUserAgent, + &user_agent)) + request_headers->SetHeader(HttpRequestHeaders::kUserAgent, user_agent); + + request_headers->MergeFrom(auth_headers); +} + +} // namespace net diff --git a/net/http/http_proxy_utils.h b/net/http/http_proxy_utils.h new file mode 100644 index 0000000..9d18fc8 --- /dev/null +++ b/net/http/http_proxy_utils.h @@ -0,0 +1,28 @@ +// Copyright (c) 2010 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. + +#ifndef NET_HTTP_HTTP_PROXY_UTILS_H_ +#define NET_HTTP_HTTP_PROXY_UTILS_H_ +#pragma once + +#include <string> + +namespace net { + +struct HttpRequestInfo; +class HttpRequestHeaders; +class HostPortPair; + +// The HTTP CONNECT method for establishing a tunnel connection is documented +// in draft-luotonen-web-proxy-tunneling-01.txt and RFC 2817, Sections 5.2 and +// 5.3. +void BuildTunnelRequest(const HttpRequestInfo& request_info, + const HttpRequestHeaders& auth_headers, + const HostPortPair& endpoint, + std::string* request_line, + HttpRequestHeaders* request_headers); + +} // namespace net + +#endif // NET_HTTP_HTTP_PROXY_UTILS_H_ |