| 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 "content/public/test/test_file_error_injector.h" | 5 #include "content/public/test/test_file_error_injector.h" |
| 6 | 6 |
| 7 #include <utility> | 7 #include <utility> |
| 8 #include <vector> | 8 #include <vector> |
| 9 | 9 |
| 10 #include "base/callback.h" | 10 #include "base/callback.h" |
| 11 #include "base/compiler_specific.h" | 11 #include "base/compiler_specific.h" |
| 12 #include "base/logging.h" | 12 #include "base/logging.h" |
| 13 #include "content/browser/download/download_file_factory.h" | 13 #include "content/browser/download/download_file_factory.h" |
| 14 #include "content/browser/download/download_file_impl.h" | 14 #include "content/browser/download/download_file_impl.h" |
| 15 #include "content/browser/download/download_interrupt_reasons_impl.h" | 15 #include "content/browser/download/download_interrupt_reasons_impl.h" |
| 16 #include "content/browser/download/download_manager_impl.h" | 16 #include "content/browser/download/download_manager_impl.h" |
| 17 #include "content/browser/loader/resource_dispatcher_host_impl.h" | 17 #include "content/browser/loader/resource_dispatcher_host_impl.h" |
| 18 #include "content/public/browser/browser_thread.h" | 18 #include "content/public/browser/browser_thread.h" |
| 19 #include "url/gurl.h" | 19 #include "url/gurl.h" |
| 20 | 20 |
| 21 namespace content { | 21 namespace content { |
| 22 class ByteStreamReader; | 22 class ByteStreamReader; |
| 23 | 23 |
| 24 namespace { | 24 namespace { |
| 25 | 25 |
| 26 // A class that performs file operations and injects errors. | 26 // A class that performs file operations and injects errors. |
| 27 class DownloadFileWithError: public DownloadFileImpl { | 27 class DownloadFileWithError: public DownloadFileImpl { |
| 28 public: | 28 public: |
| 29 DownloadFileWithError(const DownloadSaveInfo& save_info, | 29 DownloadFileWithError(scoped_ptr<DownloadSaveInfo> save_info, |
| 30 const base::FilePath& default_download_directory, | 30 const base::FilePath& default_download_directory, |
| 31 const GURL& url, | 31 scoped_ptr<ByteStreamReader> byte_stream, |
| 32 const GURL& referrer_url, | 32 const net::BoundNetLog& bound_net_log, |
| 33 bool calculate_hash, | 33 base::WeakPtr<DownloadDestinationObserver> observer, |
| 34 base::File file, | 34 const TestFileErrorInjector::FileErrorInfo& error_info, |
| 35 scoped_ptr<ByteStreamReader> byte_stream, | 35 const base::Closure& ctor_callback, |
| 36 const net::BoundNetLog& bound_net_log, | 36 const base::Closure& dtor_callback); |
| 37 base::WeakPtr<DownloadDestinationObserver> observer, | |
| 38 const TestFileErrorInjector::FileErrorInfo& error_info, | |
| 39 const base::Closure& ctor_callback, | |
| 40 const base::Closure& dtor_callback); | |
| 41 | 37 |
| 42 ~DownloadFileWithError() override; | 38 ~DownloadFileWithError() override; |
| 43 | 39 |
| 44 void Initialize(const InitializeCallback& callback) override; | 40 void Initialize(const InitializeCallback& callback) override; |
| 45 | 41 |
| 46 // DownloadFile interface. | 42 // DownloadFile interface. |
| 47 DownloadInterruptReason AppendDataToFile(const char* data, | 43 DownloadInterruptReason AppendDataToFile(const char* data, |
| 48 size_t data_len) override; | 44 size_t data_len) override; |
| 49 void RenameAndUniquify(const base::FilePath& full_path, | 45 void RenameAndUniquify(const base::FilePath& full_path, |
| 50 const RenameCompletionCallback& callback) override; | 46 const RenameCompletionCallback& callback) override; |
| 51 void RenameAndAnnotate(const base::FilePath& full_path, | 47 void RenameAndAnnotate(const base::FilePath& full_path, |
| 48 const std::string& client_guid, |
| 49 const GURL& source_url, |
| 50 const GURL& referrer_url, |
| 52 const RenameCompletionCallback& callback) override; | 51 const RenameCompletionCallback& callback) override; |
| 53 | 52 |
| 54 private: | 53 private: |
| 55 // Error generating helper. | 54 // Error generating helper. |
| 56 DownloadInterruptReason ShouldReturnError( | 55 DownloadInterruptReason ShouldReturnError( |
| 57 TestFileErrorInjector::FileOperationCode code, | 56 TestFileErrorInjector::FileOperationCode code, |
| 58 DownloadInterruptReason original_error); | 57 DownloadInterruptReason original_error); |
| 59 | 58 |
| 60 // Determine whether to overwrite an operation with the given code | 59 // Determine whether to overwrite an operation with the given code |
| 61 // with a substitute error; if returns true, |*original_error| is | 60 // with a substitute error; if returns true, |*original_error| is |
| (...skipping 27 matching lines...) Expand all Loading... |
| 89 DownloadInterruptReason overwrite_error, | 88 DownloadInterruptReason overwrite_error, |
| 90 DownloadInterruptReason original_error, | 89 DownloadInterruptReason original_error, |
| 91 const base::FilePath& path_result) { | 90 const base::FilePath& path_result) { |
| 92 original_callback.Run( | 91 original_callback.Run( |
| 93 overwrite_error, | 92 overwrite_error, |
| 94 overwrite_error == DOWNLOAD_INTERRUPT_REASON_NONE ? | 93 overwrite_error == DOWNLOAD_INTERRUPT_REASON_NONE ? |
| 95 path_result : base::FilePath()); | 94 path_result : base::FilePath()); |
| 96 } | 95 } |
| 97 | 96 |
| 98 DownloadFileWithError::DownloadFileWithError( | 97 DownloadFileWithError::DownloadFileWithError( |
| 99 const DownloadSaveInfo& save_info, | 98 scoped_ptr<DownloadSaveInfo> save_info, |
| 100 const base::FilePath& default_download_directory, | 99 const base::FilePath& default_download_directory, |
| 101 const GURL& url, | |
| 102 const GURL& referrer_url, | |
| 103 bool calculate_hash, | |
| 104 base::File file, | |
| 105 scoped_ptr<ByteStreamReader> byte_stream, | 100 scoped_ptr<ByteStreamReader> byte_stream, |
| 106 const net::BoundNetLog& bound_net_log, | 101 const net::BoundNetLog& bound_net_log, |
| 107 base::WeakPtr<DownloadDestinationObserver> observer, | 102 base::WeakPtr<DownloadDestinationObserver> observer, |
| 108 const TestFileErrorInjector::FileErrorInfo& error_info, | 103 const TestFileErrorInjector::FileErrorInfo& error_info, |
| 109 const base::Closure& ctor_callback, | 104 const base::Closure& ctor_callback, |
| 110 const base::Closure& dtor_callback) | 105 const base::Closure& dtor_callback) |
| 111 : DownloadFileImpl(save_info, | 106 : DownloadFileImpl(std::move(save_info), |
| 112 default_download_directory, | 107 default_download_directory, |
| 113 url, | |
| 114 referrer_url, | |
| 115 calculate_hash, | |
| 116 std::move(file), | |
| 117 std::move(byte_stream), | 108 std::move(byte_stream), |
| 118 bound_net_log, | 109 bound_net_log, |
| 119 observer), | 110 observer), |
| 120 error_info_(error_info), | 111 error_info_(error_info), |
| 121 destruction_callback_(dtor_callback) { | 112 destruction_callback_(dtor_callback) { |
| 122 // DownloadFiles are created on the UI thread and are destroyed on the FILE | 113 // DownloadFiles are created on the UI thread and are destroyed on the FILE |
| 123 // thread. Schedule the ConstructionCallback on the FILE thread so that if a | 114 // thread. Schedule the ConstructionCallback on the FILE thread so that if a |
| 124 // DownloadItem schedules a DownloadFile to be destroyed and creates another | 115 // DownloadItem schedules a DownloadFile to be destroyed and creates another |
| 125 // one (as happens during download resumption), then the DestructionCallback | 116 // one (as happens during download resumption), then the DestructionCallback |
| 126 // for the old DownloadFile is run before the ConstructionCallback for the | 117 // for the old DownloadFile is run before the ConstructionCallback for the |
| (...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 188 // Otherwise, just wrap the return. | 179 // Otherwise, just wrap the return. |
| 189 callback_to_use = base::Bind(&RenameErrorCallback, callback, | 180 callback_to_use = base::Bind(&RenameErrorCallback, callback, |
| 190 error_to_return); | 181 error_to_return); |
| 191 } | 182 } |
| 192 | 183 |
| 193 DownloadFileImpl::RenameAndUniquify(full_path, callback_to_use); | 184 DownloadFileImpl::RenameAndUniquify(full_path, callback_to_use); |
| 194 } | 185 } |
| 195 | 186 |
| 196 void DownloadFileWithError::RenameAndAnnotate( | 187 void DownloadFileWithError::RenameAndAnnotate( |
| 197 const base::FilePath& full_path, | 188 const base::FilePath& full_path, |
| 189 const std::string& client_guid, |
| 190 const GURL& source_url, |
| 191 const GURL& referrer_url, |
| 198 const RenameCompletionCallback& callback) { | 192 const RenameCompletionCallback& callback) { |
| 199 DownloadInterruptReason error_to_return = DOWNLOAD_INTERRUPT_REASON_NONE; | 193 DownloadInterruptReason error_to_return = DOWNLOAD_INTERRUPT_REASON_NONE; |
| 200 RenameCompletionCallback callback_to_use = callback; | 194 RenameCompletionCallback callback_to_use = callback; |
| 201 | 195 |
| 202 // Replace callback if the error needs to be overwritten. | 196 // Replace callback if the error needs to be overwritten. |
| 203 if (OverwriteError( | 197 if (OverwriteError( |
| 204 TestFileErrorInjector::FILE_OPERATION_RENAME_ANNOTATE, | 198 TestFileErrorInjector::FILE_OPERATION_RENAME_ANNOTATE, |
| 205 &error_to_return)) { | 199 &error_to_return)) { |
| 206 if (DOWNLOAD_INTERRUPT_REASON_NONE != error_to_return) { | 200 if (DOWNLOAD_INTERRUPT_REASON_NONE != error_to_return) { |
| 207 // Don't execute a, probably successful, RenameAndAnnotate; just | 201 // Don't execute a, probably successful, RenameAndAnnotate; just |
| 208 // return the error. | 202 // return the error. |
| 209 BrowserThread::PostTask( | 203 BrowserThread::PostTask( |
| 210 BrowserThread::UI, FROM_HERE, base::Bind( | 204 BrowserThread::UI, FROM_HERE, base::Bind( |
| 211 callback, error_to_return, base::FilePath())); | 205 callback, error_to_return, base::FilePath())); |
| 212 return; | 206 return; |
| 213 } | 207 } |
| 214 | 208 |
| 215 // Otherwise, just wrap the return. | 209 // Otherwise, just wrap the return. |
| 216 callback_to_use = base::Bind(&RenameErrorCallback, callback, | 210 callback_to_use = base::Bind(&RenameErrorCallback, callback, |
| 217 error_to_return); | 211 error_to_return); |
| 218 } | 212 } |
| 219 | 213 |
| 220 DownloadFileImpl::RenameAndAnnotate(full_path, callback_to_use); | 214 DownloadFileImpl::RenameAndAnnotate(full_path, client_guid, source_url, |
| 215 referrer_url, callback_to_use); |
| 221 } | 216 } |
| 222 | 217 |
| 223 bool DownloadFileWithError::OverwriteError( | 218 bool DownloadFileWithError::OverwriteError( |
| 224 TestFileErrorInjector::FileOperationCode code, | 219 TestFileErrorInjector::FileOperationCode code, |
| 225 DownloadInterruptReason* output_error) { | 220 DownloadInterruptReason* output_error) { |
| 226 int counter = operation_counter_[code]++; | 221 int counter = operation_counter_[code]++; |
| 227 | 222 |
| 228 if (code != error_info_.code) | 223 if (code != error_info_.code) |
| 229 return false; | 224 return false; |
| 230 | 225 |
| (...skipping 16 matching lines...) Expand all Loading... |
| 247 | 242 |
| 248 // A factory for constructing DownloadFiles that inject errors. | 243 // A factory for constructing DownloadFiles that inject errors. |
| 249 class DownloadFileWithErrorFactory : public DownloadFileFactory { | 244 class DownloadFileWithErrorFactory : public DownloadFileFactory { |
| 250 public: | 245 public: |
| 251 DownloadFileWithErrorFactory(const base::Closure& ctor_callback, | 246 DownloadFileWithErrorFactory(const base::Closure& ctor_callback, |
| 252 const base::Closure& dtor_callback); | 247 const base::Closure& dtor_callback); |
| 253 ~DownloadFileWithErrorFactory() override; | 248 ~DownloadFileWithErrorFactory() override; |
| 254 | 249 |
| 255 // DownloadFileFactory interface. | 250 // DownloadFileFactory interface. |
| 256 DownloadFile* CreateFile( | 251 DownloadFile* CreateFile( |
| 257 const DownloadSaveInfo& save_info, | 252 scoped_ptr<DownloadSaveInfo> save_info, |
| 258 const base::FilePath& default_download_directory, | 253 const base::FilePath& default_download_directory, |
| 259 const GURL& url, | |
| 260 const GURL& referrer_url, | |
| 261 bool calculate_hash, | |
| 262 base::File file, | |
| 263 scoped_ptr<ByteStreamReader> byte_stream, | 254 scoped_ptr<ByteStreamReader> byte_stream, |
| 264 const net::BoundNetLog& bound_net_log, | 255 const net::BoundNetLog& bound_net_log, |
| 265 base::WeakPtr<DownloadDestinationObserver> observer) override; | 256 base::WeakPtr<DownloadDestinationObserver> observer) override; |
| 266 | 257 |
| 267 void ClearError(); | |
| 268 bool SetError(TestFileErrorInjector::FileErrorInfo error); | 258 bool SetError(TestFileErrorInjector::FileErrorInfo error); |
| 269 | 259 |
| 270 private: | 260 private: |
| 271 // Our injected error. | 261 // Our injected error. |
| 272 TestFileErrorInjector::FileErrorInfo injected_error_; | 262 TestFileErrorInjector::FileErrorInfo injected_error_; |
| 273 | 263 |
| 274 // Callback for creation and destruction. | 264 // Callback for creation and destruction. |
| 275 base::Closure construction_callback_; | 265 base::Closure construction_callback_; |
| 276 base::Closure destruction_callback_; | 266 base::Closure destruction_callback_; |
| 277 }; | 267 }; |
| 278 | 268 |
| 279 DownloadFileWithErrorFactory::DownloadFileWithErrorFactory( | 269 DownloadFileWithErrorFactory::DownloadFileWithErrorFactory( |
| 280 const base::Closure& ctor_callback, | 270 const base::Closure& ctor_callback, |
| 281 const base::Closure& dtor_callback) | 271 const base::Closure& dtor_callback) |
| 282 : construction_callback_(ctor_callback), | 272 : construction_callback_(ctor_callback), |
| 283 destruction_callback_(dtor_callback) { | 273 destruction_callback_(dtor_callback) { |
| 284 injected_error_.code = TestFileErrorInjector::FILE_OPERATION_INITIALIZE; | 274 injected_error_.code = TestFileErrorInjector::FILE_OPERATION_INITIALIZE; |
| 285 injected_error_.error = DOWNLOAD_INTERRUPT_REASON_NONE; | 275 injected_error_.error = DOWNLOAD_INTERRUPT_REASON_NONE; |
| 286 injected_error_.operation_instance = -1; | 276 injected_error_.operation_instance = -1; |
| 287 } | 277 } |
| 288 | 278 |
| 289 DownloadFileWithErrorFactory::~DownloadFileWithErrorFactory() {} | 279 DownloadFileWithErrorFactory::~DownloadFileWithErrorFactory() {} |
| 290 | 280 |
| 291 DownloadFile* DownloadFileWithErrorFactory::CreateFile( | 281 DownloadFile* DownloadFileWithErrorFactory::CreateFile( |
| 292 const DownloadSaveInfo& save_info, | 282 scoped_ptr<DownloadSaveInfo> save_info, |
| 293 const base::FilePath& default_download_directory, | 283 const base::FilePath& default_download_directory, |
| 294 const GURL& url, | |
| 295 const GURL& referrer_url, | |
| 296 bool calculate_hash, | |
| 297 base::File file, | |
| 298 scoped_ptr<ByteStreamReader> byte_stream, | 284 scoped_ptr<ByteStreamReader> byte_stream, |
| 299 const net::BoundNetLog& bound_net_log, | 285 const net::BoundNetLog& bound_net_log, |
| 300 base::WeakPtr<DownloadDestinationObserver> observer) { | 286 base::WeakPtr<DownloadDestinationObserver> observer) { |
| 301 return new DownloadFileWithError( | 287 return new DownloadFileWithError( |
| 302 save_info, default_download_directory, url, referrer_url, calculate_hash, | 288 std::move(save_info), default_download_directory, std::move(byte_stream), |
| 303 std::move(file), std::move(byte_stream), bound_net_log, observer, | 289 bound_net_log, observer, injected_error_, construction_callback_, |
| 304 injected_error_, construction_callback_, destruction_callback_); | 290 destruction_callback_); |
| 305 } | 291 } |
| 306 | 292 |
| 307 bool DownloadFileWithErrorFactory::SetError( | 293 bool DownloadFileWithErrorFactory::SetError( |
| 308 TestFileErrorInjector::FileErrorInfo error) { | 294 TestFileErrorInjector::FileErrorInfo error) { |
| 309 injected_error_ = std::move(error); | 295 injected_error_ = std::move(error); |
| 310 return true; | 296 return true; |
| 311 } | 297 } |
| 312 | 298 |
| 313 TestFileErrorInjector::TestFileErrorInjector(DownloadManager* download_manager) | 299 TestFileErrorInjector::TestFileErrorInjector(DownloadManager* download_manager) |
| 314 : // This code is only used for browser_tests, so a | 300 : // This code is only used for browser_tests, so a |
| 315 // DownloadManager is always a DownloadManagerImpl. | 301 // DownloadManager is always a DownloadManagerImpl. |
| 316 download_manager_(static_cast<DownloadManagerImpl*>(download_manager)) { | 302 download_manager_(static_cast<DownloadManagerImpl*>(download_manager)) { |
| 317 // Record the value of the pointer, for later validation. | 303 // Record the value of the pointer, for later validation. |
| 318 created_factory_ = | 304 created_factory_ = new DownloadFileWithErrorFactory( |
| 319 new DownloadFileWithErrorFactory( | 305 base::Bind(&TestFileErrorInjector::RecordDownloadFileConstruction, this), |
| 320 base::Bind(&TestFileErrorInjector::RecordDownloadFileConstruction, | 306 base::Bind(&TestFileErrorInjector::RecordDownloadFileDestruction, this)); |
| 321 this), | |
| 322 base::Bind(&TestFileErrorInjector::RecordDownloadFileDestruction, | |
| 323 this)); | |
| 324 | 307 |
| 325 // We will transfer ownership of the factory to the download manager. | 308 // We will transfer ownership of the factory to the download manager. |
| 326 scoped_ptr<DownloadFileFactory> download_file_factory( | 309 scoped_ptr<DownloadFileFactory> download_file_factory( |
| 327 created_factory_); | 310 created_factory_); |
| 328 | 311 |
| 329 download_manager_->SetDownloadFileFactoryForTesting( | 312 download_manager_->SetDownloadFileFactoryForTesting( |
| 330 std::move(download_file_factory)); | 313 std::move(download_file_factory)); |
| 331 } | 314 } |
| 332 | 315 |
| 333 TestFileErrorInjector::~TestFileErrorInjector() { | 316 TestFileErrorInjector::~TestFileErrorInjector() { |
| (...skipping 79 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 413 case FILE_OPERATION_RENAME_ANNOTATE: | 396 case FILE_OPERATION_RENAME_ANNOTATE: |
| 414 return "RENAME_ANNOTATE"; | 397 return "RENAME_ANNOTATE"; |
| 415 default: | 398 default: |
| 416 break; | 399 break; |
| 417 } | 400 } |
| 418 | 401 |
| 419 return "Unknown"; | 402 return "Unknown"; |
| 420 } | 403 } |
| 421 | 404 |
| 422 } // namespace content | 405 } // namespace content |
| OLD | NEW |