OLD | NEW |
1 // Copyright (c) 2006-2008 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2010 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 "chrome/browser/net/url_request_mock_http_job.h" | 5 #include "chrome/browser/net/url_request_mock_http_job.h" |
6 | 6 |
7 #include "base/file_util.h" | 7 #include "base/file_util.h" |
8 #include "base/message_loop.h" | 8 #include "base/message_loop.h" |
9 #include "base/string_util.h" | 9 #include "base/string_util.h" |
10 #include "base/thread_restrictions.h" | 10 #include "base/thread_restrictions.h" |
11 #include "base/utf_string_conversions.h" | 11 #include "base/utf_string_conversions.h" |
12 #include "chrome/common/url_constants.h" | 12 #include "chrome/common/url_constants.h" |
13 #include "net/base/net_util.h" | 13 #include "net/base/net_util.h" |
14 #include "net/http/http_response_headers.h" | 14 #include "net/http/http_response_headers.h" |
15 #include "net/url_request/url_request_filter.h" | 15 #include "net/url_request/url_request_filter.h" |
16 | 16 |
17 static const char kMockHostname[] = "mock.http"; | 17 static const char kMockHostname[] = "mock.http"; |
18 static const FilePath::CharType kMockHeaderFileSuffix[] = | 18 static const FilePath::CharType kMockHeaderFileSuffix[] = |
19 FILE_PATH_LITERAL(".mock-http-headers"); | 19 FILE_PATH_LITERAL(".mock-http-headers"); |
20 | 20 |
21 FilePath URLRequestMockHTTPJob::base_path_; | 21 FilePath URLRequestMockHTTPJob::base_path_; |
22 | 22 |
23 /* static */ | 23 // static |
24 net::URLRequestJob* URLRequestMockHTTPJob::Factory(net::URLRequest* request, | 24 net::URLRequestJob* URLRequestMockHTTPJob::Factory(net::URLRequest* request, |
25 const std::string& scheme) { | 25 const std::string& scheme) { |
26 return new URLRequestMockHTTPJob(request, | 26 return new URLRequestMockHTTPJob(request, |
27 GetOnDiskPath(base_path_, request, scheme)); | 27 GetOnDiskPath(base_path_, request, scheme)); |
28 } | 28 } |
29 | 29 |
30 /* static */ | 30 // static |
31 void URLRequestMockHTTPJob::AddUrlHandler(const FilePath& base_path) { | 31 void URLRequestMockHTTPJob::AddUrlHandler(const FilePath& base_path) { |
32 base_path_ = base_path; | 32 base_path_ = base_path; |
33 | 33 |
34 // Add kMockHostname to URLRequestFilter. | 34 // Add kMockHostname to net::URLRequestFilter. |
35 URLRequestFilter* filter = URLRequestFilter::GetInstance(); | 35 net::URLRequestFilter* filter = net::URLRequestFilter::GetInstance(); |
36 filter->AddHostnameHandler("http", kMockHostname, | 36 filter->AddHostnameHandler("http", kMockHostname, |
37 URLRequestMockHTTPJob::Factory); | 37 URLRequestMockHTTPJob::Factory); |
38 } | 38 } |
39 | 39 |
40 /* static */ | 40 /* static */ |
41 GURL URLRequestMockHTTPJob::GetMockUrl(const FilePath& path) { | 41 GURL URLRequestMockHTTPJob::GetMockUrl(const FilePath& path) { |
42 std::string url = "http://"; | 42 std::string url = "http://"; |
43 url.append(kMockHostname); | 43 url.append(kMockHostname); |
44 url.append("/"); | 44 url.append("/"); |
45 url.append(WideToUTF8(path.ToWStringHack())); | 45 url.append(WideToUTF8(path.ToWStringHack())); |
(...skipping 60 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
106 net::HttpResponseInfo info; | 106 net::HttpResponseInfo info; |
107 GetResponseInfoConst(&info); | 107 GetResponseInfoConst(&info); |
108 return info.headers && info.headers->GetMimeType(mime_type); | 108 return info.headers && info.headers->GetMimeType(mime_type); |
109 } | 109 } |
110 | 110 |
111 bool URLRequestMockHTTPJob::GetCharset(std::string* charset) { | 111 bool URLRequestMockHTTPJob::GetCharset(std::string* charset) { |
112 net::HttpResponseInfo info; | 112 net::HttpResponseInfo info; |
113 GetResponseInfo(&info); | 113 GetResponseInfo(&info); |
114 return info.headers && info.headers->GetCharset(charset); | 114 return info.headers && info.headers->GetCharset(charset); |
115 } | 115 } |
OLD | NEW |