diff options
author | kinuko@chromium.org <kinuko@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2013-05-28 02:08:07 +0000 |
---|---|---|
committer | kinuko@chromium.org <kinuko@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2013-05-28 02:08:07 +0000 |
commit | c6f9203a46211bb08b84f73b4e1df303f1ab8c42 (patch) | |
tree | b8774c1e80f5e37c7f31a889023962fb3eb1bb7e /webkit/browser/fileapi/test_mount_point_provider.h | |
parent | ba7e19a2704f1c4772d1f1f3a45a2b2b78c0bbd7 (diff) | |
download | chromium_src-c6f9203a46211bb08b84f73b4e1df303f1ab8c42.zip chromium_src-c6f9203a46211bb08b84f73b4e1df303f1ab8c42.tar.gz chromium_src-c6f9203a46211bb08b84f73b4e1df303f1ab8c42.tar.bz2 |
Move browser-specific FileAPI code from webkit/fileapi to webkit/browser/fileapi
Moving following files:
- file_system_context*
- file_system_operation*
- file_system_url*
- and all others but not in syncable/ ones
BUG=239710
TBR=avi@chromium.org, tzik@chromium.org
Review URL: https://codereview.chromium.org/15859007
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@202482 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'webkit/browser/fileapi/test_mount_point_provider.h')
-rw-r--r-- | webkit/browser/fileapi/test_mount_point_provider.h | 104 |
1 files changed, 104 insertions, 0 deletions
diff --git a/webkit/browser/fileapi/test_mount_point_provider.h b/webkit/browser/fileapi/test_mount_point_provider.h new file mode 100644 index 0000000..2dddb3c --- /dev/null +++ b/webkit/browser/fileapi/test_mount_point_provider.h @@ -0,0 +1,104 @@ +// Copyright (c) 2012 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef WEBKIT_BROWSER_FILEAPI_TEST_MOUNT_POINT_PROVIDER_H_ +#define WEBKIT_BROWSER_FILEAPI_TEST_MOUNT_POINT_PROVIDER_H_ + +#include "base/files/file_path.h" +#include "base/memory/ref_counted.h" +#include "base/memory/scoped_ptr.h" +#include "webkit/browser/fileapi/async_file_util_adapter.h" +#include "webkit/browser/fileapi/file_system_mount_point_provider.h" +#include "webkit/browser/fileapi/task_runner_bound_observer_list.h" +#include "webkit/storage/webkit_storage_export.h" + +namespace base { +class SequencedTaskRunner; +} + +namespace fileapi { + +class AsyncFileUtilAdapter; +class FileSystemQuotaUtil; + +// This should be only used for testing. +// This mount point provider uses LocalFileUtil and stores data file +// under the given directory. +class WEBKIT_STORAGE_EXPORT_PRIVATE TestMountPointProvider + : public FileSystemMountPointProvider { + public: + TestMountPointProvider( + base::SequencedTaskRunner* task_runner, + const base::FilePath& base_path); + virtual ~TestMountPointProvider(); + + // FileSystemMountPointProvider implementation. + virtual bool CanHandleType(FileSystemType type) const OVERRIDE; + virtual void ValidateFileSystemRoot( + const GURL& origin_url, + FileSystemType type, + bool create, + const ValidateFileSystemCallback& callback) OVERRIDE; + virtual base::FilePath GetFileSystemRootPathOnFileThread( + const FileSystemURL& url, + bool create) OVERRIDE; + virtual FileSystemFileUtil* GetFileUtil(FileSystemType type) OVERRIDE; + virtual AsyncFileUtil* GetAsyncFileUtil(FileSystemType type) OVERRIDE; + virtual CopyOrMoveFileValidatorFactory* GetCopyOrMoveFileValidatorFactory( + FileSystemType type, + base::PlatformFileError* error_code) OVERRIDE; + virtual void InitializeCopyOrMoveFileValidatorFactory( + FileSystemType type, + scoped_ptr<CopyOrMoveFileValidatorFactory> factory) OVERRIDE; + virtual FilePermissionPolicy GetPermissionPolicy( + const FileSystemURL& url, + int permissions) const OVERRIDE; + virtual FileSystemOperation* CreateFileSystemOperation( + const FileSystemURL& url, + FileSystemContext* context, + base::PlatformFileError* error_code) const OVERRIDE; + virtual scoped_ptr<webkit_blob::FileStreamReader> CreateFileStreamReader( + const FileSystemURL& url, + int64 offset, + const base::Time& expected_modification_time, + FileSystemContext* context) const OVERRIDE; + virtual scoped_ptr<FileStreamWriter> CreateFileStreamWriter( + const FileSystemURL& url, + int64 offset, + FileSystemContext* context) const OVERRIDE; + virtual FileSystemQuotaUtil* GetQuotaUtil() OVERRIDE; + virtual void DeleteFileSystem( + const GURL& origin_url, + FileSystemType type, + FileSystemContext* context, + const DeleteFileSystemCallback& callback) OVERRIDE; + + const UpdateObserverList* GetUpdateObservers(FileSystemType type) const; + + // For CopyOrMoveFileValidatorFactory testing. Once it's set to true + // GetCopyOrMoveFileValidatorFactory will start returning security + // error if validator is not initialized. + void set_require_copy_or_move_validator(bool flag) { + require_copy_or_move_validator_ = flag; + } + + private: + class QuotaUtil; + + base::FilePath base_path_; + scoped_refptr<base::SequencedTaskRunner> task_runner_; + scoped_ptr<AsyncFileUtilAdapter> local_file_util_; + scoped_ptr<QuotaUtil> quota_util_; + UpdateObserverList observers_; + + bool require_copy_or_move_validator_; + scoped_ptr<CopyOrMoveFileValidatorFactory> + copy_or_move_file_validator_factory_; + + DISALLOW_COPY_AND_ASSIGN(TestMountPointProvider); +}; + +} // namespace fileapi + +#endif // WEBKIT_BROWSER_FILEAPI_TEST_MOUNT_POINT_PROVIDER_H_ |