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