blob: 2c80e62ac7a699af7a2ea4c0535ec13fc6d88f1c (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
|
// Copyright 2013 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 CONTENT_PUBLIC_TEST_TEST_FILE_SYSTEM_BACKEND_H_
#define CONTENT_PUBLIC_TEST_TEST_FILE_SYSTEM_BACKEND_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_backend.h"
#include "webkit/browser/fileapi/task_runner_bound_observer_list.h"
namespace base {
class SequencedTaskRunner;
}
namespace storage {
class AsyncFileUtilAdapter;
class FileSystemQuotaUtil;
}
namespace content {
// This should be only used for testing.
// This file system backend uses LocalFileUtil and stores data file
// under the given directory.
class TestFileSystemBackend : public storage::FileSystemBackend {
public:
TestFileSystemBackend(
base::SequencedTaskRunner* task_runner,
const base::FilePath& base_path);
virtual ~TestFileSystemBackend();
// FileSystemBackend implementation.
virtual bool CanHandleType(storage::FileSystemType type) const OVERRIDE;
virtual void Initialize(storage::FileSystemContext* context) OVERRIDE;
virtual void ResolveURL(const storage::FileSystemURL& url,
storage::OpenFileSystemMode mode,
const OpenFileSystemCallback& callback) OVERRIDE;
virtual storage::AsyncFileUtil* GetAsyncFileUtil(
storage::FileSystemType type) OVERRIDE;
virtual storage::CopyOrMoveFileValidatorFactory*
GetCopyOrMoveFileValidatorFactory(storage::FileSystemType type,
base::File::Error* error_code) OVERRIDE;
virtual storage::FileSystemOperation* CreateFileSystemOperation(
const storage::FileSystemURL& url,
storage::FileSystemContext* context,
base::File::Error* error_code) const OVERRIDE;
virtual bool SupportsStreaming(
const storage::FileSystemURL& url) const OVERRIDE;
virtual bool HasInplaceCopyImplementation(
storage::FileSystemType type) const OVERRIDE;
virtual scoped_ptr<storage::FileStreamReader> CreateFileStreamReader(
const storage::FileSystemURL& url,
int64 offset,
const base::Time& expected_modification_time,
storage::FileSystemContext* context) const OVERRIDE;
virtual scoped_ptr<storage::FileStreamWriter> CreateFileStreamWriter(
const storage::FileSystemURL& url,
int64 offset,
storage::FileSystemContext* context) const OVERRIDE;
virtual storage::FileSystemQuotaUtil* GetQuotaUtil() OVERRIDE;
// Initialize the CopyOrMoveFileValidatorFactory. Invalid to call more than
// once.
void InitializeCopyOrMoveFileValidatorFactory(
scoped_ptr<storage::CopyOrMoveFileValidatorFactory> factory);
const storage::UpdateObserverList* GetUpdateObservers(
storage::FileSystemType type) const;
void AddFileChangeObserver(storage::FileChangeObserver* observer);
// 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<storage::AsyncFileUtilAdapter> file_util_;
scoped_ptr<QuotaUtil> quota_util_;
bool require_copy_or_move_validator_;
scoped_ptr<storage::CopyOrMoveFileValidatorFactory>
copy_or_move_file_validator_factory_;
DISALLOW_COPY_AND_ASSIGN(TestFileSystemBackend);
};
} // namespace content
#endif // CONTENT_PUBLIC_TEST_TEST_FILE_SYSTEM_BACKEND_H_
|