| 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/url_request/url_request_ftp_job.h" | 5 #include "net/url_request/url_request_ftp_job.h" |
| 6 | 6 |
| 7 #include <memory> | 7 #include <memory> |
| 8 #include <utility> | 8 #include <utility> |
| 9 #include <vector> | 9 #include <vector> |
| 10 | 10 |
| (...skipping 292 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 303 | 303 |
| 304 TestDelegate request_delegate; | 304 TestDelegate request_delegate; |
| 305 std::unique_ptr<URLRequest> url_request(request_context()->CreateRequest( | 305 std::unique_ptr<URLRequest> url_request(request_context()->CreateRequest( |
| 306 GURL("ftp://ftp.example.com/"), DEFAULT_PRIORITY, &request_delegate)); | 306 GURL("ftp://ftp.example.com/"), DEFAULT_PRIORITY, &request_delegate)); |
| 307 url_request->Start(); | 307 url_request->Start(); |
| 308 ASSERT_TRUE(url_request->is_pending()); | 308 ASSERT_TRUE(url_request->is_pending()); |
| 309 | 309 |
| 310 // The TestDelegate will by default quit the message loop on completion. | 310 // The TestDelegate will by default quit the message loop on completion. |
| 311 base::RunLoop().Run(); | 311 base::RunLoop().Run(); |
| 312 | 312 |
| 313 EXPECT_TRUE(url_request->status().is_success()); | 313 EXPECT_THAT(request_delegate.request_status(), IsOk()); |
| 314 EXPECT_TRUE(url_request->proxy_server().Equals( | 314 EXPECT_TRUE(url_request->proxy_server().Equals( |
| 315 HostPortPair::FromString("localhost:80"))); | 315 HostPortPair::FromString("localhost:80"))); |
| 316 EXPECT_EQ(1, network_delegate()->completed_requests()); | 316 EXPECT_EQ(1, network_delegate()->completed_requests()); |
| 317 EXPECT_EQ(0, network_delegate()->error_count()); | 317 EXPECT_EQ(0, network_delegate()->error_count()); |
| 318 EXPECT_FALSE(request_delegate.auth_required_called()); | 318 EXPECT_FALSE(request_delegate.auth_required_called()); |
| 319 EXPECT_EQ("test.html", request_delegate.data_received()); | 319 EXPECT_EQ("test.html", request_delegate.data_received()); |
| 320 } | 320 } |
| 321 | 321 |
| 322 // Regression test for http://crbug.com/237526. | 322 // Regression test for http://crbug.com/237526. |
| 323 TEST_F(URLRequestFtpJobTest, FtpProxyRequestOrphanJob) { | 323 TEST_F(URLRequestFtpJobTest, FtpProxyRequestOrphanJob) { |
| (...skipping 75 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 399 | 399 |
| 400 TestDelegate request_delegate; | 400 TestDelegate request_delegate; |
| 401 std::unique_ptr<URLRequest> url_request(request_context()->CreateRequest( | 401 std::unique_ptr<URLRequest> url_request(request_context()->CreateRequest( |
| 402 GURL("ftp://ftp.example.com/"), DEFAULT_PRIORITY, &request_delegate)); | 402 GURL("ftp://ftp.example.com/"), DEFAULT_PRIORITY, &request_delegate)); |
| 403 url_request->Start(); | 403 url_request->Start(); |
| 404 ASSERT_TRUE(url_request->is_pending()); | 404 ASSERT_TRUE(url_request->is_pending()); |
| 405 | 405 |
| 406 // The TestDelegate will by default quit the message loop on completion. | 406 // The TestDelegate will by default quit the message loop on completion. |
| 407 base::RunLoop().Run(); | 407 base::RunLoop().Run(); |
| 408 | 408 |
| 409 EXPECT_TRUE(url_request->status().is_success()); | 409 EXPECT_THAT(request_delegate.request_status(), IsOk()); |
| 410 EXPECT_TRUE(url_request->proxy_server().Equals( | 410 EXPECT_TRUE(url_request->proxy_server().Equals( |
| 411 HostPortPair::FromString("localhost:80"))); | 411 HostPortPair::FromString("localhost:80"))); |
| 412 EXPECT_EQ(1, network_delegate()->completed_requests()); | 412 EXPECT_EQ(1, network_delegate()->completed_requests()); |
| 413 EXPECT_EQ(0, network_delegate()->error_count()); | 413 EXPECT_EQ(0, network_delegate()->error_count()); |
| 414 EXPECT_TRUE(request_delegate.auth_required_called()); | 414 EXPECT_TRUE(request_delegate.auth_required_called()); |
| 415 EXPECT_EQ("test.html", request_delegate.data_received()); | 415 EXPECT_EQ("test.html", request_delegate.data_received()); |
| 416 } | 416 } |
| 417 | 417 |
| 418 TEST_F(URLRequestFtpJobTest, FtpProxyRequestNeedProxyAuthWithCredentials) { | 418 TEST_F(URLRequestFtpJobTest, FtpProxyRequestNeedProxyAuthWithCredentials) { |
| 419 MockWrite writes[] = { | 419 MockWrite writes[] = { |
| (...skipping 25 matching lines...) Expand all Loading... |
| 445 request_delegate.set_credentials( | 445 request_delegate.set_credentials( |
| 446 AuthCredentials(ASCIIToUTF16("myuser"), ASCIIToUTF16("mypass"))); | 446 AuthCredentials(ASCIIToUTF16("myuser"), ASCIIToUTF16("mypass"))); |
| 447 std::unique_ptr<URLRequest> url_request(request_context()->CreateRequest( | 447 std::unique_ptr<URLRequest> url_request(request_context()->CreateRequest( |
| 448 GURL("ftp://ftp.example.com/"), DEFAULT_PRIORITY, &request_delegate)); | 448 GURL("ftp://ftp.example.com/"), DEFAULT_PRIORITY, &request_delegate)); |
| 449 url_request->Start(); | 449 url_request->Start(); |
| 450 ASSERT_TRUE(url_request->is_pending()); | 450 ASSERT_TRUE(url_request->is_pending()); |
| 451 | 451 |
| 452 // The TestDelegate will by default quit the message loop on completion. | 452 // The TestDelegate will by default quit the message loop on completion. |
| 453 base::RunLoop().Run(); | 453 base::RunLoop().Run(); |
| 454 | 454 |
| 455 EXPECT_TRUE(url_request->status().is_success()); | 455 EXPECT_THAT(request_delegate.request_status(), IsOk()); |
| 456 EXPECT_EQ(1, network_delegate()->completed_requests()); | 456 EXPECT_EQ(1, network_delegate()->completed_requests()); |
| 457 EXPECT_EQ(0, network_delegate()->error_count()); | 457 EXPECT_EQ(0, network_delegate()->error_count()); |
| 458 EXPECT_TRUE(request_delegate.auth_required_called()); | 458 EXPECT_TRUE(request_delegate.auth_required_called()); |
| 459 EXPECT_EQ("test2.html", request_delegate.data_received()); | 459 EXPECT_EQ("test2.html", request_delegate.data_received()); |
| 460 } | 460 } |
| 461 | 461 |
| 462 TEST_F(URLRequestFtpJobTest, FtpProxyRequestNeedServerAuthNoCredentials) { | 462 TEST_F(URLRequestFtpJobTest, FtpProxyRequestNeedServerAuthNoCredentials) { |
| 463 MockWrite writes[] = { | 463 MockWrite writes[] = { |
| 464 MockWrite(ASYNC, 0, "GET ftp://ftp.example.com/ HTTP/1.1\r\n" | 464 MockWrite(ASYNC, 0, "GET ftp://ftp.example.com/ HTTP/1.1\r\n" |
| 465 "Host: ftp.example.com\r\n" | 465 "Host: ftp.example.com\r\n" |
| (...skipping 12 matching lines...) Expand all Loading... |
| 478 | 478 |
| 479 TestDelegate request_delegate; | 479 TestDelegate request_delegate; |
| 480 std::unique_ptr<URLRequest> url_request(request_context()->CreateRequest( | 480 std::unique_ptr<URLRequest> url_request(request_context()->CreateRequest( |
| 481 GURL("ftp://ftp.example.com/"), DEFAULT_PRIORITY, &request_delegate)); | 481 GURL("ftp://ftp.example.com/"), DEFAULT_PRIORITY, &request_delegate)); |
| 482 url_request->Start(); | 482 url_request->Start(); |
| 483 ASSERT_TRUE(url_request->is_pending()); | 483 ASSERT_TRUE(url_request->is_pending()); |
| 484 | 484 |
| 485 // The TestDelegate will by default quit the message loop on completion. | 485 // The TestDelegate will by default quit the message loop on completion. |
| 486 base::RunLoop().Run(); | 486 base::RunLoop().Run(); |
| 487 | 487 |
| 488 EXPECT_TRUE(url_request->status().is_success()); | 488 EXPECT_THAT(request_delegate.request_status(), IsOk()); |
| 489 EXPECT_EQ(1, network_delegate()->completed_requests()); | 489 EXPECT_EQ(1, network_delegate()->completed_requests()); |
| 490 EXPECT_EQ(0, network_delegate()->error_count()); | 490 EXPECT_EQ(0, network_delegate()->error_count()); |
| 491 EXPECT_TRUE(request_delegate.auth_required_called()); | 491 EXPECT_TRUE(request_delegate.auth_required_called()); |
| 492 EXPECT_EQ("test.html", request_delegate.data_received()); | 492 EXPECT_EQ("test.html", request_delegate.data_received()); |
| 493 } | 493 } |
| 494 | 494 |
| 495 TEST_F(URLRequestFtpJobTest, FtpProxyRequestNeedServerAuthWithCredentials) { | 495 TEST_F(URLRequestFtpJobTest, FtpProxyRequestNeedServerAuthWithCredentials) { |
| 496 MockWrite writes[] = { | 496 MockWrite writes[] = { |
| 497 MockWrite(ASYNC, 0, "GET ftp://ftp.example.com/ HTTP/1.1\r\n" | 497 MockWrite(ASYNC, 0, "GET ftp://ftp.example.com/ HTTP/1.1\r\n" |
| 498 "Host: ftp.example.com\r\n" | 498 "Host: ftp.example.com\r\n" |
| (...skipping 23 matching lines...) Expand all Loading... |
| 522 request_delegate.set_credentials( | 522 request_delegate.set_credentials( |
| 523 AuthCredentials(ASCIIToUTF16("myuser"), ASCIIToUTF16("mypass"))); | 523 AuthCredentials(ASCIIToUTF16("myuser"), ASCIIToUTF16("mypass"))); |
| 524 std::unique_ptr<URLRequest> url_request(request_context()->CreateRequest( | 524 std::unique_ptr<URLRequest> url_request(request_context()->CreateRequest( |
| 525 GURL("ftp://ftp.example.com/"), DEFAULT_PRIORITY, &request_delegate)); | 525 GURL("ftp://ftp.example.com/"), DEFAULT_PRIORITY, &request_delegate)); |
| 526 url_request->Start(); | 526 url_request->Start(); |
| 527 ASSERT_TRUE(url_request->is_pending()); | 527 ASSERT_TRUE(url_request->is_pending()); |
| 528 | 528 |
| 529 // The TestDelegate will by default quit the message loop on completion. | 529 // The TestDelegate will by default quit the message loop on completion. |
| 530 base::RunLoop().Run(); | 530 base::RunLoop().Run(); |
| 531 | 531 |
| 532 EXPECT_TRUE(url_request->status().is_success()); | 532 EXPECT_THAT(request_delegate.request_status(), IsOk()); |
| 533 EXPECT_EQ(1, network_delegate()->completed_requests()); | 533 EXPECT_EQ(1, network_delegate()->completed_requests()); |
| 534 EXPECT_EQ(0, network_delegate()->error_count()); | 534 EXPECT_EQ(0, network_delegate()->error_count()); |
| 535 EXPECT_TRUE(request_delegate.auth_required_called()); | 535 EXPECT_TRUE(request_delegate.auth_required_called()); |
| 536 EXPECT_EQ("test2.html", request_delegate.data_received()); | 536 EXPECT_EQ("test2.html", request_delegate.data_received()); |
| 537 } | 537 } |
| 538 | 538 |
| 539 TEST_F(URLRequestFtpJobTest, FtpProxyRequestNeedProxyAndServerAuth) { | 539 TEST_F(URLRequestFtpJobTest, FtpProxyRequestNeedProxyAndServerAuth) { |
| 540 MockWrite writes[] = { | 540 MockWrite writes[] = { |
| 541 MockWrite(ASYNC, 0, "GET ftp://ftp.example.com/ HTTP/1.1\r\n" | 541 MockWrite(ASYNC, 0, "GET ftp://ftp.example.com/ HTTP/1.1\r\n" |
| 542 "Host: ftp.example.com\r\n" | 542 "Host: ftp.example.com\r\n" |
| (...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 596 | 596 |
| 597 ASSERT_TRUE(request_delegate.auth_required_called()); | 597 ASSERT_TRUE(request_delegate.auth_required_called()); |
| 598 EXPECT_EQ(0, network_delegate()->completed_requests()); | 598 EXPECT_EQ(0, network_delegate()->completed_requests()); |
| 599 EXPECT_EQ(0, network_delegate()->error_count()); | 599 EXPECT_EQ(0, network_delegate()->error_count()); |
| 600 url_request->SetAuth( | 600 url_request->SetAuth( |
| 601 AuthCredentials(ASCIIToUTF16("proxyuser"), ASCIIToUTF16("proxypass"))); | 601 AuthCredentials(ASCIIToUTF16("proxyuser"), ASCIIToUTF16("proxypass"))); |
| 602 | 602 |
| 603 // Run until server auth is requested. | 603 // Run until server auth is requested. |
| 604 base::RunLoop().Run(); | 604 base::RunLoop().Run(); |
| 605 | 605 |
| 606 EXPECT_TRUE(url_request->status().is_success()); | |
| 607 EXPECT_EQ(0, network_delegate()->completed_requests()); | 606 EXPECT_EQ(0, network_delegate()->completed_requests()); |
| 608 EXPECT_EQ(0, network_delegate()->error_count()); | 607 EXPECT_EQ(0, network_delegate()->error_count()); |
| 609 url_request->SetAuth( | 608 url_request->SetAuth( |
| 610 AuthCredentials(ASCIIToUTF16("myuser"), ASCIIToUTF16("mypass"))); | 609 AuthCredentials(ASCIIToUTF16("myuser"), ASCIIToUTF16("mypass"))); |
| 611 | 610 |
| 612 // The TestDelegate will by default quit the message loop on completion. | 611 // The TestDelegate will by default quit the message loop on completion. |
| 613 base::RunLoop().Run(); | 612 base::RunLoop().Run(); |
| 614 | 613 |
| 615 EXPECT_TRUE(url_request->status().is_success()); | 614 EXPECT_THAT(request_delegate.request_status(), IsOk()); |
| 616 EXPECT_EQ(1, network_delegate()->completed_requests()); | 615 EXPECT_EQ(1, network_delegate()->completed_requests()); |
| 617 EXPECT_EQ(0, network_delegate()->error_count()); | 616 EXPECT_EQ(0, network_delegate()->error_count()); |
| 618 EXPECT_TRUE(request_delegate.auth_required_called()); | 617 EXPECT_TRUE(request_delegate.auth_required_called()); |
| 619 EXPECT_EQ("test2.html", request_delegate.data_received()); | 618 EXPECT_EQ("test2.html", request_delegate.data_received()); |
| 620 } | 619 } |
| 621 | 620 |
| 622 TEST_F(URLRequestFtpJobTest, FtpProxyRequestDoNotSaveCookies) { | 621 TEST_F(URLRequestFtpJobTest, FtpProxyRequestDoNotSaveCookies) { |
| 623 MockWrite writes[] = { | 622 MockWrite writes[] = { |
| 624 MockWrite(ASYNC, 0, "GET ftp://ftp.example.com/ HTTP/1.1\r\n" | 623 MockWrite(ASYNC, 0, "GET ftp://ftp.example.com/ HTTP/1.1\r\n" |
| 625 "Host: ftp.example.com\r\n" | 624 "Host: ftp.example.com\r\n" |
| (...skipping 10 matching lines...) Expand all Loading... |
| 636 | 635 |
| 637 TestDelegate request_delegate; | 636 TestDelegate request_delegate; |
| 638 std::unique_ptr<URLRequest> url_request(request_context()->CreateRequest( | 637 std::unique_ptr<URLRequest> url_request(request_context()->CreateRequest( |
| 639 GURL("ftp://ftp.example.com/"), DEFAULT_PRIORITY, &request_delegate)); | 638 GURL("ftp://ftp.example.com/"), DEFAULT_PRIORITY, &request_delegate)); |
| 640 url_request->Start(); | 639 url_request->Start(); |
| 641 ASSERT_TRUE(url_request->is_pending()); | 640 ASSERT_TRUE(url_request->is_pending()); |
| 642 | 641 |
| 643 // The TestDelegate will by default quit the message loop on completion. | 642 // The TestDelegate will by default quit the message loop on completion. |
| 644 base::RunLoop().Run(); | 643 base::RunLoop().Run(); |
| 645 | 644 |
| 646 EXPECT_TRUE(url_request->status().is_success()); | 645 EXPECT_THAT(request_delegate.request_status(), IsOk()); |
| 647 EXPECT_EQ(1, network_delegate()->completed_requests()); | 646 EXPECT_EQ(1, network_delegate()->completed_requests()); |
| 648 EXPECT_EQ(0, network_delegate()->error_count()); | 647 EXPECT_EQ(0, network_delegate()->error_count()); |
| 649 | 648 |
| 650 // Make sure we do not accept cookies. | 649 // Make sure we do not accept cookies. |
| 651 EXPECT_EQ(0, network_delegate()->set_cookie_count()); | 650 EXPECT_EQ(0, network_delegate()->set_cookie_count()); |
| 652 | 651 |
| 653 EXPECT_FALSE(request_delegate.auth_required_called()); | 652 EXPECT_FALSE(request_delegate.auth_required_called()); |
| 654 EXPECT_EQ("test.html", request_delegate.data_received()); | 653 EXPECT_EQ("test.html", request_delegate.data_received()); |
| 655 } | 654 } |
| 656 | 655 |
| (...skipping 141 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 798 EXPECT_TRUE(url_request2->status().is_success()); | 797 EXPECT_TRUE(url_request2->status().is_success()); |
| 799 EXPECT_EQ(2, network_delegate()->completed_requests()); | 798 EXPECT_EQ(2, network_delegate()->completed_requests()); |
| 800 EXPECT_EQ(0, network_delegate()->error_count()); | 799 EXPECT_EQ(0, network_delegate()->error_count()); |
| 801 EXPECT_FALSE(request_delegate2.auth_required_called()); | 800 EXPECT_FALSE(request_delegate2.auth_required_called()); |
| 802 EXPECT_EQ("test2.html", request_delegate2.data_received()); | 801 EXPECT_EQ("test2.html", request_delegate2.data_received()); |
| 803 } | 802 } |
| 804 | 803 |
| 805 } // namespace | 804 } // namespace |
| 806 | 805 |
| 807 } // namespace net | 806 } // namespace net |
| OLD | NEW |