Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(617)

Side by Side Diff: net/http/http_network_transaction_spdy21_unittest.cc

Issue 9791044: Revert 129277 - Revert 127893 - Attempting to re-land the feature. (Closed) Base URL: svn://svn.chromium.org/chrome/branches/1081/src/
Patch Set: Created 8 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « no previous file | net/http/http_network_transaction_spdy2_unittest.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
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/http/http_network_transaction.h" 5 #include "net/http/http_network_transaction.h"
6 6
7 #include <math.h> // ceil 7 #include <math.h> // ceil
8 #include <stdarg.h> 8 #include <stdarg.h>
9 #include <string> 9 #include <string>
10 #include <vector> 10 #include <vector>
(...skipping 9359 matching lines...) Expand 10 before | Expand all | Expand 10 after
9370 data_writes2, arraysize(data_writes2)); 9370 data_writes2, arraysize(data_writes2));
9371 StaticSocketDataProvider* data[] = { &data1, &data2 }; 9371 StaticSocketDataProvider* data[] = { &data1, &data2 };
9372 9372
9373 SimpleGetHelperResult out = SimpleGetHelperForData(data, arraysize(data)); 9373 SimpleGetHelperResult out = SimpleGetHelperForData(data, arraysize(data));
9374 9374
9375 EXPECT_EQ(OK, out.rv); 9375 EXPECT_EQ(OK, out.rv);
9376 EXPECT_EQ("HTTP/1.0 200 OK", out.status_line); 9376 EXPECT_EQ("HTTP/1.0 200 OK", out.status_line);
9377 EXPECT_EQ("hello world", out.response_data); 9377 EXPECT_EQ("hello world", out.response_data);
9378 } 9378 }
9379 9379
9380 TEST_F(HttpNetworkTransactionSpdy21Test, CloseIdleSpdySessionToOpenNewOne) {
9381 HttpStreamFactory::SetNextProtos(SpdyNextProtos());
9382 int old_max_sockets_per_group =
9383 ClientSocketPoolManager::max_sockets_per_group(
9384 HttpNetworkSession::NORMAL_SOCKET_POOL);
9385 int old_max_sockets_per_proxy_server =
9386 ClientSocketPoolManager::max_sockets_per_proxy_server(
9387 HttpNetworkSession::NORMAL_SOCKET_POOL);
9388 int old_max_sockets_per_pool =
9389 ClientSocketPoolManager::max_sockets_per_pool(
9390 HttpNetworkSession::NORMAL_SOCKET_POOL);
9391 ClientSocketPoolManager::set_max_sockets_per_group(
9392 HttpNetworkSession::NORMAL_SOCKET_POOL, 1);
9393 ClientSocketPoolManager::set_max_sockets_per_proxy_server(
9394 HttpNetworkSession::NORMAL_SOCKET_POOL, 1);
9395 ClientSocketPoolManager::set_max_sockets_per_pool(
9396 HttpNetworkSession::NORMAL_SOCKET_POOL, 1);
9397
9398 // Use two different hosts with different IPs so they don't get pooled.
9399 SessionDependencies session_deps;
9400 session_deps.host_resolver->rules()->AddRule("a.com", "10.0.0.1");
9401 session_deps.host_resolver->rules()->AddRule("b.com", "10.0.0.2");
9402 scoped_refptr<HttpNetworkSession> session(CreateSession(&session_deps));
9403
9404 SSLSocketDataProvider ssl1(ASYNC, OK);
9405 ssl1.SetNextProto(SSLClientSocket::kProtoSPDY21);
9406 SSLSocketDataProvider ssl2(ASYNC, OK);
9407 ssl2.SetNextProto(SSLClientSocket::kProtoSPDY21);
9408 session_deps.socket_factory.AddSSLSocketDataProvider(&ssl1);
9409 session_deps.socket_factory.AddSSLSocketDataProvider(&ssl2);
9410
9411 scoped_ptr<SpdyFrame> host1_req(ConstructSpdyGet(
9412 "https://www.a.com", false, 1, LOWEST));
9413 MockWrite spdy1_writes[] = {
9414 CreateMockWrite(*host1_req, 1),
9415 };
9416 scoped_ptr<SpdyFrame> host1_resp(ConstructSpdyGetSynReply(NULL, 0, 1));
9417 scoped_ptr<SpdyFrame> host1_resp_body(ConstructSpdyBodyFrame(1, true));
9418 MockRead spdy1_reads[] = {
9419 CreateMockRead(*host1_resp, 2),
9420 CreateMockRead(*host1_resp_body, 3),
9421 MockRead(ASYNC, ERR_IO_PENDING, 4),
9422 };
9423
9424 scoped_ptr<OrderedSocketData> spdy1_data(
9425 new OrderedSocketData(
9426 spdy1_reads, arraysize(spdy1_reads),
9427 spdy1_writes, arraysize(spdy1_writes)));
9428 session_deps.socket_factory.AddSocketDataProvider(spdy1_data.get());
9429
9430 scoped_ptr<SpdyFrame> host2_req(ConstructSpdyGet(
9431 "https://www.b.com", false, 1, LOWEST));
9432 MockWrite spdy2_writes[] = {
9433 CreateMockWrite(*host2_req, 1),
9434 };
9435 scoped_ptr<SpdyFrame> host2_resp(ConstructSpdyGetSynReply(NULL, 0, 1));
9436 scoped_ptr<SpdyFrame> host2_resp_body(ConstructSpdyBodyFrame(1, true));
9437 MockRead spdy2_reads[] = {
9438 CreateMockRead(*host2_resp, 2),
9439 CreateMockRead(*host2_resp_body, 3),
9440 MockRead(ASYNC, ERR_IO_PENDING, 4),
9441 };
9442
9443 scoped_ptr<OrderedSocketData> spdy2_data(
9444 new OrderedSocketData(
9445 spdy2_reads, arraysize(spdy2_reads),
9446 spdy2_writes, arraysize(spdy2_writes)));
9447 session_deps.socket_factory.AddSocketDataProvider(spdy2_data.get());
9448
9449 MockWrite http_write[] = {
9450 MockWrite("GET / HTTP/1.1\r\n"
9451 "Host: www.a.com\r\n"
9452 "Connection: keep-alive\r\n\r\n"),
9453 };
9454
9455 MockRead http_read[] = {
9456 MockRead("HTTP/1.1 200 OK\r\n"),
9457 MockRead("Content-Type: text/html; charset=iso-8859-1\r\n"),
9458 MockRead("Content-Length: 6\r\n\r\n"),
9459 MockRead("hello!"),
9460 };
9461 StaticSocketDataProvider http_data(http_read, arraysize(http_read),
9462 http_write, arraysize(http_write));
9463 session_deps.socket_factory.AddSocketDataProvider(&http_data);
9464
9465 HostPortPair host_port_pair_a("www.a.com", 443);
9466 HostPortProxyPair host_port_proxy_pair_a(
9467 host_port_pair_a, ProxyServer::Direct());
9468 EXPECT_FALSE(
9469 session->spdy_session_pool()->HasSession(host_port_proxy_pair_a));
9470
9471 TestCompletionCallback callback;
9472 HttpRequestInfo request1;
9473 request1.method = "GET";
9474 request1.url = GURL("https://www.a.com/");
9475 request1.load_flags = 0;
9476 scoped_ptr<HttpNetworkTransaction> trans(new HttpNetworkTransaction(session));
9477
9478 int rv = trans->Start(&request1, callback.callback(), BoundNetLog());
9479 EXPECT_EQ(ERR_IO_PENDING, rv);
9480 EXPECT_EQ(OK, callback.WaitForResult());
9481
9482 const HttpResponseInfo* response = trans->GetResponseInfo();
9483 ASSERT_TRUE(response != NULL);
9484 ASSERT_TRUE(response->headers != NULL);
9485 EXPECT_EQ("HTTP/1.1 200 OK", response->headers->GetStatusLine());
9486 EXPECT_TRUE(response->was_fetched_via_spdy);
9487 EXPECT_TRUE(response->was_npn_negotiated);
9488
9489 std::string response_data;
9490 ASSERT_EQ(OK, ReadTransaction(trans.get(), &response_data));
9491 EXPECT_EQ("hello!", response_data);
9492 trans.reset();
9493 EXPECT_TRUE(
9494 session->spdy_session_pool()->HasSession(host_port_proxy_pair_a));
9495
9496 HostPortPair host_port_pair_b("www.b.com", 443);
9497 HostPortProxyPair host_port_proxy_pair_b(
9498 host_port_pair_b, ProxyServer::Direct());
9499 EXPECT_FALSE(
9500 session->spdy_session_pool()->HasSession(host_port_proxy_pair_b));
9501 HttpRequestInfo request2;
9502 request2.method = "GET";
9503 request2.url = GURL("https://www.b.com/");
9504 request2.load_flags = 0;
9505 trans.reset(new HttpNetworkTransaction(session));
9506
9507 rv = trans->Start(&request2, callback.callback(), BoundNetLog());
9508 EXPECT_EQ(ERR_IO_PENDING, rv);
9509 EXPECT_EQ(OK, callback.WaitForResult());
9510
9511 response = trans->GetResponseInfo();
9512 ASSERT_TRUE(response != NULL);
9513 ASSERT_TRUE(response->headers != NULL);
9514 EXPECT_EQ("HTTP/1.1 200 OK", response->headers->GetStatusLine());
9515 EXPECT_TRUE(response->was_fetched_via_spdy);
9516 EXPECT_TRUE(response->was_npn_negotiated);
9517 ASSERT_EQ(OK, ReadTransaction(trans.get(), &response_data));
9518 EXPECT_EQ("hello!", response_data);
9519 EXPECT_FALSE(
9520 session->spdy_session_pool()->HasSession(host_port_proxy_pair_a));
9521 EXPECT_TRUE(
9522 session->spdy_session_pool()->HasSession(host_port_proxy_pair_b));
9523
9524 HostPortPair host_port_pair_a1("www.a.com", 80);
9525 HostPortProxyPair host_port_proxy_pair_a1(
9526 host_port_pair_a1, ProxyServer::Direct());
9527 EXPECT_FALSE(
9528 session->spdy_session_pool()->HasSession(host_port_proxy_pair_a1));
9529 HttpRequestInfo request3;
9530 request3.method = "GET";
9531 request3.url = GURL("http://www.a.com/");
9532 request3.load_flags = 0;
9533 trans.reset(new HttpNetworkTransaction(session));
9534
9535 rv = trans->Start(&request3, callback.callback(), BoundNetLog());
9536 EXPECT_EQ(ERR_IO_PENDING, rv);
9537 EXPECT_EQ(OK, callback.WaitForResult());
9538
9539 response = trans->GetResponseInfo();
9540 ASSERT_TRUE(response != NULL);
9541 ASSERT_TRUE(response->headers != NULL);
9542 EXPECT_EQ("HTTP/1.1 200 OK", response->headers->GetStatusLine());
9543 EXPECT_FALSE(response->was_fetched_via_spdy);
9544 EXPECT_FALSE(response->was_npn_negotiated);
9545 ASSERT_EQ(OK, ReadTransaction(trans.get(), &response_data));
9546 EXPECT_EQ("hello!", response_data);
9547 EXPECT_FALSE(
9548 session->spdy_session_pool()->HasSession(host_port_proxy_pair_a));
9549 EXPECT_FALSE(
9550 session->spdy_session_pool()->HasSession(host_port_proxy_pair_b));
9551
9552 HttpStreamFactory::SetNextProtos(std::vector<std::string>());
9553 ClientSocketPoolManager::set_max_sockets_per_pool(
9554 HttpNetworkSession::NORMAL_SOCKET_POOL, old_max_sockets_per_pool);
9555 ClientSocketPoolManager::set_max_sockets_per_proxy_server(
9556 HttpNetworkSession::NORMAL_SOCKET_POOL, old_max_sockets_per_proxy_server);
9557 ClientSocketPoolManager::set_max_sockets_per_group(
9558 HttpNetworkSession::NORMAL_SOCKET_POOL, old_max_sockets_per_group);
9559 }
9560
9380 } // namespace net 9561 } // namespace net
OLDNEW
« no previous file with comments | « no previous file | net/http/http_network_transaction_spdy2_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698