| Index: net/url_request/url_request_unittest.cc
|
| ===================================================================
|
| --- net/url_request/url_request_unittest.cc (revision 21335)
|
| +++ net/url_request/url_request_unittest.cc (working copy)
|
| @@ -27,6 +27,7 @@
|
| #include "net/base/net_errors.h"
|
| #include "net/base/net_module.h"
|
| #include "net/base/net_util.h"
|
| +#include "net/base/upload_data.h"
|
| #include "net/disk_cache/disk_cache.h"
|
| #include "net/http/http_cache.h"
|
| #include "net/http/http_network_layer.h"
|
| @@ -100,6 +101,12 @@
|
| }
|
| }
|
|
|
| +scoped_refptr<net::UploadData> CreateSimpleUploadData(const char* data) {
|
| + scoped_refptr<net::UploadData> upload = new net::UploadData;
|
| + upload->AppendBytes(data, strlen(data));
|
| + return upload;
|
| +}
|
| +
|
| } // namespace
|
|
|
| // Inherit PlatformTest since we require the autorelease pool on Mac OS X.f
|
| @@ -1071,6 +1078,64 @@
|
| }
|
| }
|
|
|
| +TEST_F(URLRequestTest, DeferredRedirect) {
|
| + scoped_refptr<HTTPTestServer> server =
|
| + HTTPTestServer::CreateServer(L"net/data/url_request_unittest", NULL);
|
| + ASSERT_TRUE(NULL != server.get());
|
| + TestDelegate d;
|
| + {
|
| + d.set_quit_on_redirect(true);
|
| + TestURLRequest req(server->TestServerPage(
|
| + "files/redirect-test.html"), &d);
|
| + req.Start();
|
| + MessageLoop::current()->Run();
|
| +
|
| + EXPECT_EQ(1, d.received_redirect_count());
|
| +
|
| + req.FollowDeferredRedirect();
|
| + MessageLoop::current()->Run();
|
| +
|
| + EXPECT_EQ(1, d.response_started_count());
|
| + EXPECT_FALSE(d.received_data_before_response());
|
| + EXPECT_EQ(URLRequestStatus::SUCCESS, req.status().status());
|
| +
|
| + FilePath path;
|
| + PathService::Get(base::DIR_SOURCE_ROOT, &path);
|
| + path = path.Append(FILE_PATH_LITERAL("net"));
|
| + path = path.Append(FILE_PATH_LITERAL("data"));
|
| + path = path.Append(FILE_PATH_LITERAL("url_request_unittest"));
|
| + path = path.Append(FILE_PATH_LITERAL("with-headers.html"));
|
| +
|
| + std::string contents;
|
| + EXPECT_TRUE(file_util::ReadFileToString(path, &contents));
|
| + EXPECT_EQ(contents, d.data_received());
|
| + }
|
| +}
|
| +
|
| +TEST_F(URLRequestTest, CancelDeferredRedirect) {
|
| + scoped_refptr<HTTPTestServer> server =
|
| + HTTPTestServer::CreateServer(L"net/data/url_request_unittest", NULL);
|
| + ASSERT_TRUE(NULL != server.get());
|
| + TestDelegate d;
|
| + {
|
| + d.set_quit_on_redirect(true);
|
| + TestURLRequest req(server->TestServerPage(
|
| + "files/redirect-test.html"), &d);
|
| + req.Start();
|
| + MessageLoop::current()->Run();
|
| +
|
| + EXPECT_EQ(1, d.received_redirect_count());
|
| +
|
| + req.Cancel();
|
| + MessageLoop::current()->Run();
|
| +
|
| + EXPECT_EQ(1, d.response_started_count());
|
| + EXPECT_EQ(0, d.bytes_received());
|
| + EXPECT_FALSE(d.received_data_before_response());
|
| + EXPECT_EQ(URLRequestStatus::CANCELED, req.status().status());
|
| + }
|
| +}
|
| +
|
| TEST_F(URLRequestTest, VaryHeader) {
|
| scoped_refptr<HTTPTestServer> server =
|
| HTTPTestServer::CreateServer(L"net/data/url_request_unittest", NULL);
|
| @@ -1236,15 +1301,16 @@
|
| // Content-Type header.
|
| // http://code.google.com/p/chromium/issues/detail?id=843
|
| TEST_F(URLRequestTest, Post302RedirectGet) {
|
| + const char kData[] = "hello world";
|
| scoped_refptr<HTTPTestServer> server =
|
| HTTPTestServer::CreateServer(L"net/data/url_request_unittest", NULL);
|
| ASSERT_TRUE(NULL != server.get());
|
| TestDelegate d;
|
| TestURLRequest req(server->TestServerPage("files/redirect-to-echoall"), &d);
|
| req.set_method("POST");
|
| + req.set_upload(CreateSimpleUploadData(kData));
|
|
|
| // Set headers (some of which are specific to the POST).
|
| - // ("Content-Length: 10" is just a junk value to make sure it gets stripped).
|
| req.SetExtraRequestHeaders(
|
| "Content-Type: multipart/form-data; "
|
| "boundary=----WebKitFormBoundaryAADeAA+NAAWMAAwZ\r\n"
|
| @@ -1252,7 +1318,7 @@
|
| "text/plain;q=0.8,image/png,*/*;q=0.5\r\n"
|
| "Accept-Language: en-US,en\r\n"
|
| "Accept-Charset: ISO-8859-1,*,utf-8\r\n"
|
| - "Content-Length: 10\r\n"
|
| + "Content-Length: 11\r\n"
|
| "Origin: http://localhost:1337/");
|
| req.Start();
|
| MessageLoop::current()->Run();
|
| @@ -1274,17 +1340,23 @@
|
| EXPECT_TRUE(ContainsString(data, "Accept-Charset:"));
|
| }
|
|
|
| -TEST_F(URLRequestTest, Post307RedirectPost) {
|
| +// TODO(darin): Re-enable this test once bug 16832 is fixed.
|
| +TEST_F(URLRequestTest, DISABLED_Post307RedirectPost) {
|
| + const char kData[] = "hello world";
|
| scoped_refptr<HTTPTestServer> server =
|
| HTTPTestServer::CreateServer(L"net/data/url_request_unittest", NULL);
|
| ASSERT_TRUE(NULL != server.get());
|
| TestDelegate d;
|
| - TestURLRequest req(server->TestServerPage("files/redirect307-to-echoall"),
|
| + TestURLRequest req(server->TestServerPage("files/redirect307-to-echo"),
|
| &d);
|
| req.set_method("POST");
|
| + req.set_upload(CreateSimpleUploadData(kData).get());
|
| + req.SetExtraRequestHeaders(
|
| + "Content-Length: " + UintToString(sizeof(kData) - 1));
|
| req.Start();
|
| MessageLoop::current()->Run();
|
| - EXPECT_EQ(req.method(), "POST");
|
| + EXPECT_EQ("POST", req.method());
|
| + EXPECT_EQ(kData, d.data_received());
|
| }
|
|
|
| // Custom URLRequestJobs for use with interceptor tests
|
|
|