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

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

Issue 9861032: Close idle connections / SPDY sessions when needed (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Rebase 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
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 9344 matching lines...) Expand 10 before | Expand all | Expand 10 after
9355 data_writes2, arraysize(data_writes2)); 9355 data_writes2, arraysize(data_writes2));
9356 StaticSocketDataProvider* data[] = { &data1, &data2 }; 9356 StaticSocketDataProvider* data[] = { &data1, &data2 };
9357 9357
9358 SimpleGetHelperResult out = SimpleGetHelperForData(data, arraysize(data)); 9358 SimpleGetHelperResult out = SimpleGetHelperForData(data, arraysize(data));
9359 9359
9360 EXPECT_EQ(OK, out.rv); 9360 EXPECT_EQ(OK, out.rv);
9361 EXPECT_EQ("HTTP/1.0 200 OK", out.status_line); 9361 EXPECT_EQ("HTTP/1.0 200 OK", out.status_line);
9362 EXPECT_EQ("hello world", out.response_data); 9362 EXPECT_EQ("hello world", out.response_data);
9363 } 9363 }
9364 9364
9365 TEST_F(HttpNetworkTransactionSpdy2Test, CloseIdleSpdySessionToOpenNewOne) {
9366 HttpStreamFactory::SetNextProtos(SpdyNextProtos());
9367 int old_max_sockets_per_group =
9368 ClientSocketPoolManager::max_sockets_per_group(
9369 HttpNetworkSession::NORMAL_SOCKET_POOL);
9370 int old_max_sockets_per_proxy_server =
9371 ClientSocketPoolManager::max_sockets_per_proxy_server(
9372 HttpNetworkSession::NORMAL_SOCKET_POOL);
9373 int old_max_sockets_per_pool =
9374 ClientSocketPoolManager::max_sockets_per_pool(
9375 HttpNetworkSession::NORMAL_SOCKET_POOL);
9376 ClientSocketPoolManager::set_max_sockets_per_group(
9377 HttpNetworkSession::NORMAL_SOCKET_POOL, 1);
9378 ClientSocketPoolManager::set_max_sockets_per_proxy_server(
9379 HttpNetworkSession::NORMAL_SOCKET_POOL, 1);
9380 ClientSocketPoolManager::set_max_sockets_per_pool(
9381 HttpNetworkSession::NORMAL_SOCKET_POOL, 1);
9382
9383 // Use two different hosts with different IPs so they don't get pooled.
9384 SessionDependencies session_deps;
9385 session_deps.host_resolver->rules()->AddRule("a.com", "10.0.0.1");
9386 session_deps.host_resolver->rules()->AddRule("b.com", "10.0.0.2");
9387 scoped_refptr<HttpNetworkSession> session(CreateSession(&session_deps));
9388
9389 SSLSocketDataProvider ssl1(ASYNC, OK);
9390 ssl1.SetNextProto(kProtoSPDY2);
9391 SSLSocketDataProvider ssl2(ASYNC, OK);
9392 ssl2.SetNextProto(kProtoSPDY2);
9393 session_deps.socket_factory.AddSSLSocketDataProvider(&ssl1);
9394 session_deps.socket_factory.AddSSLSocketDataProvider(&ssl2);
9395
9396 scoped_ptr<SpdyFrame> host1_req(ConstructSpdyGet(
9397 "https://www.a.com", false, 1, LOWEST));
9398 MockWrite spdy1_writes[] = {
9399 CreateMockWrite(*host1_req, 1),
9400 };
9401 scoped_ptr<SpdyFrame> host1_resp(ConstructSpdyGetSynReply(NULL, 0, 1));
9402 scoped_ptr<SpdyFrame> host1_resp_body(ConstructSpdyBodyFrame(1, true));
9403 MockRead spdy1_reads[] = {
9404 CreateMockRead(*host1_resp, 2),
9405 CreateMockRead(*host1_resp_body, 3),
9406 MockRead(ASYNC, ERR_IO_PENDING, 4),
9407 };
9408
9409 scoped_ptr<OrderedSocketData> spdy1_data(
9410 new OrderedSocketData(
9411 spdy1_reads, arraysize(spdy1_reads),
9412 spdy1_writes, arraysize(spdy1_writes)));
9413 session_deps.socket_factory.AddSocketDataProvider(spdy1_data.get());
9414
9415 scoped_ptr<SpdyFrame> host2_req(ConstructSpdyGet(
9416 "https://www.b.com", false, 1, LOWEST));
9417 MockWrite spdy2_writes[] = {
9418 CreateMockWrite(*host2_req, 1),
9419 };
9420 scoped_ptr<SpdyFrame> host2_resp(ConstructSpdyGetSynReply(NULL, 0, 1));
9421 scoped_ptr<SpdyFrame> host2_resp_body(ConstructSpdyBodyFrame(1, true));
9422 MockRead spdy2_reads[] = {
9423 CreateMockRead(*host2_resp, 2),
9424 CreateMockRead(*host2_resp_body, 3),
9425 MockRead(ASYNC, ERR_IO_PENDING, 4),
9426 };
9427
9428 scoped_ptr<OrderedSocketData> spdy2_data(
9429 new OrderedSocketData(
9430 spdy2_reads, arraysize(spdy2_reads),
9431 spdy2_writes, arraysize(spdy2_writes)));
9432 session_deps.socket_factory.AddSocketDataProvider(spdy2_data.get());
9433
9434 MockWrite http_write[] = {
9435 MockWrite("GET / HTTP/1.1\r\n"
9436 "Host: www.a.com\r\n"
9437 "Connection: keep-alive\r\n\r\n"),
9438 };
9439
9440 MockRead http_read[] = {
9441 MockRead("HTTP/1.1 200 OK\r\n"),
9442 MockRead("Content-Type: text/html; charset=iso-8859-1\r\n"),
9443 MockRead("Content-Length: 6\r\n\r\n"),
9444 MockRead("hello!"),
9445 };
9446 StaticSocketDataProvider http_data(http_read, arraysize(http_read),
9447 http_write, arraysize(http_write));
9448 session_deps.socket_factory.AddSocketDataProvider(&http_data);
9449
9450 HostPortPair host_port_pair_a("www.a.com", 443);
9451 HostPortProxyPair host_port_proxy_pair_a(
9452 host_port_pair_a, ProxyServer::Direct());
9453 EXPECT_FALSE(
9454 session->spdy_session_pool()->HasSession(host_port_proxy_pair_a));
9455
9456 TestCompletionCallback callback;
9457 HttpRequestInfo request1;
9458 request1.method = "GET";
9459 request1.url = GURL("https://www.a.com/");
9460 request1.load_flags = 0;
9461 scoped_ptr<HttpNetworkTransaction> trans(new HttpNetworkTransaction(session));
9462
9463 int rv = trans->Start(&request1, callback.callback(), BoundNetLog());
9464 EXPECT_EQ(ERR_IO_PENDING, rv);
9465 EXPECT_EQ(OK, callback.WaitForResult());
9466
9467 const HttpResponseInfo* response = trans->GetResponseInfo();
9468 ASSERT_TRUE(response != NULL);
9469 ASSERT_TRUE(response->headers != NULL);
9470 EXPECT_EQ("HTTP/1.1 200 OK", response->headers->GetStatusLine());
9471 EXPECT_TRUE(response->was_fetched_via_spdy);
9472 EXPECT_TRUE(response->was_npn_negotiated);
9473
9474 std::string response_data;
9475 ASSERT_EQ(OK, ReadTransaction(trans.get(), &response_data));
9476 EXPECT_EQ("hello!", response_data);
9477 trans.reset();
9478 EXPECT_TRUE(
9479 session->spdy_session_pool()->HasSession(host_port_proxy_pair_a));
9480
9481 HostPortPair host_port_pair_b("www.b.com", 443);
9482 HostPortProxyPair host_port_proxy_pair_b(
9483 host_port_pair_b, ProxyServer::Direct());
9484 EXPECT_FALSE(
9485 session->spdy_session_pool()->HasSession(host_port_proxy_pair_b));
9486 HttpRequestInfo request2;
9487 request2.method = "GET";
9488 request2.url = GURL("https://www.b.com/");
9489 request2.load_flags = 0;
9490 trans.reset(new HttpNetworkTransaction(session));
9491
9492 rv = trans->Start(&request2, callback.callback(), BoundNetLog());
9493 EXPECT_EQ(ERR_IO_PENDING, rv);
9494 EXPECT_EQ(OK, callback.WaitForResult());
9495
9496 response = trans->GetResponseInfo();
9497 ASSERT_TRUE(response != NULL);
9498 ASSERT_TRUE(response->headers != NULL);
9499 EXPECT_EQ("HTTP/1.1 200 OK", response->headers->GetStatusLine());
9500 EXPECT_TRUE(response->was_fetched_via_spdy);
9501 EXPECT_TRUE(response->was_npn_negotiated);
9502 ASSERT_EQ(OK, ReadTransaction(trans.get(), &response_data));
9503 EXPECT_EQ("hello!", response_data);
9504 EXPECT_FALSE(
9505 session->spdy_session_pool()->HasSession(host_port_proxy_pair_a));
9506 EXPECT_TRUE(
9507 session->spdy_session_pool()->HasSession(host_port_proxy_pair_b));
9508
9509 HostPortPair host_port_pair_a1("www.a.com", 80);
9510 HostPortProxyPair host_port_proxy_pair_a1(
9511 host_port_pair_a1, ProxyServer::Direct());
9512 EXPECT_FALSE(
9513 session->spdy_session_pool()->HasSession(host_port_proxy_pair_a1));
9514 HttpRequestInfo request3;
9515 request3.method = "GET";
9516 request3.url = GURL("http://www.a.com/");
9517 request3.load_flags = 0;
9518 trans.reset(new HttpNetworkTransaction(session));
9519
9520 rv = trans->Start(&request3, callback.callback(), BoundNetLog());
9521 EXPECT_EQ(ERR_IO_PENDING, rv);
9522 EXPECT_EQ(OK, callback.WaitForResult());
9523
9524 response = trans->GetResponseInfo();
9525 ASSERT_TRUE(response != NULL);
9526 ASSERT_TRUE(response->headers != NULL);
9527 EXPECT_EQ("HTTP/1.1 200 OK", response->headers->GetStatusLine());
9528 EXPECT_FALSE(response->was_fetched_via_spdy);
9529 EXPECT_FALSE(response->was_npn_negotiated);
9530 ASSERT_EQ(OK, ReadTransaction(trans.get(), &response_data));
9531 EXPECT_EQ("hello!", response_data);
9532 EXPECT_FALSE(
9533 session->spdy_session_pool()->HasSession(host_port_proxy_pair_a));
9534 EXPECT_FALSE(
9535 session->spdy_session_pool()->HasSession(host_port_proxy_pair_b));
9536
9537 HttpStreamFactory::SetNextProtos(std::vector<std::string>());
9538 ClientSocketPoolManager::set_max_sockets_per_pool(
9539 HttpNetworkSession::NORMAL_SOCKET_POOL, old_max_sockets_per_pool);
9540 ClientSocketPoolManager::set_max_sockets_per_proxy_server(
9541 HttpNetworkSession::NORMAL_SOCKET_POOL, old_max_sockets_per_proxy_server);
9542 ClientSocketPoolManager::set_max_sockets_per_group(
9543 HttpNetworkSession::NORMAL_SOCKET_POOL, old_max_sockets_per_group);
9544 }
9545
9365 } // namespace net 9546 } // namespace net
OLDNEW
« no previous file with comments | « net/http/http_network_transaction_spdy21_unittest.cc ('k') | net/http/http_network_transaction_spdy3_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698