summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--chrome/browser/file_system/file_system_host_context.cc15
-rw-r--r--chrome/browser/file_system/file_system_host_context.h5
-rw-r--r--chrome/common/chrome_switches.cc6
-rw-r--r--chrome/common/chrome_switches.h1
-rw-r--r--chrome/test/ui/ppapi_uitest.cc5
5 files changed, 25 insertions, 7 deletions
diff --git a/chrome/browser/file_system/file_system_host_context.cc b/chrome/browser/file_system/file_system_host_context.cc
index e94c326..54f8056 100644
--- a/chrome/browser/file_system/file_system_host_context.cc
+++ b/chrome/browser/file_system/file_system_host_context.cc
@@ -15,19 +15,24 @@
FileSystemHostContext::FileSystemHostContext(
const FilePath& data_path, bool is_incognito)
- : allow_file_access_from_files_(CommandLine::ForCurrentProcess()->HasSwitch(
- switches::kAllowFileAccessFromFiles)),
- quota_manager_(new fileapi::FileSystemQuota()),
+ : quota_manager_(new fileapi::FileSystemQuota()),
path_manager_(new fileapi::FileSystemPathManager(
BrowserThread::GetMessageLoopProxyForThread(BrowserThread::FILE),
data_path, is_incognito, allow_file_access_from_files_)) {
+ CommandLine* command_line = CommandLine::ForCurrentProcess();
+ allow_file_access_from_files_ =
+ command_line->HasSwitch(switches::kAllowFileAccessFromFiles);
+ unlimited_quota_ =
+ command_line->HasSwitch(switches::kUnlimitedQuotaForFiles);
}
bool FileSystemHostContext::CheckOriginQuota(const GURL& url, int64 growth) {
DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
// If allow-file-access-from-files flag is explicitly given and the scheme
- // is file, always return true.
- if (url.SchemeIsFile() && allow_file_access_from_files_)
+ // is file, or if unlimited quota for this process was explicitly requested,
+ // return true.
+ if (unlimited_quota_ ||
+ (url.SchemeIsFile() && allow_file_access_from_files_))
return true;
return quota_manager_->CheckOriginQuota(url, growth);
}
diff --git a/chrome/browser/file_system/file_system_host_context.h b/chrome/browser/file_system/file_system_host_context.h
index 1575c97..ddb0bf2 100644
--- a/chrome/browser/file_system/file_system_host_context.h
+++ b/chrome/browser/file_system/file_system_host_context.h
@@ -32,11 +32,12 @@ class FileSystemHostContext
fileapi::FileSystemPathManager* path_manager() { return path_manager_.get(); }
private:
- bool allow_file_access_from_files_;
-
scoped_ptr<fileapi::FileSystemQuota> quota_manager_;
scoped_ptr<fileapi::FileSystemPathManager> path_manager_;
+ bool allow_file_access_from_files_;
+ bool unlimited_quota_;
+
DISALLOW_IMPLICIT_CONSTRUCTORS(FileSystemHostContext);
};
diff --git a/chrome/common/chrome_switches.cc b/chrome/common/chrome_switches.cc
index 5541573..ef593e9 100644
--- a/chrome/common/chrome_switches.cc
+++ b/chrome/common/chrome_switches.cc
@@ -1054,6 +1054,12 @@ const char kIgnoreCertificateErrors[] = "ignore-certificate-errors";
// Set the maximum SPDY sessions per domain.
const char kMaxSpdySessionsPerDomain[] = "max-spdy-sessions-per-domain";
+// Grant unlimited quota to store files to this process.
+// Used for testing Pepper's FileRef/FileIO/FileSystem implementations.
+// DO NOT USE FOR OTHER PURPOSES.
+// TODO(dumi): remove the switch when we have a real quota implementation.
+const char kUnlimitedQuotaForFiles[] = "unlimited-quota-for-files";
+
// Use the low fragmentation heap for the CRT.
const char kUseLowFragHeapCrt[] = "use-lf-heap";
diff --git a/chrome/common/chrome_switches.h b/chrome/common/chrome_switches.h
index adb6bd5..1dcdc37 100644
--- a/chrome/common/chrome_switches.h
+++ b/chrome/common/chrome_switches.h
@@ -297,6 +297,7 @@ extern const char kUninstall[];
extern const char kUseSpdy[];
extern const char kIgnoreCertificateErrors[];
extern const char kMaxSpdySessionsPerDomain[];
+extern const char kUnlimitedQuotaForFiles[];
extern const char kUseLowFragHeapCrt[];
extern const char kUserAgent[];
extern const char kUserDataDir[];
diff --git a/chrome/test/ui/ppapi_uitest.cc b/chrome/test/ui/ppapi_uitest.cc
index 0409573..195c5e0 100644
--- a/chrome/test/ui/ppapi_uitest.cc
+++ b/chrome/test/ui/ppapi_uitest.cc
@@ -47,6 +47,11 @@ class PPAPITest : public UITest {
// Some stuff is hung off of the testing interface which is not enabled
// by default.
launch_arguments_.AppendSwitch(switches::kEnablePepperTesting);
+
+ // Give unlimited quota for files to Pepper tests.
+ // TODO(dumi): remove this switch once we have a quota management
+ // system in place.
+ launch_arguments_.AppendSwitch(switches::kUnlimitedQuotaForFiles);
}
void RunTest(const std::string& test_case) {