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

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

Issue 10006036: Reverting again ... More crashes, and the instrumentation did not appear to help (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/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 9534 matching lines...) Expand 10 before | Expand all | Expand 10 after
9545 data_writes2, arraysize(data_writes2)); 9545 data_writes2, arraysize(data_writes2));
9546 StaticSocketDataProvider* data[] = { &data1, &data2 }; 9546 StaticSocketDataProvider* data[] = { &data1, &data2 };
9547 9547
9548 SimpleGetHelperResult out = SimpleGetHelperForData(data, arraysize(data)); 9548 SimpleGetHelperResult out = SimpleGetHelperForData(data, arraysize(data));
9549 9549
9550 EXPECT_EQ(OK, out.rv); 9550 EXPECT_EQ(OK, out.rv);
9551 EXPECT_EQ("HTTP/1.0 200 OK", out.status_line); 9551 EXPECT_EQ("HTTP/1.0 200 OK", out.status_line);
9552 EXPECT_EQ("hello world", out.response_data); 9552 EXPECT_EQ("hello world", out.response_data);
9553 } 9553 }
9554 9554
9555 TEST_F(HttpNetworkTransactionSpdy21Test, CloseIdleSpdySessionToOpenNewOne) {
9556 HttpStreamFactory::SetNextProtos(SpdyNextProtos());
9557 int old_max_sockets_per_group =
9558 ClientSocketPoolManager::max_sockets_per_group(
9559 HttpNetworkSession::NORMAL_SOCKET_POOL);
9560 int old_max_sockets_per_proxy_server =
9561 ClientSocketPoolManager::max_sockets_per_proxy_server(
9562 HttpNetworkSession::NORMAL_SOCKET_POOL);
9563 int old_max_sockets_per_pool =
9564 ClientSocketPoolManager::max_sockets_per_pool(
9565 HttpNetworkSession::NORMAL_SOCKET_POOL);
9566 ClientSocketPoolManager::set_max_sockets_per_group(
9567 HttpNetworkSession::NORMAL_SOCKET_POOL, 1);
9568 ClientSocketPoolManager::set_max_sockets_per_proxy_server(
9569 HttpNetworkSession::NORMAL_SOCKET_POOL, 1);
9570 ClientSocketPoolManager::set_max_sockets_per_pool(
9571 HttpNetworkSession::NORMAL_SOCKET_POOL, 1);
9572
9573 // Use two different hosts with different IPs so they don't get pooled.
9574 SessionDependencies session_deps;
9575 session_deps.host_resolver->rules()->AddRule("a.com", "10.0.0.1");
9576 session_deps.host_resolver->rules()->AddRule("b.com", "10.0.0.2");
9577 scoped_refptr<HttpNetworkSession> session(CreateSession(&session_deps));
9578
9579 SSLSocketDataProvider ssl1(ASYNC, OK);
9580 ssl1.SetNextProto(kProtoSPDY21);
9581 SSLSocketDataProvider ssl2(ASYNC, OK);
9582 ssl2.SetNextProto(kProtoSPDY21);
9583 session_deps.socket_factory.AddSSLSocketDataProvider(&ssl1);
9584 session_deps.socket_factory.AddSSLSocketDataProvider(&ssl2);
9585
9586 scoped_ptr<SpdyFrame> host1_req(ConstructSpdyGet(
9587 "https://www.a.com", false, 1, LOWEST));
9588 MockWrite spdy1_writes[] = {
9589 CreateMockWrite(*host1_req, 1),
9590 };
9591 scoped_ptr<SpdyFrame> host1_resp(ConstructSpdyGetSynReply(NULL, 0, 1));
9592 scoped_ptr<SpdyFrame> host1_resp_body(ConstructSpdyBodyFrame(1, true));
9593 MockRead spdy1_reads[] = {
9594 CreateMockRead(*host1_resp, 2),
9595 CreateMockRead(*host1_resp_body, 3),
9596 MockRead(ASYNC, ERR_IO_PENDING, 4),
9597 };
9598
9599 scoped_ptr<OrderedSocketData> spdy1_data(
9600 new OrderedSocketData(
9601 spdy1_reads, arraysize(spdy1_reads),
9602 spdy1_writes, arraysize(spdy1_writes)));
9603 session_deps.socket_factory.AddSocketDataProvider(spdy1_data.get());
9604
9605 scoped_ptr<SpdyFrame> host2_req(ConstructSpdyGet(
9606 "https://www.b.com", false, 1, LOWEST));
9607 MockWrite spdy2_writes[] = {
9608 CreateMockWrite(*host2_req, 1),
9609 };
9610 scoped_ptr<SpdyFrame> host2_resp(ConstructSpdyGetSynReply(NULL, 0, 1));
9611 scoped_ptr<SpdyFrame> host2_resp_body(ConstructSpdyBodyFrame(1, true));
9612 MockRead spdy2_reads[] = {
9613 CreateMockRead(*host2_resp, 2),
9614 CreateMockRead(*host2_resp_body, 3),
9615 MockRead(ASYNC, ERR_IO_PENDING, 4),
9616 };
9617
9618 scoped_ptr<OrderedSocketData> spdy2_data(
9619 new OrderedSocketData(
9620 spdy2_reads, arraysize(spdy2_reads),
9621 spdy2_writes, arraysize(spdy2_writes)));
9622 session_deps.socket_factory.AddSocketDataProvider(spdy2_data.get());
9623
9624 MockWrite http_write[] = {
9625 MockWrite("GET / HTTP/1.1\r\n"
9626 "Host: www.a.com\r\n"
9627 "Connection: keep-alive\r\n\r\n"),
9628 };
9629
9630 MockRead http_read[] = {
9631 MockRead("HTTP/1.1 200 OK\r\n"),
9632 MockRead("Content-Type: text/html; charset=iso-8859-1\r\n"),
9633 MockRead("Content-Length: 6\r\n\r\n"),
9634 MockRead("hello!"),
9635 };
9636 StaticSocketDataProvider http_data(http_read, arraysize(http_read),
9637 http_write, arraysize(http_write));
9638 session_deps.socket_factory.AddSocketDataProvider(&http_data);
9639
9640 HostPortPair host_port_pair_a("www.a.com", 443);
9641 HostPortProxyPair host_port_proxy_pair_a(
9642 host_port_pair_a, ProxyServer::Direct());
9643 EXPECT_FALSE(
9644 session->spdy_session_pool()->HasSession(host_port_proxy_pair_a));
9645
9646 TestCompletionCallback callback;
9647 HttpRequestInfo request1;
9648 request1.method = "GET";
9649 request1.url = GURL("https://www.a.com/");
9650 request1.load_flags = 0;
9651 scoped_ptr<HttpNetworkTransaction> trans(new HttpNetworkTransaction(session));
9652
9653 int rv = trans->Start(&request1, callback.callback(), BoundNetLog());
9654 EXPECT_EQ(ERR_IO_PENDING, rv);
9655 EXPECT_EQ(OK, callback.WaitForResult());
9656
9657 const HttpResponseInfo* response = trans->GetResponseInfo();
9658 ASSERT_TRUE(response != NULL);
9659 ASSERT_TRUE(response->headers != NULL);
9660 EXPECT_EQ("HTTP/1.1 200 OK", response->headers->GetStatusLine());
9661 EXPECT_TRUE(response->was_fetched_via_spdy);
9662 EXPECT_TRUE(response->was_npn_negotiated);
9663
9664 std::string response_data;
9665 ASSERT_EQ(OK, ReadTransaction(trans.get(), &response_data));
9666 EXPECT_EQ("hello!", response_data);
9667 trans.reset();
9668 EXPECT_TRUE(
9669 session->spdy_session_pool()->HasSession(host_port_proxy_pair_a));
9670
9671 HostPortPair host_port_pair_b("www.b.com", 443);
9672 HostPortProxyPair host_port_proxy_pair_b(
9673 host_port_pair_b, ProxyServer::Direct());
9674 EXPECT_FALSE(
9675 session->spdy_session_pool()->HasSession(host_port_proxy_pair_b));
9676 HttpRequestInfo request2;
9677 request2.method = "GET";
9678 request2.url = GURL("https://www.b.com/");
9679 request2.load_flags = 0;
9680 trans.reset(new HttpNetworkTransaction(session));
9681
9682 rv = trans->Start(&request2, callback.callback(), BoundNetLog());
9683 EXPECT_EQ(ERR_IO_PENDING, rv);
9684 EXPECT_EQ(OK, callback.WaitForResult());
9685
9686 response = trans->GetResponseInfo();
9687 ASSERT_TRUE(response != NULL);
9688 ASSERT_TRUE(response->headers != NULL);
9689 EXPECT_EQ("HTTP/1.1 200 OK", response->headers->GetStatusLine());
9690 EXPECT_TRUE(response->was_fetched_via_spdy);
9691 EXPECT_TRUE(response->was_npn_negotiated);
9692 ASSERT_EQ(OK, ReadTransaction(trans.get(), &response_data));
9693 EXPECT_EQ("hello!", response_data);
9694 EXPECT_FALSE(
9695 session->spdy_session_pool()->HasSession(host_port_proxy_pair_a));
9696 EXPECT_TRUE(
9697 session->spdy_session_pool()->HasSession(host_port_proxy_pair_b));
9698
9699 HostPortPair host_port_pair_a1("www.a.com", 80);
9700 HostPortProxyPair host_port_proxy_pair_a1(
9701 host_port_pair_a1, ProxyServer::Direct());
9702 EXPECT_FALSE(
9703 session->spdy_session_pool()->HasSession(host_port_proxy_pair_a1));
9704 HttpRequestInfo request3;
9705 request3.method = "GET";
9706 request3.url = GURL("http://www.a.com/");
9707 request3.load_flags = 0;
9708 trans.reset(new HttpNetworkTransaction(session));
9709
9710 rv = trans->Start(&request3, callback.callback(), BoundNetLog());
9711 EXPECT_EQ(ERR_IO_PENDING, rv);
9712 EXPECT_EQ(OK, callback.WaitForResult());
9713
9714 response = trans->GetResponseInfo();
9715 ASSERT_TRUE(response != NULL);
9716 ASSERT_TRUE(response->headers != NULL);
9717 EXPECT_EQ("HTTP/1.1 200 OK", response->headers->GetStatusLine());
9718 EXPECT_FALSE(response->was_fetched_via_spdy);
9719 EXPECT_FALSE(response->was_npn_negotiated);
9720 ASSERT_EQ(OK, ReadTransaction(trans.get(), &response_data));
9721 EXPECT_EQ("hello!", response_data);
9722 EXPECT_FALSE(
9723 session->spdy_session_pool()->HasSession(host_port_proxy_pair_a));
9724 EXPECT_FALSE(
9725 session->spdy_session_pool()->HasSession(host_port_proxy_pair_b));
9726
9727 HttpStreamFactory::SetNextProtos(std::vector<std::string>());
9728 ClientSocketPoolManager::set_max_sockets_per_pool(
9729 HttpNetworkSession::NORMAL_SOCKET_POOL, old_max_sockets_per_pool);
9730 ClientSocketPoolManager::set_max_sockets_per_proxy_server(
9731 HttpNetworkSession::NORMAL_SOCKET_POOL, old_max_sockets_per_proxy_server);
9732 ClientSocketPoolManager::set_max_sockets_per_group(
9733 HttpNetworkSession::NORMAL_SOCKET_POOL, old_max_sockets_per_group);
9734 }
9735
9736 } // namespace net 9555 } // 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