1*6777b538SAndroid Build Coastguard Worker // Copyright 2013 The Chromium Authors
2*6777b538SAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be
3*6777b538SAndroid Build Coastguard Worker // found in the LICENSE file.
4*6777b538SAndroid Build Coastguard Worker
5*6777b538SAndroid Build Coastguard Worker #include "net/websockets/websocket_test_util.h"
6*6777b538SAndroid Build Coastguard Worker
7*6777b538SAndroid Build Coastguard Worker #include <stddef.h>
8*6777b538SAndroid Build Coastguard Worker
9*6777b538SAndroid Build Coastguard Worker #include <algorithm>
10*6777b538SAndroid Build Coastguard Worker #include <sstream>
11*6777b538SAndroid Build Coastguard Worker #include <utility>
12*6777b538SAndroid Build Coastguard Worker
13*6777b538SAndroid Build Coastguard Worker #include "base/check.h"
14*6777b538SAndroid Build Coastguard Worker #include "base/containers/span.h"
15*6777b538SAndroid Build Coastguard Worker #include "base/strings/strcat.h"
16*6777b538SAndroid Build Coastguard Worker #include "base/strings/string_util.h"
17*6777b538SAndroid Build Coastguard Worker #include "base/strings/stringprintf.h"
18*6777b538SAndroid Build Coastguard Worker #include "net/base/net_errors.h"
19*6777b538SAndroid Build Coastguard Worker #include "net/http/http_network_session.h"
20*6777b538SAndroid Build Coastguard Worker #include "net/proxy_resolution/configured_proxy_resolution_service.h"
21*6777b538SAndroid Build Coastguard Worker #include "net/proxy_resolution/proxy_resolution_service.h"
22*6777b538SAndroid Build Coastguard Worker #include "net/socket/socket_test_util.h"
23*6777b538SAndroid Build Coastguard Worker #include "net/third_party/quiche/src/quiche/spdy/core/http2_header_block.h"
24*6777b538SAndroid Build Coastguard Worker #include "net/third_party/quiche/src/quiche/spdy/core/spdy_protocol.h"
25*6777b538SAndroid Build Coastguard Worker #include "net/traffic_annotation/network_traffic_annotation_test_helper.h"
26*6777b538SAndroid Build Coastguard Worker #include "net/url_request/url_request_context.h"
27*6777b538SAndroid Build Coastguard Worker #include "net/url_request/url_request_context_builder.h"
28*6777b538SAndroid Build Coastguard Worker #include "net/websockets/websocket_basic_handshake_stream.h"
29*6777b538SAndroid Build Coastguard Worker #include "url/origin.h"
30*6777b538SAndroid Build Coastguard Worker
31*6777b538SAndroid Build Coastguard Worker namespace net {
32*6777b538SAndroid Build Coastguard Worker class AuthChallengeInfo;
33*6777b538SAndroid Build Coastguard Worker class AuthCredentials;
34*6777b538SAndroid Build Coastguard Worker class HttpResponseHeaders;
35*6777b538SAndroid Build Coastguard Worker class WebSocketHttp2HandshakeStream;
36*6777b538SAndroid Build Coastguard Worker class WebSocketHttp3HandshakeStream;
37*6777b538SAndroid Build Coastguard Worker
38*6777b538SAndroid Build Coastguard Worker namespace {
39*6777b538SAndroid Build Coastguard Worker
40*6777b538SAndroid Build Coastguard Worker const uint64_t kA = (static_cast<uint64_t>(0x5851f42d) << 32) +
41*6777b538SAndroid Build Coastguard Worker static_cast<uint64_t>(0x4c957f2d);
42*6777b538SAndroid Build Coastguard Worker const uint64_t kC = 12345;
43*6777b538SAndroid Build Coastguard Worker const uint64_t kM = static_cast<uint64_t>(1) << 48;
44*6777b538SAndroid Build Coastguard Worker
45*6777b538SAndroid Build Coastguard Worker } // namespace
46*6777b538SAndroid Build Coastguard Worker
LinearCongruentialGenerator(uint32_t seed)47*6777b538SAndroid Build Coastguard Worker LinearCongruentialGenerator::LinearCongruentialGenerator(uint32_t seed)
48*6777b538SAndroid Build Coastguard Worker : current_(seed) {}
49*6777b538SAndroid Build Coastguard Worker
Generate()50*6777b538SAndroid Build Coastguard Worker uint32_t LinearCongruentialGenerator::Generate() {
51*6777b538SAndroid Build Coastguard Worker uint64_t result = current_;
52*6777b538SAndroid Build Coastguard Worker current_ = (current_ * kA + kC) % kM;
53*6777b538SAndroid Build Coastguard Worker return static_cast<uint32_t>(result >> 16);
54*6777b538SAndroid Build Coastguard Worker }
55*6777b538SAndroid Build Coastguard Worker
WebSocketExtraHeadersToString(const WebSocketExtraHeaders & headers)56*6777b538SAndroid Build Coastguard Worker std::string WebSocketExtraHeadersToString(
57*6777b538SAndroid Build Coastguard Worker const WebSocketExtraHeaders& headers) {
58*6777b538SAndroid Build Coastguard Worker std::string answer;
59*6777b538SAndroid Build Coastguard Worker for (const auto& header : headers) {
60*6777b538SAndroid Build Coastguard Worker base::StrAppend(&answer, {header.first, ": ", header.second, "\r\n"});
61*6777b538SAndroid Build Coastguard Worker }
62*6777b538SAndroid Build Coastguard Worker return answer;
63*6777b538SAndroid Build Coastguard Worker }
64*6777b538SAndroid Build Coastguard Worker
WebSocketExtraHeadersToHttpRequestHeaders(const WebSocketExtraHeaders & headers)65*6777b538SAndroid Build Coastguard Worker HttpRequestHeaders WebSocketExtraHeadersToHttpRequestHeaders(
66*6777b538SAndroid Build Coastguard Worker const WebSocketExtraHeaders& headers) {
67*6777b538SAndroid Build Coastguard Worker HttpRequestHeaders headers_to_return;
68*6777b538SAndroid Build Coastguard Worker for (const auto& header : headers)
69*6777b538SAndroid Build Coastguard Worker headers_to_return.SetHeader(header.first, header.second);
70*6777b538SAndroid Build Coastguard Worker return headers_to_return;
71*6777b538SAndroid Build Coastguard Worker }
72*6777b538SAndroid Build Coastguard Worker
WebSocketStandardRequest(const std::string & path,const std::string & host,const url::Origin & origin,const WebSocketExtraHeaders & send_additional_request_headers,const WebSocketExtraHeaders & extra_headers)73*6777b538SAndroid Build Coastguard Worker std::string WebSocketStandardRequest(
74*6777b538SAndroid Build Coastguard Worker const std::string& path,
75*6777b538SAndroid Build Coastguard Worker const std::string& host,
76*6777b538SAndroid Build Coastguard Worker const url::Origin& origin,
77*6777b538SAndroid Build Coastguard Worker const WebSocketExtraHeaders& send_additional_request_headers,
78*6777b538SAndroid Build Coastguard Worker const WebSocketExtraHeaders& extra_headers) {
79*6777b538SAndroid Build Coastguard Worker return WebSocketStandardRequestWithCookies(path, host, origin, /*cookies=*/{},
80*6777b538SAndroid Build Coastguard Worker send_additional_request_headers,
81*6777b538SAndroid Build Coastguard Worker extra_headers);
82*6777b538SAndroid Build Coastguard Worker }
83*6777b538SAndroid Build Coastguard Worker
WebSocketStandardRequestWithCookies(const std::string & path,const std::string & host,const url::Origin & origin,const WebSocketExtraHeaders & cookies,const WebSocketExtraHeaders & send_additional_request_headers,const WebSocketExtraHeaders & extra_headers)84*6777b538SAndroid Build Coastguard Worker std::string WebSocketStandardRequestWithCookies(
85*6777b538SAndroid Build Coastguard Worker const std::string& path,
86*6777b538SAndroid Build Coastguard Worker const std::string& host,
87*6777b538SAndroid Build Coastguard Worker const url::Origin& origin,
88*6777b538SAndroid Build Coastguard Worker const WebSocketExtraHeaders& cookies,
89*6777b538SAndroid Build Coastguard Worker const WebSocketExtraHeaders& send_additional_request_headers,
90*6777b538SAndroid Build Coastguard Worker const WebSocketExtraHeaders& extra_headers) {
91*6777b538SAndroid Build Coastguard Worker // Unrelated changes in net/http may change the order and default-values of
92*6777b538SAndroid Build Coastguard Worker // HTTP headers, causing WebSocket tests to fail. It is safe to update this
93*6777b538SAndroid Build Coastguard Worker // in that case.
94*6777b538SAndroid Build Coastguard Worker HttpRequestHeaders headers;
95*6777b538SAndroid Build Coastguard Worker std::stringstream request_headers;
96*6777b538SAndroid Build Coastguard Worker
97*6777b538SAndroid Build Coastguard Worker request_headers << base::StringPrintf("GET %s HTTP/1.1\r\n", path.c_str());
98*6777b538SAndroid Build Coastguard Worker headers.SetHeader("Host", host);
99*6777b538SAndroid Build Coastguard Worker headers.SetHeader("Connection", "Upgrade");
100*6777b538SAndroid Build Coastguard Worker headers.SetHeader("Pragma", "no-cache");
101*6777b538SAndroid Build Coastguard Worker headers.SetHeader("Cache-Control", "no-cache");
102*6777b538SAndroid Build Coastguard Worker for (const auto& [key, value] : send_additional_request_headers)
103*6777b538SAndroid Build Coastguard Worker headers.SetHeader(key, value);
104*6777b538SAndroid Build Coastguard Worker headers.SetHeader("Upgrade", "websocket");
105*6777b538SAndroid Build Coastguard Worker headers.SetHeader("Origin", origin.Serialize());
106*6777b538SAndroid Build Coastguard Worker headers.SetHeader("Sec-WebSocket-Version", "13");
107*6777b538SAndroid Build Coastguard Worker if (!headers.HasHeader("User-Agent"))
108*6777b538SAndroid Build Coastguard Worker headers.SetHeader("User-Agent", "");
109*6777b538SAndroid Build Coastguard Worker headers.SetHeader("Accept-Encoding", "gzip, deflate");
110*6777b538SAndroid Build Coastguard Worker headers.SetHeader("Accept-Language", "en-us,fr");
111*6777b538SAndroid Build Coastguard Worker for (const auto& [key, value] : cookies)
112*6777b538SAndroid Build Coastguard Worker headers.SetHeader(key, value);
113*6777b538SAndroid Build Coastguard Worker headers.SetHeader("Sec-WebSocket-Key", "dGhlIHNhbXBsZSBub25jZQ==");
114*6777b538SAndroid Build Coastguard Worker headers.SetHeader("Sec-WebSocket-Extensions",
115*6777b538SAndroid Build Coastguard Worker "permessage-deflate; client_max_window_bits");
116*6777b538SAndroid Build Coastguard Worker for (const auto& [key, value] : extra_headers)
117*6777b538SAndroid Build Coastguard Worker headers.SetHeader(key, value);
118*6777b538SAndroid Build Coastguard Worker
119*6777b538SAndroid Build Coastguard Worker request_headers << headers.ToString();
120*6777b538SAndroid Build Coastguard Worker return request_headers.str();
121*6777b538SAndroid Build Coastguard Worker }
122*6777b538SAndroid Build Coastguard Worker
WebSocketStandardResponse(const std::string & extra_headers)123*6777b538SAndroid Build Coastguard Worker std::string WebSocketStandardResponse(const std::string& extra_headers) {
124*6777b538SAndroid Build Coastguard Worker return base::StrCat(
125*6777b538SAndroid Build Coastguard Worker {"HTTP/1.1 101 Switching Protocols\r\n"
126*6777b538SAndroid Build Coastguard Worker "Upgrade: websocket\r\n"
127*6777b538SAndroid Build Coastguard Worker "Connection: Upgrade\r\n"
128*6777b538SAndroid Build Coastguard Worker "Sec-WebSocket-Accept: s3pPLMBiTxaQ9kYGzzhZRbK+xOo=\r\n",
129*6777b538SAndroid Build Coastguard Worker extra_headers, "\r\n"});
130*6777b538SAndroid Build Coastguard Worker }
131*6777b538SAndroid Build Coastguard Worker
WebSocketCommonTestHeaders()132*6777b538SAndroid Build Coastguard Worker HttpRequestHeaders WebSocketCommonTestHeaders() {
133*6777b538SAndroid Build Coastguard Worker HttpRequestHeaders request_headers;
134*6777b538SAndroid Build Coastguard Worker request_headers.SetHeader("Host", "www.example.org");
135*6777b538SAndroid Build Coastguard Worker request_headers.SetHeader("Connection", "Upgrade");
136*6777b538SAndroid Build Coastguard Worker request_headers.SetHeader("Pragma", "no-cache");
137*6777b538SAndroid Build Coastguard Worker request_headers.SetHeader("Cache-Control", "no-cache");
138*6777b538SAndroid Build Coastguard Worker request_headers.SetHeader("Upgrade", "websocket");
139*6777b538SAndroid Build Coastguard Worker request_headers.SetHeader("Origin", "http://origin.example.org");
140*6777b538SAndroid Build Coastguard Worker request_headers.SetHeader("Sec-WebSocket-Version", "13");
141*6777b538SAndroid Build Coastguard Worker request_headers.SetHeader("User-Agent", "");
142*6777b538SAndroid Build Coastguard Worker request_headers.SetHeader("Accept-Encoding", "gzip, deflate");
143*6777b538SAndroid Build Coastguard Worker request_headers.SetHeader("Accept-Language", "en-us,fr");
144*6777b538SAndroid Build Coastguard Worker return request_headers;
145*6777b538SAndroid Build Coastguard Worker }
146*6777b538SAndroid Build Coastguard Worker
WebSocketHttp2Request(const std::string & path,const std::string & authority,const std::string & origin,const WebSocketExtraHeaders & extra_headers)147*6777b538SAndroid Build Coastguard Worker spdy::Http2HeaderBlock WebSocketHttp2Request(
148*6777b538SAndroid Build Coastguard Worker const std::string& path,
149*6777b538SAndroid Build Coastguard Worker const std::string& authority,
150*6777b538SAndroid Build Coastguard Worker const std::string& origin,
151*6777b538SAndroid Build Coastguard Worker const WebSocketExtraHeaders& extra_headers) {
152*6777b538SAndroid Build Coastguard Worker spdy::Http2HeaderBlock request_headers;
153*6777b538SAndroid Build Coastguard Worker request_headers[spdy::kHttp2MethodHeader] = "CONNECT";
154*6777b538SAndroid Build Coastguard Worker request_headers[spdy::kHttp2AuthorityHeader] = authority;
155*6777b538SAndroid Build Coastguard Worker request_headers[spdy::kHttp2SchemeHeader] = "https";
156*6777b538SAndroid Build Coastguard Worker request_headers[spdy::kHttp2PathHeader] = path;
157*6777b538SAndroid Build Coastguard Worker request_headers[spdy::kHttp2ProtocolHeader] = "websocket";
158*6777b538SAndroid Build Coastguard Worker request_headers["pragma"] = "no-cache";
159*6777b538SAndroid Build Coastguard Worker request_headers["cache-control"] = "no-cache";
160*6777b538SAndroid Build Coastguard Worker request_headers["origin"] = origin;
161*6777b538SAndroid Build Coastguard Worker request_headers["sec-websocket-version"] = "13";
162*6777b538SAndroid Build Coastguard Worker request_headers["user-agent"] = "";
163*6777b538SAndroid Build Coastguard Worker request_headers["accept-encoding"] = "gzip, deflate";
164*6777b538SAndroid Build Coastguard Worker request_headers["accept-language"] = "en-us,fr";
165*6777b538SAndroid Build Coastguard Worker request_headers["sec-websocket-extensions"] =
166*6777b538SAndroid Build Coastguard Worker "permessage-deflate; client_max_window_bits";
167*6777b538SAndroid Build Coastguard Worker for (const auto& header : extra_headers) {
168*6777b538SAndroid Build Coastguard Worker request_headers[base::ToLowerASCII(header.first)] = header.second;
169*6777b538SAndroid Build Coastguard Worker }
170*6777b538SAndroid Build Coastguard Worker return request_headers;
171*6777b538SAndroid Build Coastguard Worker }
172*6777b538SAndroid Build Coastguard Worker
WebSocketHttp2Response(const WebSocketExtraHeaders & extra_headers)173*6777b538SAndroid Build Coastguard Worker spdy::Http2HeaderBlock WebSocketHttp2Response(
174*6777b538SAndroid Build Coastguard Worker const WebSocketExtraHeaders& extra_headers) {
175*6777b538SAndroid Build Coastguard Worker spdy::Http2HeaderBlock response_headers;
176*6777b538SAndroid Build Coastguard Worker response_headers[spdy::kHttp2StatusHeader] = "200";
177*6777b538SAndroid Build Coastguard Worker for (const auto& header : extra_headers) {
178*6777b538SAndroid Build Coastguard Worker response_headers[base::ToLowerASCII(header.first)] = header.second;
179*6777b538SAndroid Build Coastguard Worker }
180*6777b538SAndroid Build Coastguard Worker return response_headers;
181*6777b538SAndroid Build Coastguard Worker }
182*6777b538SAndroid Build Coastguard Worker
183*6777b538SAndroid Build Coastguard Worker struct WebSocketMockClientSocketFactoryMaker::Detail {
184*6777b538SAndroid Build Coastguard Worker std::string expect_written;
185*6777b538SAndroid Build Coastguard Worker std::string return_to_read;
186*6777b538SAndroid Build Coastguard Worker std::vector<MockRead> reads;
187*6777b538SAndroid Build Coastguard Worker MockWrite write;
188*6777b538SAndroid Build Coastguard Worker std::vector<std::unique_ptr<SequencedSocketData>> socket_data_vector;
189*6777b538SAndroid Build Coastguard Worker std::vector<std::unique_ptr<SSLSocketDataProvider>> ssl_socket_data_vector;
190*6777b538SAndroid Build Coastguard Worker MockClientSocketFactory factory;
191*6777b538SAndroid Build Coastguard Worker };
192*6777b538SAndroid Build Coastguard Worker
WebSocketMockClientSocketFactoryMaker()193*6777b538SAndroid Build Coastguard Worker WebSocketMockClientSocketFactoryMaker::WebSocketMockClientSocketFactoryMaker()
194*6777b538SAndroid Build Coastguard Worker : detail_(std::make_unique<Detail>()) {}
195*6777b538SAndroid Build Coastguard Worker
196*6777b538SAndroid Build Coastguard Worker WebSocketMockClientSocketFactoryMaker::
197*6777b538SAndroid Build Coastguard Worker ~WebSocketMockClientSocketFactoryMaker() = default;
198*6777b538SAndroid Build Coastguard Worker
factory()199*6777b538SAndroid Build Coastguard Worker MockClientSocketFactory* WebSocketMockClientSocketFactoryMaker::factory() {
200*6777b538SAndroid Build Coastguard Worker return &detail_->factory;
201*6777b538SAndroid Build Coastguard Worker }
202*6777b538SAndroid Build Coastguard Worker
SetExpectations(const std::string & expect_written,const std::string & return_to_read)203*6777b538SAndroid Build Coastguard Worker void WebSocketMockClientSocketFactoryMaker::SetExpectations(
204*6777b538SAndroid Build Coastguard Worker const std::string& expect_written,
205*6777b538SAndroid Build Coastguard Worker const std::string& return_to_read) {
206*6777b538SAndroid Build Coastguard Worker constexpr size_t kHttpStreamParserBufferSize = 4096;
207*6777b538SAndroid Build Coastguard Worker // We need to extend the lifetime of these strings.
208*6777b538SAndroid Build Coastguard Worker detail_->expect_written = expect_written;
209*6777b538SAndroid Build Coastguard Worker detail_->return_to_read = return_to_read;
210*6777b538SAndroid Build Coastguard Worker int sequence = 0;
211*6777b538SAndroid Build Coastguard Worker detail_->write = MockWrite(SYNCHRONOUS,
212*6777b538SAndroid Build Coastguard Worker detail_->expect_written.data(),
213*6777b538SAndroid Build Coastguard Worker detail_->expect_written.size(),
214*6777b538SAndroid Build Coastguard Worker sequence++);
215*6777b538SAndroid Build Coastguard Worker // HttpStreamParser reads 4KB at a time. We need to take this implementation
216*6777b538SAndroid Build Coastguard Worker // detail into account if |return_to_read| is big enough.
217*6777b538SAndroid Build Coastguard Worker for (size_t place = 0; place < detail_->return_to_read.size();
218*6777b538SAndroid Build Coastguard Worker place += kHttpStreamParserBufferSize) {
219*6777b538SAndroid Build Coastguard Worker detail_->reads.emplace_back(SYNCHRONOUS,
220*6777b538SAndroid Build Coastguard Worker detail_->return_to_read.data() + place,
221*6777b538SAndroid Build Coastguard Worker std::min(detail_->return_to_read.size() - place,
222*6777b538SAndroid Build Coastguard Worker kHttpStreamParserBufferSize),
223*6777b538SAndroid Build Coastguard Worker sequence++);
224*6777b538SAndroid Build Coastguard Worker }
225*6777b538SAndroid Build Coastguard Worker auto socket_data = std::make_unique<SequencedSocketData>(
226*6777b538SAndroid Build Coastguard Worker detail_->reads, base::make_span(&detail_->write, 1u));
227*6777b538SAndroid Build Coastguard Worker socket_data->set_connect_data(MockConnect(SYNCHRONOUS, OK));
228*6777b538SAndroid Build Coastguard Worker AddRawExpectations(std::move(socket_data));
229*6777b538SAndroid Build Coastguard Worker }
230*6777b538SAndroid Build Coastguard Worker
AddRawExpectations(std::unique_ptr<SequencedSocketData> socket_data)231*6777b538SAndroid Build Coastguard Worker void WebSocketMockClientSocketFactoryMaker::AddRawExpectations(
232*6777b538SAndroid Build Coastguard Worker std::unique_ptr<SequencedSocketData> socket_data) {
233*6777b538SAndroid Build Coastguard Worker detail_->factory.AddSocketDataProvider(socket_data.get());
234*6777b538SAndroid Build Coastguard Worker detail_->socket_data_vector.push_back(std::move(socket_data));
235*6777b538SAndroid Build Coastguard Worker }
236*6777b538SAndroid Build Coastguard Worker
AddSSLSocketDataProvider(std::unique_ptr<SSLSocketDataProvider> ssl_socket_data)237*6777b538SAndroid Build Coastguard Worker void WebSocketMockClientSocketFactoryMaker::AddSSLSocketDataProvider(
238*6777b538SAndroid Build Coastguard Worker std::unique_ptr<SSLSocketDataProvider> ssl_socket_data) {
239*6777b538SAndroid Build Coastguard Worker detail_->factory.AddSSLSocketDataProvider(ssl_socket_data.get());
240*6777b538SAndroid Build Coastguard Worker detail_->ssl_socket_data_vector.push_back(std::move(ssl_socket_data));
241*6777b538SAndroid Build Coastguard Worker }
242*6777b538SAndroid Build Coastguard Worker
WebSocketTestURLRequestContextHost()243*6777b538SAndroid Build Coastguard Worker WebSocketTestURLRequestContextHost::WebSocketTestURLRequestContextHost()
244*6777b538SAndroid Build Coastguard Worker : url_request_context_builder_(CreateTestURLRequestContextBuilder()) {
245*6777b538SAndroid Build Coastguard Worker url_request_context_builder_->set_client_socket_factory_for_testing(
246*6777b538SAndroid Build Coastguard Worker maker_.factory());
247*6777b538SAndroid Build Coastguard Worker HttpNetworkSessionParams params;
248*6777b538SAndroid Build Coastguard Worker params.enable_spdy_ping_based_connection_checking = false;
249*6777b538SAndroid Build Coastguard Worker params.enable_quic = false;
250*6777b538SAndroid Build Coastguard Worker params.disable_idle_sockets_close_on_memory_pressure = false;
251*6777b538SAndroid Build Coastguard Worker url_request_context_builder_->set_http_network_session_params(params);
252*6777b538SAndroid Build Coastguard Worker }
253*6777b538SAndroid Build Coastguard Worker
254*6777b538SAndroid Build Coastguard Worker WebSocketTestURLRequestContextHost::~WebSocketTestURLRequestContextHost() =
255*6777b538SAndroid Build Coastguard Worker default;
256*6777b538SAndroid Build Coastguard Worker
AddRawExpectations(std::unique_ptr<SequencedSocketData> socket_data)257*6777b538SAndroid Build Coastguard Worker void WebSocketTestURLRequestContextHost::AddRawExpectations(
258*6777b538SAndroid Build Coastguard Worker std::unique_ptr<SequencedSocketData> socket_data) {
259*6777b538SAndroid Build Coastguard Worker maker_.AddRawExpectations(std::move(socket_data));
260*6777b538SAndroid Build Coastguard Worker }
261*6777b538SAndroid Build Coastguard Worker
AddSSLSocketDataProvider(std::unique_ptr<SSLSocketDataProvider> ssl_socket_data)262*6777b538SAndroid Build Coastguard Worker void WebSocketTestURLRequestContextHost::AddSSLSocketDataProvider(
263*6777b538SAndroid Build Coastguard Worker std::unique_ptr<SSLSocketDataProvider> ssl_socket_data) {
264*6777b538SAndroid Build Coastguard Worker maker_.AddSSLSocketDataProvider(std::move(ssl_socket_data));
265*6777b538SAndroid Build Coastguard Worker }
266*6777b538SAndroid Build Coastguard Worker
SetProxyConfig(const std::string & proxy_rules)267*6777b538SAndroid Build Coastguard Worker void WebSocketTestURLRequestContextHost::SetProxyConfig(
268*6777b538SAndroid Build Coastguard Worker const std::string& proxy_rules) {
269*6777b538SAndroid Build Coastguard Worker DCHECK(!url_request_context_);
270*6777b538SAndroid Build Coastguard Worker auto proxy_resolution_service =
271*6777b538SAndroid Build Coastguard Worker ConfiguredProxyResolutionService::CreateFixedForTest(
272*6777b538SAndroid Build Coastguard Worker proxy_rules, TRAFFIC_ANNOTATION_FOR_TESTS);
273*6777b538SAndroid Build Coastguard Worker url_request_context_builder_->set_proxy_resolution_service(
274*6777b538SAndroid Build Coastguard Worker std::move(proxy_resolution_service));
275*6777b538SAndroid Build Coastguard Worker }
276*6777b538SAndroid Build Coastguard Worker
OnURLRequestConnected(URLRequest * request,const TransportInfo & info)277*6777b538SAndroid Build Coastguard Worker void DummyConnectDelegate::OnURLRequestConnected(URLRequest* request,
278*6777b538SAndroid Build Coastguard Worker const TransportInfo& info) {}
279*6777b538SAndroid Build Coastguard Worker
OnAuthRequired(const AuthChallengeInfo & auth_info,scoped_refptr<HttpResponseHeaders> response_headers,const IPEndPoint & host_port_pair,base::OnceCallback<void (const AuthCredentials *)> callback,std::optional<AuthCredentials> * credentials)280*6777b538SAndroid Build Coastguard Worker int DummyConnectDelegate::OnAuthRequired(
281*6777b538SAndroid Build Coastguard Worker const AuthChallengeInfo& auth_info,
282*6777b538SAndroid Build Coastguard Worker scoped_refptr<HttpResponseHeaders> response_headers,
283*6777b538SAndroid Build Coastguard Worker const IPEndPoint& host_port_pair,
284*6777b538SAndroid Build Coastguard Worker base::OnceCallback<void(const AuthCredentials*)> callback,
285*6777b538SAndroid Build Coastguard Worker std::optional<AuthCredentials>* credentials) {
286*6777b538SAndroid Build Coastguard Worker return OK;
287*6777b538SAndroid Build Coastguard Worker }
288*6777b538SAndroid Build Coastguard Worker
GetURLRequestContext()289*6777b538SAndroid Build Coastguard Worker URLRequestContext* WebSocketTestURLRequestContextHost::GetURLRequestContext() {
290*6777b538SAndroid Build Coastguard Worker if (!url_request_context_) {
291*6777b538SAndroid Build Coastguard Worker url_request_context_builder_->set_network_delegate(
292*6777b538SAndroid Build Coastguard Worker std::make_unique<TestNetworkDelegate>());
293*6777b538SAndroid Build Coastguard Worker url_request_context_ = url_request_context_builder_->Build();
294*6777b538SAndroid Build Coastguard Worker url_request_context_builder_ = nullptr;
295*6777b538SAndroid Build Coastguard Worker }
296*6777b538SAndroid Build Coastguard Worker return url_request_context_.get();
297*6777b538SAndroid Build Coastguard Worker }
298*6777b538SAndroid Build Coastguard Worker
OnBasicHandshakeStreamCreated(WebSocketBasicHandshakeStream * handshake_stream)299*6777b538SAndroid Build Coastguard Worker void TestWebSocketStreamRequestAPI::OnBasicHandshakeStreamCreated(
300*6777b538SAndroid Build Coastguard Worker WebSocketBasicHandshakeStream* handshake_stream) {
301*6777b538SAndroid Build Coastguard Worker handshake_stream->SetWebSocketKeyForTesting("dGhlIHNhbXBsZSBub25jZQ==");
302*6777b538SAndroid Build Coastguard Worker }
303*6777b538SAndroid Build Coastguard Worker
OnHttp2HandshakeStreamCreated(WebSocketHttp2HandshakeStream * handshake_stream)304*6777b538SAndroid Build Coastguard Worker void TestWebSocketStreamRequestAPI::OnHttp2HandshakeStreamCreated(
305*6777b538SAndroid Build Coastguard Worker WebSocketHttp2HandshakeStream* handshake_stream) {}
306*6777b538SAndroid Build Coastguard Worker
OnHttp3HandshakeStreamCreated(WebSocketHttp3HandshakeStream * handshake_stream)307*6777b538SAndroid Build Coastguard Worker void TestWebSocketStreamRequestAPI::OnHttp3HandshakeStreamCreated(
308*6777b538SAndroid Build Coastguard Worker WebSocketHttp3HandshakeStream* handshake_stream) {}
309*6777b538SAndroid Build Coastguard Worker } // namespace net
310