| OLD | NEW |
| 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2013 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/chromeos/drive/fake_drive_file_system.h" | 5 #include "chrome/browser/chromeos/drive/fake_file_system.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/bind_helpers.h" | 8 #include "base/bind_helpers.h" |
| 9 #include "base/callback.h" | 9 #include "base/callback.h" |
| 10 #include "base/file_util.h" | 10 #include "base/file_util.h" |
| 11 #include "base/files/file_path.h" | 11 #include "base/files/file_path.h" |
| 12 #include "base/logging.h" | 12 #include "base/logging.h" |
| 13 #include "chrome/browser/chromeos/drive/drive.pb.h" | 13 #include "chrome/browser/chromeos/drive/drive.pb.h" |
| 14 #include "chrome/browser/chromeos/drive/file_errors.h" | 14 #include "chrome/browser/chromeos/drive/file_errors.h" |
| 15 #include "chrome/browser/chromeos/drive/file_system_util.h" | 15 #include "chrome/browser/chromeos/drive/file_system_util.h" |
| 16 #include "chrome/browser/chromeos/drive/resource_entry_conversion.h" | 16 #include "chrome/browser/chromeos/drive/resource_entry_conversion.h" |
| 17 #include "chrome/browser/google_apis/drive_api_parser.h" | 17 #include "chrome/browser/google_apis/drive_api_parser.h" |
| 18 #include "chrome/browser/google_apis/gdata_wapi_parser.h" | 18 #include "chrome/browser/google_apis/gdata_wapi_parser.h" |
| 19 #include "content/public/browser/browser_thread.h" | 19 #include "content/public/browser/browser_thread.h" |
| 20 | 20 |
| 21 namespace drive { | 21 namespace drive { |
| 22 namespace test_util { | 22 namespace test_util { |
| 23 | 23 |
| 24 using content::BrowserThread; | 24 using content::BrowserThread; |
| 25 | 25 |
| 26 FakeDriveFileSystem::FakeDriveFileSystem( | 26 FakeFileSystem::FakeFileSystem( |
| 27 google_apis::DriveServiceInterface* drive_service) | 27 google_apis::DriveServiceInterface* drive_service) |
| 28 : drive_service_(drive_service), | 28 : drive_service_(drive_service), |
| 29 weak_ptr_factory_(this) { | 29 weak_ptr_factory_(this) { |
| 30 } | 30 } |
| 31 | 31 |
| 32 FakeDriveFileSystem::~FakeDriveFileSystem() { | 32 FakeFileSystem::~FakeFileSystem() { |
| 33 } | 33 } |
| 34 | 34 |
| 35 bool FakeDriveFileSystem::InitializeForTesting() { | 35 bool FakeFileSystem::InitializeForTesting() { |
| 36 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 36 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 37 return cache_dir_.CreateUniqueTempDir(); | 37 return cache_dir_.CreateUniqueTempDir(); |
| 38 } | 38 } |
| 39 | 39 |
| 40 void FakeDriveFileSystem::Initialize() { | 40 void FakeFileSystem::Initialize() { |
| 41 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 41 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 42 InitializeForTesting(); | 42 InitializeForTesting(); |
| 43 } | 43 } |
| 44 | 44 |
| 45 void FakeDriveFileSystem::AddObserver(FileSystemObserver* observer) { | 45 void FakeFileSystem::AddObserver(FileSystemObserver* observer) { |
| 46 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 46 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 47 } | 47 } |
| 48 | 48 |
| 49 void FakeDriveFileSystem::RemoveObserver(FileSystemObserver* observer) { | 49 void FakeFileSystem::RemoveObserver(FileSystemObserver* observer) { |
| 50 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 50 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 51 } | 51 } |
| 52 | 52 |
| 53 void FakeDriveFileSystem::CheckForUpdates() { | 53 void FakeFileSystem::CheckForUpdates() { |
| 54 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 54 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 55 } | 55 } |
| 56 | 56 |
| 57 void FakeDriveFileSystem::GetEntryInfoByResourceId( | 57 void FakeFileSystem::GetEntryInfoByResourceId( |
| 58 const std::string& resource_id, | 58 const std::string& resource_id, |
| 59 const GetEntryInfoWithFilePathCallback& callback) { | 59 const GetEntryInfoWithFilePathCallback& callback) { |
| 60 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 60 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 61 | 61 |
| 62 drive_service_->GetResourceEntry( | 62 drive_service_->GetResourceEntry( |
| 63 resource_id, | 63 resource_id, |
| 64 base::Bind( | 64 base::Bind( |
| 65 &FakeDriveFileSystem::GetEntryInfoByResourceIdAfterGetResourceEntry, | 65 &FakeFileSystem::GetEntryInfoByResourceIdAfterGetResourceEntry, |
| 66 weak_ptr_factory_.GetWeakPtr(), callback)); | 66 weak_ptr_factory_.GetWeakPtr(), callback)); |
| 67 } | 67 } |
| 68 | 68 |
| 69 void FakeDriveFileSystem::TransferFileFromRemoteToLocal( | 69 void FakeFileSystem::TransferFileFromRemoteToLocal( |
| 70 const base::FilePath& remote_src_file_path, | 70 const base::FilePath& remote_src_file_path, |
| 71 const base::FilePath& local_dest_file_path, | 71 const base::FilePath& local_dest_file_path, |
| 72 const FileOperationCallback& callback) { | 72 const FileOperationCallback& callback) { |
| 73 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 73 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 74 } | 74 } |
| 75 | 75 |
| 76 void FakeDriveFileSystem::TransferFileFromLocalToRemote( | 76 void FakeFileSystem::TransferFileFromLocalToRemote( |
| 77 const base::FilePath& local_src_file_path, | 77 const base::FilePath& local_src_file_path, |
| 78 const base::FilePath& remote_dest_file_path, | 78 const base::FilePath& remote_dest_file_path, |
| 79 const FileOperationCallback& callback) { | 79 const FileOperationCallback& callback) { |
| 80 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 80 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 81 } | 81 } |
| 82 | 82 |
| 83 void FakeDriveFileSystem::OpenFile(const base::FilePath& file_path, | 83 void FakeFileSystem::OpenFile(const base::FilePath& file_path, |
| 84 const OpenFileCallback& callback) { | 84 const OpenFileCallback& callback) { |
| 85 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 85 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 86 } | 86 } |
| 87 | 87 |
| 88 void FakeDriveFileSystem::CloseFile(const base::FilePath& file_path, | 88 void FakeFileSystem::CloseFile(const base::FilePath& file_path, |
| 89 const FileOperationCallback& callback) { | |
| 90 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | |
| 91 } | |
| 92 | |
| 93 void FakeDriveFileSystem::Copy(const base::FilePath& src_file_path, | |
| 94 const base::FilePath& dest_file_path, | |
| 95 const FileOperationCallback& callback) { | 89 const FileOperationCallback& callback) { |
| 96 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 90 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 97 } | 91 } |
| 98 | 92 |
| 99 void FakeDriveFileSystem::Move(const base::FilePath& src_file_path, | 93 void FakeFileSystem::Copy(const base::FilePath& src_file_path, |
| 100 const base::FilePath& dest_file_path, | 94 const base::FilePath& dest_file_path, |
| 101 const FileOperationCallback& callback) { | 95 const FileOperationCallback& callback) { |
| 102 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 96 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 103 } | 97 } |
| 104 | 98 |
| 105 void FakeDriveFileSystem::Remove(const base::FilePath& file_path, | 99 void FakeFileSystem::Move(const base::FilePath& src_file_path, |
| 106 bool is_recursive, | 100 const base::FilePath& dest_file_path, |
| 107 const FileOperationCallback& callback) { | 101 const FileOperationCallback& callback) { |
| 108 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 102 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 109 } | 103 } |
| 110 | 104 |
| 111 void FakeDriveFileSystem::CreateDirectory( | 105 void FakeFileSystem::Remove(const base::FilePath& file_path, |
| 106 bool is_recursive, |
| 107 const FileOperationCallback& callback) { |
| 108 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 109 } |
| 110 |
| 111 void FakeFileSystem::CreateDirectory( |
| 112 const base::FilePath& directory_path, | 112 const base::FilePath& directory_path, |
| 113 bool is_exclusive, | 113 bool is_exclusive, |
| 114 bool is_recursive, | 114 bool is_recursive, |
| 115 const FileOperationCallback& callback) { | 115 const FileOperationCallback& callback) { |
| 116 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 116 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 117 } | 117 } |
| 118 | 118 |
| 119 void FakeDriveFileSystem::CreateFile(const base::FilePath& file_path, | 119 void FakeFileSystem::CreateFile(const base::FilePath& file_path, |
| 120 bool is_exclusive, | 120 bool is_exclusive, |
| 121 const FileOperationCallback& callback) { | |
| 122 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | |
| 123 } | |
| 124 | |
| 125 void FakeDriveFileSystem::Pin(const base::FilePath& file_path, | |
| 126 const FileOperationCallback& callback) { | |
| 127 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | |
| 128 } | |
| 129 | |
| 130 void FakeDriveFileSystem::Unpin(const base::FilePath& file_path, | |
| 131 const FileOperationCallback& callback) { | 121 const FileOperationCallback& callback) { |
| 132 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 122 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 133 } | 123 } |
| 134 | 124 |
| 135 void FakeDriveFileSystem::GetFileByPath(const base::FilePath& file_path, | 125 void FakeFileSystem::Pin(const base::FilePath& file_path, |
| 136 const GetFileCallback& callback) { | 126 const FileOperationCallback& callback) { |
| 137 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 127 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 138 } | 128 } |
| 139 | 129 |
| 140 void FakeDriveFileSystem::GetFileByResourceId( | 130 void FakeFileSystem::Unpin(const base::FilePath& file_path, |
| 131 const FileOperationCallback& callback) { |
| 132 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 133 } |
| 134 |
| 135 void FakeFileSystem::GetFileByPath(const base::FilePath& file_path, |
| 136 const GetFileCallback& callback) { |
| 137 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 138 } |
| 139 |
| 140 void FakeFileSystem::GetFileByResourceId( |
| 141 const std::string& resource_id, | 141 const std::string& resource_id, |
| 142 const DriveClientContext& context, | 142 const DriveClientContext& context, |
| 143 const GetFileCallback& get_file_callback, | 143 const GetFileCallback& get_file_callback, |
| 144 const google_apis::GetContentCallback& get_content_callback) { | 144 const google_apis::GetContentCallback& get_content_callback) { |
| 145 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 145 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 146 } | 146 } |
| 147 | 147 |
| 148 void FakeDriveFileSystem::GetFileContentByPath( | 148 void FakeFileSystem::GetFileContentByPath( |
| 149 const base::FilePath& file_path, | 149 const base::FilePath& file_path, |
| 150 const GetFileContentInitializedCallback& initialized_callback, | 150 const GetFileContentInitializedCallback& initialized_callback, |
| 151 const google_apis::GetContentCallback& get_content_callback, | 151 const google_apis::GetContentCallback& get_content_callback, |
| 152 const FileOperationCallback& completion_callback) { | 152 const FileOperationCallback& completion_callback) { |
| 153 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 153 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 154 | 154 |
| 155 GetEntryInfoByPath( | 155 GetEntryInfoByPath( |
| 156 file_path, | 156 file_path, |
| 157 base::Bind(&FakeDriveFileSystem::GetFileContentByPathAfterGetEntryInfo, | 157 base::Bind(&FakeFileSystem::GetFileContentByPathAfterGetEntryInfo, |
| 158 weak_ptr_factory_.GetWeakPtr(), | 158 weak_ptr_factory_.GetWeakPtr(), |
| 159 file_path, initialized_callback, get_content_callback, | 159 file_path, initialized_callback, get_content_callback, |
| 160 completion_callback)); | 160 completion_callback)); |
| 161 } | 161 } |
| 162 | 162 |
| 163 void FakeDriveFileSystem::UpdateFileByResourceId( | 163 void FakeFileSystem::UpdateFileByResourceId( |
| 164 const std::string& resource_id, | 164 const std::string& resource_id, |
| 165 const DriveClientContext& context, | 165 const DriveClientContext& context, |
| 166 const FileOperationCallback& callback) { | 166 const FileOperationCallback& callback) { |
| 167 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 167 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 168 } | 168 } |
| 169 | 169 |
| 170 void FakeDriveFileSystem::GetEntryInfoByPath( | 170 void FakeFileSystem::GetEntryInfoByPath( |
| 171 const base::FilePath& file_path, | 171 const base::FilePath& file_path, |
| 172 const GetEntryInfoCallback& callback) { | 172 const GetEntryInfoCallback& callback) { |
| 173 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 173 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 174 | 174 |
| 175 // Now, we only support files under my drive. | 175 // Now, we only support files under my drive. |
| 176 DCHECK(!util::IsUnderDriveMountPoint(file_path)); | 176 DCHECK(!util::IsUnderDriveMountPoint(file_path)); |
| 177 | 177 |
| 178 if (file_path == util::GetDriveMyDriveRootPath()) { | 178 if (file_path == util::GetDriveMyDriveRootPath()) { |
| 179 // Specialized for the root entry. | 179 // Specialized for the root entry. |
| 180 drive_service_->GetAboutResource( | 180 drive_service_->GetAboutResource( |
| 181 base::Bind( | 181 base::Bind( |
| 182 &FakeDriveFileSystem::GetEntryInfoByPathAfterGetAboutResource, | 182 &FakeFileSystem::GetEntryInfoByPathAfterGetAboutResource, |
| 183 weak_ptr_factory_.GetWeakPtr(), callback)); | 183 weak_ptr_factory_.GetWeakPtr(), callback)); |
| 184 return; | 184 return; |
| 185 } | 185 } |
| 186 | 186 |
| 187 GetEntryInfoByPath( | 187 GetEntryInfoByPath( |
| 188 file_path.DirName(), | 188 file_path.DirName(), |
| 189 base::Bind( | 189 base::Bind( |
| 190 &FakeDriveFileSystem::GetEntryInfoByPathAfterGetParentEntryInfo, | 190 &FakeFileSystem::GetEntryInfoByPathAfterGetParentEntryInfo, |
| 191 weak_ptr_factory_.GetWeakPtr(), file_path.BaseName(), callback)); | 191 weak_ptr_factory_.GetWeakPtr(), file_path.BaseName(), callback)); |
| 192 } | 192 } |
| 193 | 193 |
| 194 void FakeDriveFileSystem::ReadDirectoryByPath( | 194 void FakeFileSystem::ReadDirectoryByPath( |
| 195 const base::FilePath& file_path, | 195 const base::FilePath& file_path, |
| 196 const ReadDirectoryWithSettingCallback& callback) { | 196 const ReadDirectoryWithSettingCallback& callback) { |
| 197 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 197 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 198 } | 198 } |
| 199 | 199 |
| 200 void FakeDriveFileSystem::RefreshDirectory( | 200 void FakeFileSystem::RefreshDirectory( |
| 201 const base::FilePath& file_path, | 201 const base::FilePath& file_path, |
| 202 const FileOperationCallback& callback) { | 202 const FileOperationCallback& callback) { |
| 203 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 203 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 204 } | 204 } |
| 205 | 205 |
| 206 void FakeDriveFileSystem::Search(const std::string& search_query, | 206 void FakeFileSystem::Search(const std::string& search_query, |
| 207 const GURL& next_feed, | 207 const GURL& next_feed, |
| 208 const SearchCallback& callback) { | 208 const SearchCallback& callback) { |
| 209 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 209 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 210 } | 210 } |
| 211 | 211 |
| 212 void FakeDriveFileSystem::SearchMetadata( | 212 void FakeFileSystem::SearchMetadata( |
| 213 const std::string& query, | 213 const std::string& query, |
| 214 int options, | 214 int options, |
| 215 int at_most_num_matches, | 215 int at_most_num_matches, |
| 216 const SearchMetadataCallback& callback) { | 216 const SearchMetadataCallback& callback) { |
| 217 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 217 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 218 } | 218 } |
| 219 | 219 |
| 220 void FakeDriveFileSystem::GetAvailableSpace( | 220 void FakeFileSystem::GetAvailableSpace( |
| 221 const GetAvailableSpaceCallback& callback) { | 221 const GetAvailableSpaceCallback& callback) { |
| 222 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 222 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 223 } | 223 } |
| 224 | 224 |
| 225 void FakeDriveFileSystem::AddUploadedFile( | 225 void FakeFileSystem::AddUploadedFile( |
| 226 scoped_ptr<google_apis::ResourceEntry> doc_entry, | 226 scoped_ptr<google_apis::ResourceEntry> doc_entry, |
| 227 const base::FilePath& file_content_path, | 227 const base::FilePath& file_content_path, |
| 228 const FileOperationCallback& callback) { | 228 const FileOperationCallback& callback) { |
| 229 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 229 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 230 } | 230 } |
| 231 | 231 |
| 232 void FakeDriveFileSystem::GetMetadata( | 232 void FakeFileSystem::GetMetadata( |
| 233 const GetFilesystemMetadataCallback& callback) { | 233 const GetFilesystemMetadataCallback& callback) { |
| 234 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 234 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 235 } | 235 } |
| 236 | 236 |
| 237 void FakeDriveFileSystem::MarkCacheFileAsMounted( | 237 void FakeFileSystem::MarkCacheFileAsMounted( |
| 238 const base::FilePath& drive_file_path, | 238 const base::FilePath& drive_file_path, |
| 239 const OpenFileCallback& callback) { | 239 const OpenFileCallback& callback) { |
| 240 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 240 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 241 } | 241 } |
| 242 | 242 |
| 243 void FakeDriveFileSystem::MarkCacheFileAsUnmounted( | 243 void FakeFileSystem::MarkCacheFileAsUnmounted( |
| 244 const base::FilePath& cache_file_path, | 244 const base::FilePath& cache_file_path, |
| 245 const FileOperationCallback& callback) { | 245 const FileOperationCallback& callback) { |
| 246 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 246 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 247 } | 247 } |
| 248 | 248 |
| 249 void FakeDriveFileSystem::GetCacheEntryByResourceId( | 249 void FakeFileSystem::GetCacheEntryByResourceId( |
| 250 const std::string& resource_id, | 250 const std::string& resource_id, |
| 251 const std::string& md5, | 251 const std::string& md5, |
| 252 const GetCacheEntryCallback& callback) { | 252 const GetCacheEntryCallback& callback) { |
| 253 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 253 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 254 } | 254 } |
| 255 | 255 |
| 256 void FakeDriveFileSystem::IterateCache( | 256 void FakeFileSystem::IterateCache( |
| 257 const CacheIterateCallback& iteration_callback, | 257 const CacheIterateCallback& iteration_callback, |
| 258 const base::Closure& completion_callback) { | 258 const base::Closure& completion_callback) { |
| 259 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 259 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 260 } | 260 } |
| 261 | 261 |
| 262 void FakeDriveFileSystem::Reload() { | 262 void FakeFileSystem::Reload() { |
| 263 } | 263 } |
| 264 | 264 |
| 265 // Implementation of GetFilePath. | 265 // Implementation of GetFilePath. |
| 266 void FakeDriveFileSystem::GetFilePath(const std::string& resource_id, | 266 void FakeFileSystem::GetFilePath(const std::string& resource_id, |
| 267 const GetFilePathCallback& callback) { | 267 const GetFilePathCallback& callback) { |
| 268 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 268 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 269 | 269 |
| 270 drive_service_->GetAboutResource( | 270 drive_service_->GetAboutResource( |
| 271 base::Bind( | 271 base::Bind( |
| 272 &FakeDriveFileSystem::GetFilePathAfterGetAboutResource, | 272 &FakeFileSystem::GetFilePathAfterGetAboutResource, |
| 273 weak_ptr_factory_.GetWeakPtr(), resource_id, callback)); | 273 weak_ptr_factory_.GetWeakPtr(), resource_id, callback)); |
| 274 } | 274 } |
| 275 | 275 |
| 276 void FakeDriveFileSystem::GetFilePathAfterGetAboutResource( | 276 void FakeFileSystem::GetFilePathAfterGetAboutResource( |
| 277 const std::string& resource_id, | 277 const std::string& resource_id, |
| 278 const GetFilePathCallback& callback, | 278 const GetFilePathCallback& callback, |
| 279 google_apis::GDataErrorCode error, | 279 google_apis::GDataErrorCode error, |
| 280 scoped_ptr<google_apis::AboutResource> about_resource) { | 280 scoped_ptr<google_apis::AboutResource> about_resource) { |
| 281 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 281 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 282 | 282 |
| 283 // We assume the call always success for test. | 283 // We assume the call always success for test. |
| 284 DCHECK_EQ(util::GDataToFileError(error), FILE_ERROR_OK); | 284 DCHECK_EQ(util::GDataToFileError(error), FILE_ERROR_OK); |
| 285 DCHECK(about_resource); | 285 DCHECK(about_resource); |
| 286 | 286 |
| 287 GetFilePathInternal(about_resource->root_folder_id(), resource_id, | 287 GetFilePathInternal(about_resource->root_folder_id(), resource_id, |
| 288 base::FilePath(), callback); | 288 base::FilePath(), callback); |
| 289 } | 289 } |
| 290 | 290 |
| 291 void FakeDriveFileSystem::GetFilePathInternal( | 291 void FakeFileSystem::GetFilePathInternal( |
| 292 const std::string& root_resource_id, | 292 const std::string& root_resource_id, |
| 293 const std::string& resource_id, | 293 const std::string& resource_id, |
| 294 const base::FilePath& file_path, | 294 const base::FilePath& file_path, |
| 295 const GetFilePathCallback& callback) { | 295 const GetFilePathCallback& callback) { |
| 296 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 296 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 297 | 297 |
| 298 if (resource_id == root_resource_id) { | 298 if (resource_id == root_resource_id) { |
| 299 // Reached to the root. Append the drive root path, and run |callback|. | 299 // Reached to the root. Append the drive root path, and run |callback|. |
| 300 callback.Run(util::GetDriveMyDriveRootPath().Append(file_path)); | 300 callback.Run(util::GetDriveMyDriveRootPath().Append(file_path)); |
| 301 return; | 301 return; |
| 302 } | 302 } |
| 303 | 303 |
| 304 drive_service_->GetResourceEntry( | 304 drive_service_->GetResourceEntry( |
| 305 resource_id, | 305 resource_id, |
| 306 base::Bind( | 306 base::Bind( |
| 307 &FakeDriveFileSystem::GetFilePathAfterGetResourceEntry, | 307 &FakeFileSystem::GetFilePathAfterGetResourceEntry, |
| 308 weak_ptr_factory_.GetWeakPtr(), | 308 weak_ptr_factory_.GetWeakPtr(), |
| 309 root_resource_id, file_path, callback)); | 309 root_resource_id, file_path, callback)); |
| 310 } | 310 } |
| 311 | 311 |
| 312 void FakeDriveFileSystem::GetFilePathAfterGetResourceEntry( | 312 void FakeFileSystem::GetFilePathAfterGetResourceEntry( |
| 313 const std::string& root_resource_id, | 313 const std::string& root_resource_id, |
| 314 const base::FilePath& remaining_file_path, | 314 const base::FilePath& remaining_file_path, |
| 315 const GetFilePathCallback& callback, | 315 const GetFilePathCallback& callback, |
| 316 google_apis::GDataErrorCode error_in, | 316 google_apis::GDataErrorCode error_in, |
| 317 scoped_ptr<google_apis::ResourceEntry> resource_entry) { | 317 scoped_ptr<google_apis::ResourceEntry> resource_entry) { |
| 318 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 318 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 319 | 319 |
| 320 // We assume the call always success for test. | 320 // We assume the call always success for test. |
| 321 DCHECK_EQ(util::GDataToFileError(error_in), FILE_ERROR_OK); | 321 DCHECK_EQ(util::GDataToFileError(error_in), FILE_ERROR_OK); |
| 322 DCHECK(resource_entry); | 322 DCHECK(resource_entry); |
| 323 | 323 |
| 324 DriveEntryProto entry_proto = | 324 DriveEntryProto entry_proto = |
| 325 ConvertResourceEntryToDriveEntryProto(*resource_entry); | 325 ConvertResourceEntryToDriveEntryProto(*resource_entry); |
| 326 base::FilePath file_path = | 326 base::FilePath file_path = |
| 327 base::FilePath::FromUTF8Unsafe(entry_proto.base_name()).Append( | 327 base::FilePath::FromUTF8Unsafe(entry_proto.base_name()).Append( |
| 328 remaining_file_path); | 328 remaining_file_path); |
| 329 | 329 |
| 330 GetFilePathInternal(root_resource_id, entry_proto.parent_resource_id(), | 330 GetFilePathInternal(root_resource_id, entry_proto.parent_resource_id(), |
| 331 file_path, callback); | 331 file_path, callback); |
| 332 } | 332 } |
| 333 | 333 |
| 334 // Implementation of GetEntryInfoByResourceId. | 334 // Implementation of GetEntryInfoByResourceId. |
| 335 void FakeDriveFileSystem::GetEntryInfoByResourceIdAfterGetResourceEntry( | 335 void FakeFileSystem::GetEntryInfoByResourceIdAfterGetResourceEntry( |
| 336 const GetEntryInfoWithFilePathCallback& callback, | 336 const GetEntryInfoWithFilePathCallback& callback, |
| 337 google_apis::GDataErrorCode error_in, | 337 google_apis::GDataErrorCode error_in, |
| 338 scoped_ptr<google_apis::ResourceEntry> resource_entry) { | 338 scoped_ptr<google_apis::ResourceEntry> resource_entry) { |
| 339 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 339 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 340 | 340 |
| 341 FileError error = util::GDataToFileError(error_in); | 341 FileError error = util::GDataToFileError(error_in); |
| 342 if (error != FILE_ERROR_OK) { | 342 if (error != FILE_ERROR_OK) { |
| 343 callback.Run(error, base::FilePath(), scoped_ptr<DriveEntryProto>()); | 343 callback.Run(error, base::FilePath(), scoped_ptr<DriveEntryProto>()); |
| 344 return; | 344 return; |
| 345 } | 345 } |
| 346 | 346 |
| 347 DCHECK(resource_entry); | 347 DCHECK(resource_entry); |
| 348 scoped_ptr<DriveEntryProto> entry_proto(new DriveEntryProto( | 348 scoped_ptr<DriveEntryProto> entry_proto(new DriveEntryProto( |
| 349 ConvertResourceEntryToDriveEntryProto(*resource_entry))); | 349 ConvertResourceEntryToDriveEntryProto(*resource_entry))); |
| 350 | 350 |
| 351 const std::string parent_resource_id = entry_proto->parent_resource_id(); | 351 const std::string parent_resource_id = entry_proto->parent_resource_id(); |
| 352 GetFilePath( | 352 GetFilePath( |
| 353 parent_resource_id, | 353 parent_resource_id, |
| 354 base::Bind( | 354 base::Bind( |
| 355 &FakeDriveFileSystem::GetEntryInfoByResourceIdAfterGetFilePath, | 355 &FakeFileSystem::GetEntryInfoByResourceIdAfterGetFilePath, |
| 356 weak_ptr_factory_.GetWeakPtr(), | 356 weak_ptr_factory_.GetWeakPtr(), |
| 357 callback, error, base::Passed(&entry_proto))); | 357 callback, error, base::Passed(&entry_proto))); |
| 358 } | 358 } |
| 359 | 359 |
| 360 void FakeDriveFileSystem::GetEntryInfoByResourceIdAfterGetFilePath( | 360 void FakeFileSystem::GetEntryInfoByResourceIdAfterGetFilePath( |
| 361 const GetEntryInfoWithFilePathCallback& callback, | 361 const GetEntryInfoWithFilePathCallback& callback, |
| 362 FileError error, | 362 FileError error, |
| 363 scoped_ptr<DriveEntryProto> entry_proto, | 363 scoped_ptr<DriveEntryProto> entry_proto, |
| 364 const base::FilePath& parent_file_path) { | 364 const base::FilePath& parent_file_path) { |
| 365 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 365 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 366 base::FilePath file_path = parent_file_path.Append( | 366 base::FilePath file_path = parent_file_path.Append( |
| 367 base::FilePath::FromUTF8Unsafe(entry_proto->base_name())); | 367 base::FilePath::FromUTF8Unsafe(entry_proto->base_name())); |
| 368 callback.Run(error, file_path, entry_proto.Pass()); | 368 callback.Run(error, file_path, entry_proto.Pass()); |
| 369 } | 369 } |
| 370 | 370 |
| 371 // Implementation of GetFileContentByPath. | 371 // Implementation of GetFileContentByPath. |
| 372 void FakeDriveFileSystem::GetFileContentByPathAfterGetEntryInfo( | 372 void FakeFileSystem::GetFileContentByPathAfterGetEntryInfo( |
| 373 const base::FilePath& file_path, | 373 const base::FilePath& file_path, |
| 374 const GetFileContentInitializedCallback& initialized_callback, | 374 const GetFileContentInitializedCallback& initialized_callback, |
| 375 const google_apis::GetContentCallback& get_content_callback, | 375 const google_apis::GetContentCallback& get_content_callback, |
| 376 const FileOperationCallback& completion_callback, | 376 const FileOperationCallback& completion_callback, |
| 377 FileError error, | 377 FileError error, |
| 378 scoped_ptr<DriveEntryProto> entry_proto) { | 378 scoped_ptr<DriveEntryProto> entry_proto) { |
| 379 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 379 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 380 | 380 |
| 381 if (error != FILE_ERROR_OK) { | 381 if (error != FILE_ERROR_OK) { |
| 382 completion_callback.Run(error); | 382 completion_callback.Run(error); |
| (...skipping 18 matching lines...) Expand all Loading... |
| 401 } | 401 } |
| 402 | 402 |
| 403 // Copy the URL here before passing |entry_proto| to the callback. | 403 // Copy the URL here before passing |entry_proto| to the callback. |
| 404 const GURL download_url(entry_proto->download_url()); | 404 const GURL download_url(entry_proto->download_url()); |
| 405 initialized_callback.Run(FILE_ERROR_OK, entry_proto.Pass(), base::FilePath(), | 405 initialized_callback.Run(FILE_ERROR_OK, entry_proto.Pass(), base::FilePath(), |
| 406 base::Bind(&base::DoNothing)); | 406 base::Bind(&base::DoNothing)); |
| 407 drive_service_->DownloadFile( | 407 drive_service_->DownloadFile( |
| 408 file_path, | 408 file_path, |
| 409 cache_path, | 409 cache_path, |
| 410 download_url, | 410 download_url, |
| 411 base::Bind(&FakeDriveFileSystem::GetFileContentByPathAfterDownloadFile, | 411 base::Bind(&FakeFileSystem::GetFileContentByPathAfterDownloadFile, |
| 412 weak_ptr_factory_.GetWeakPtr(), | 412 weak_ptr_factory_.GetWeakPtr(), |
| 413 completion_callback), | 413 completion_callback), |
| 414 get_content_callback, | 414 get_content_callback, |
| 415 google_apis::ProgressCallback()); | 415 google_apis::ProgressCallback()); |
| 416 } | 416 } |
| 417 | 417 |
| 418 void FakeDriveFileSystem::GetFileContentByPathAfterDownloadFile( | 418 void FakeFileSystem::GetFileContentByPathAfterDownloadFile( |
| 419 const FileOperationCallback& completion_callback, | 419 const FileOperationCallback& completion_callback, |
| 420 google_apis::GDataErrorCode gdata_error, | 420 google_apis::GDataErrorCode gdata_error, |
| 421 const base::FilePath& temp_file) { | 421 const base::FilePath& temp_file) { |
| 422 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 422 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 423 completion_callback.Run(util::GDataToFileError(gdata_error)); | 423 completion_callback.Run(util::GDataToFileError(gdata_error)); |
| 424 } | 424 } |
| 425 | 425 |
| 426 // Implementation of GetEntryInfoByPath. | 426 // Implementation of GetEntryInfoByPath. |
| 427 void FakeDriveFileSystem::GetEntryInfoByPathAfterGetAboutResource( | 427 void FakeFileSystem::GetEntryInfoByPathAfterGetAboutResource( |
| 428 const GetEntryInfoCallback& callback, | 428 const GetEntryInfoCallback& callback, |
| 429 google_apis::GDataErrorCode gdata_error, | 429 google_apis::GDataErrorCode gdata_error, |
| 430 scoped_ptr<google_apis::AboutResource> about_resource) { | 430 scoped_ptr<google_apis::AboutResource> about_resource) { |
| 431 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 431 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 432 | 432 |
| 433 FileError error = util::GDataToFileError(gdata_error); | 433 FileError error = util::GDataToFileError(gdata_error); |
| 434 if (error != FILE_ERROR_OK) { | 434 if (error != FILE_ERROR_OK) { |
| 435 callback.Run(error, scoped_ptr<DriveEntryProto>()); | 435 callback.Run(error, scoped_ptr<DriveEntryProto>()); |
| 436 return; | 436 return; |
| 437 } | 437 } |
| 438 | 438 |
| 439 DCHECK(about_resource); | 439 DCHECK(about_resource); |
| 440 scoped_ptr<DriveEntryProto> root(new DriveEntryProto); | 440 scoped_ptr<DriveEntryProto> root(new DriveEntryProto); |
| 441 root->mutable_file_info()->set_is_directory(true); | 441 root->mutable_file_info()->set_is_directory(true); |
| 442 root->set_resource_id(about_resource->root_folder_id()); | 442 root->set_resource_id(about_resource->root_folder_id()); |
| 443 root->set_title(util::kDriveMyDriveRootDirName); | 443 root->set_title(util::kDriveMyDriveRootDirName); |
| 444 callback.Run(error, root.Pass()); | 444 callback.Run(error, root.Pass()); |
| 445 } | 445 } |
| 446 | 446 |
| 447 void FakeDriveFileSystem::GetEntryInfoByPathAfterGetParentEntryInfo( | 447 void FakeFileSystem::GetEntryInfoByPathAfterGetParentEntryInfo( |
| 448 const base::FilePath& base_name, | 448 const base::FilePath& base_name, |
| 449 const GetEntryInfoCallback& callback, | 449 const GetEntryInfoCallback& callback, |
| 450 FileError error, | 450 FileError error, |
| 451 scoped_ptr<DriveEntryProto> parent_entry_proto) { | 451 scoped_ptr<DriveEntryProto> parent_entry_proto) { |
| 452 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 452 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 453 | 453 |
| 454 if (error != FILE_ERROR_OK) { | 454 if (error != FILE_ERROR_OK) { |
| 455 callback.Run(error, scoped_ptr<DriveEntryProto>()); | 455 callback.Run(error, scoped_ptr<DriveEntryProto>()); |
| 456 return; | 456 return; |
| 457 } | 457 } |
| 458 | 458 |
| 459 DCHECK(parent_entry_proto); | 459 DCHECK(parent_entry_proto); |
| 460 drive_service_->GetResourceListInDirectory( | 460 drive_service_->GetResourceListInDirectory( |
| 461 parent_entry_proto->resource_id(), | 461 parent_entry_proto->resource_id(), |
| 462 base::Bind( | 462 base::Bind( |
| 463 &FakeDriveFileSystem::GetEntryInfoByPathAfterGetResourceList, | 463 &FakeFileSystem::GetEntryInfoByPathAfterGetResourceList, |
| 464 weak_ptr_factory_.GetWeakPtr(), base_name, callback)); | 464 weak_ptr_factory_.GetWeakPtr(), base_name, callback)); |
| 465 } | 465 } |
| 466 | 466 |
| 467 void FakeDriveFileSystem::GetEntryInfoByPathAfterGetResourceList( | 467 void FakeFileSystem::GetEntryInfoByPathAfterGetResourceList( |
| 468 const base::FilePath& base_name, | 468 const base::FilePath& base_name, |
| 469 const GetEntryInfoCallback& callback, | 469 const GetEntryInfoCallback& callback, |
| 470 google_apis::GDataErrorCode gdata_error, | 470 google_apis::GDataErrorCode gdata_error, |
| 471 scoped_ptr<google_apis::ResourceList> resource_list) { | 471 scoped_ptr<google_apis::ResourceList> resource_list) { |
| 472 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 472 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 473 | 473 |
| 474 FileError error = util::GDataToFileError(gdata_error); | 474 FileError error = util::GDataToFileError(gdata_error); |
| 475 if (error != FILE_ERROR_OK) { | 475 if (error != FILE_ERROR_OK) { |
| 476 callback.Run(error, scoped_ptr<DriveEntryProto>()); | 476 callback.Run(error, scoped_ptr<DriveEntryProto>()); |
| 477 return; | 477 return; |
| (...skipping 10 matching lines...) Expand all Loading... |
| 488 callback.Run(FILE_ERROR_OK, entry.Pass()); | 488 callback.Run(FILE_ERROR_OK, entry.Pass()); |
| 489 return; | 489 return; |
| 490 } | 490 } |
| 491 } | 491 } |
| 492 | 492 |
| 493 callback.Run(FILE_ERROR_NOT_FOUND, scoped_ptr<DriveEntryProto>()); | 493 callback.Run(FILE_ERROR_NOT_FOUND, scoped_ptr<DriveEntryProto>()); |
| 494 } | 494 } |
| 495 | 495 |
| 496 } // namespace test_util | 496 } // namespace test_util |
| 497 } // namespace drive | 497 } // namespace drive |
| OLD | NEW |