blob: 2edac67e71de0b4059fe0eef4bd9005c6c20ed84 (
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
100
101
102
103
104
105
106
|
// 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_SANDBOX_FILE_SYSTEM_TEST_HELPER_H_
#define CONTENT_PUBLIC_TEST_SANDBOX_FILE_SYSTEM_TEST_HELPER_H_
#include <string>
#include "base/files/file_path.h"
#include "base/memory/ref_counted.h"
#include "storage/browser/fileapi/file_system_url.h"
#include "storage/browser/fileapi/file_system_usage_cache.h"
#include "storage/browser/fileapi/task_runner_bound_observer_list.h"
#include "storage/common/fileapi/file_system_types.h"
#include "storage/common/fileapi/file_system_util.h"
#include "storage/common/quota/quota_types.h"
#include "url/gurl.h"
namespace base {
class FilePath;
}
namespace storage {
class QuotaManagerProxy;
}
namespace storage {
class FileSystemContext;
class FileSystemFileUtil;
class FileSystemOperationContext;
class FileSystemOperationRunner;
}
namespace content {
// Filesystem test helper class that encapsulates test environment for
// a given {origin, type} pair. This helper only works for sandboxed
// file systems (Temporary or Persistent).
class SandboxFileSystemTestHelper {
public:
SandboxFileSystemTestHelper(const GURL& origin, storage::FileSystemType type);
SandboxFileSystemTestHelper();
~SandboxFileSystemTestHelper();
void SetUp(const base::FilePath& base_dir);
// If you want to use more than one SandboxFileSystemTestHelper in
// a single base directory, they have to share a context, so that they don't
// have multiple databases fighting over the lock to the origin directory
// [deep down inside ObfuscatedFileUtil].
void SetUp(storage::FileSystemContext* file_system_context);
void SetUp(const base::FilePath& base_dir,
storage::QuotaManagerProxy* quota_manager_proxy);
void TearDown();
base::FilePath GetOriginRootPath();
base::FilePath GetLocalPath(const base::FilePath& path);
base::FilePath GetLocalPathFromASCII(const std::string& path);
// Returns empty path if filesystem type is neither temporary nor persistent.
base::FilePath GetUsageCachePath() const;
storage::FileSystemURL CreateURL(const base::FilePath& path) const;
storage::FileSystemURL CreateURLFromUTF8(const std::string& utf8) const {
return CreateURL(base::FilePath::FromUTF8Unsafe(utf8));
}
// This returns cached usage size returned by QuotaUtil.
int64 GetCachedOriginUsage() const;
// This doesn't work with OFSFU.
int64 ComputeCurrentOriginUsage();
int64 ComputeCurrentDirectoryDatabaseUsage();
storage::FileSystemOperationRunner* operation_runner();
storage::FileSystemOperationContext* NewOperationContext();
void AddFileChangeObserver(storage::FileChangeObserver* observer);
void AddFileUpdateObserver(storage::FileUpdateObserver* observer);
storage::FileSystemContext* file_system_context() const {
return file_system_context_.get();
}
const GURL& origin() const { return origin_; }
storage::FileSystemType type() const { return type_; }
storage::StorageType storage_type() const {
return storage::FileSystemTypeToQuotaStorageType(type_);
}
storage::FileSystemFileUtil* file_util() const { return file_util_; }
storage::FileSystemUsageCache* usage_cache();
private:
void SetUpFileSystem();
scoped_refptr<storage::FileSystemContext> file_system_context_;
const GURL origin_;
const storage::FileSystemType type_;
storage::FileSystemFileUtil* file_util_;
};
} // namespace content
#endif // CONTENT_PUBLIC_TEST_SANDBOX_FILE_SYSTEM_TEST_HELPER_H_
|