summaryrefslogtreecommitdiffstats
path: root/webkit/fileapi
diff options
context:
space:
mode:
Diffstat (limited to 'webkit/fileapi')
-rw-r--r--webkit/fileapi/file_system_operation_write_unittest.cc29
-rw-r--r--webkit/fileapi/file_system_quota_unittest.cc24
-rw-r--r--webkit/fileapi/file_system_test_helper.cc37
-rw-r--r--webkit/fileapi/file_system_test_helper.h4
-rw-r--r--webkit/fileapi/file_writer_delegate_unittest.cc1
-rw-r--r--webkit/fileapi/obfuscated_file_util_unittest.cc17
-rw-r--r--webkit/fileapi/test_mount_point_provider.cc7
7 files changed, 63 insertions, 56 deletions
diff --git a/webkit/fileapi/file_system_operation_write_unittest.cc b/webkit/fileapi/file_system_operation_write_unittest.cc
index 47ade43..2b3fec8 100644
--- a/webkit/fileapi/file_system_operation_write_unittest.cc
+++ b/webkit/fileapi/file_system_operation_write_unittest.cc
@@ -76,7 +76,8 @@ class FileSystemOperationWriteTest
public base::SupportsWeakPtr<FileSystemOperationWriteTest> {
public:
FileSystemOperationWriteTest()
- : loop_(MessageLoop::TYPE_IO),
+ : test_helper_(GURL("http://example.com"), kFileSystemTypeTest),
+ loop_(MessageLoop::TYPE_IO),
status_(base::PLATFORM_FILE_OK),
cancel_status_(base::PLATFORM_FILE_ERROR_FAILED),
bytes_written_(0),
@@ -140,8 +141,6 @@ class FileSystemOperationWriteTest
MessageLoop loop_;
ScopedTempDir dir_;
- FilePath filesystem_dir_;
- FilePath file_;
FilePath virtual_path_;
// For post-operation status.
@@ -192,13 +191,10 @@ void FileSystemOperationWriteTest::SetUp() {
false /* unlimited quota */,
quota_manager_->proxy(),
NULL);
- filesystem_dir_ = test_helper_.GetOriginRootPath();
-
- ASSERT_TRUE(file_util::CreateTemporaryFileInDir(filesystem_dir_, &file_));
- virtual_path_ = file_.BaseName();
+ virtual_path_ = FilePath(FILE_PATH_LITERAL("temporary file"));
operation()->CreateFile(
- URLForPath(virtual_path_), true,
+ URLForPath(virtual_path_), true /* exclusive */,
base::Bind(&AssertStatusEq, base::PLATFORM_FILE_OK));
net::URLRequest::Deprecated::RegisterProtocolFactory(
@@ -289,14 +285,9 @@ TEST_F(FileSystemOperationWriteTest, TestWriteInvalidFile) {
}
TEST_F(FileSystemOperationWriteTest, TestWriteDir) {
- FilePath subdir;
- ASSERT_TRUE(file_util::CreateTemporaryDirInDir(filesystem_dir_,
- FILE_PATH_LITERAL("d"),
- &subdir));
- FilePath virtual_subdir_path = subdir.BaseName();
-
+ FilePath virtual_dir_path(FILE_PATH_LITERAL("d"));
operation()->CreateDirectory(
- URLForPath(virtual_subdir_path),
+ URLForPath(virtual_dir_path),
true /* exclusive */, false /* recursive */,
base::Bind(&AssertStatusEq, base::PLATFORM_FILE_OK));
@@ -308,14 +299,18 @@ TEST_F(FileSystemOperationWriteTest, TestWriteDir) {
url_request_context.blob_storage_controller()->AddFinishedBlob(
blob_url, blob_data);
- operation()->Write(&url_request_context, URLForPath(virtual_subdir_path),
+ operation()->Write(&url_request_context, URLForPath(virtual_dir_path),
blob_url, 0, RecordWriteCallback());
MessageLoop::current()->Run();
url_request_context.blob_storage_controller()->RemoveBlob(blob_url);
EXPECT_EQ(0, bytes_written());
- EXPECT_EQ(base::PLATFORM_FILE_ERROR_NOT_A_FILE, status());
+ // TODO(kinuko): This error code is platform- or fileutil- dependent
+ // right now. Make it return PLATFORM_FILE_ERROR_NOT_A_FILE in every case.
+ EXPECT_TRUE(status() == base::PLATFORM_FILE_ERROR_NOT_A_FILE ||
+ status() == base::PLATFORM_FILE_ERROR_ACCESS_DENIED ||
+ status() == base::PLATFORM_FILE_ERROR_FAILED);
EXPECT_TRUE(complete());
}
diff --git a/webkit/fileapi/file_system_quota_unittest.cc b/webkit/fileapi/file_system_quota_unittest.cc
index 02c6d44..4b33ae4 100644
--- a/webkit/fileapi/file_system_quota_unittest.cc
+++ b/webkit/fileapi/file_system_quota_unittest.cc
@@ -86,7 +86,7 @@ class FileSystemQuotaTest
test_helper_.ComputeCurrentDirectoryDatabaseUsage();
}
- int64 SizeInUsageFile() {
+ int64 SizeByQuotaUtil() {
return test_helper_.GetCachedOriginUsage();
}
@@ -212,26 +212,26 @@ void FileSystemQuotaTest::OnGetUsageAndQuota(
}
void FileSystemQuotaTest::PrepareFileSet(const FilePath& virtual_path) {
- int64 usage = SizeInUsageFile();
+ int64 usage = SizeByQuotaUtil();
child_dir_path_ = CreateUniqueDirInDir(virtual_path);
child_file1_path_ = CreateUniqueFileInDir(virtual_path);
child_file2_path_ = CreateUniqueFileInDir(virtual_path);
- child_path_cost_ = SizeInUsageFile() - usage;
+ child_path_cost_ = SizeByQuotaUtil() - usage;
usage += child_path_cost_;
grandchild_file1_path_ = CreateUniqueFileInDir(child_dir_path_);
grandchild_file2_path_ = CreateUniqueFileInDir(child_dir_path_);
- grandchild_path_cost_ = SizeInUsageFile() - usage;
+ grandchild_path_cost_ = SizeByQuotaUtil() - usage;
}
TEST_F(FileSystemQuotaTest, TestMoveSuccessSrcDirRecursive) {
FilePath src_dir_path(CreateUniqueDir());
- int src_path_cost = SizeInUsageFile();
+ int src_path_cost = SizeByQuotaUtil();
PrepareFileSet(src_dir_path);
FilePath dest_dir_path(CreateUniqueDir());
EXPECT_EQ(0, ActualFileSize());
- int total_path_cost = SizeInUsageFile();
+ int total_path_cost = SizeByQuotaUtil();
operation()->Truncate(URLForPath(child_file1_path_), 5000,
base::Bind(&AssertFileErrorEq, base::PLATFORM_FILE_OK));
@@ -246,7 +246,7 @@ TEST_F(FileSystemQuotaTest, TestMoveSuccessSrcDirRecursive) {
const int64 all_file_size = 5000 + 400 + 30 + 2;
EXPECT_EQ(all_file_size, ActualFileSize());
- EXPECT_EQ(all_file_size + total_path_cost, SizeInUsageFile());
+ EXPECT_EQ(all_file_size + total_path_cost, SizeByQuotaUtil());
GetUsageAndQuotaFromQuotaManager();
EXPECT_EQ(quota::kQuotaStatusOk, quota_status());
EXPECT_EQ(all_file_size + total_path_cost, usage());
@@ -265,7 +265,7 @@ TEST_F(FileSystemQuotaTest, TestMoveSuccessSrcDirRecursive) {
EXPECT_EQ(all_file_size, ActualFileSize());
EXPECT_EQ(all_file_size + total_path_cost - src_path_cost,
- SizeInUsageFile());
+ SizeByQuotaUtil());
GetUsageAndQuotaFromQuotaManager();
EXPECT_EQ(quota::kQuotaStatusOk, quota_status());
EXPECT_EQ(all_file_size + total_path_cost - src_path_cost, usage());
@@ -279,7 +279,7 @@ TEST_F(FileSystemQuotaTest, TestCopySuccessSrcDirRecursive) {
FilePath dest_dir2_path(CreateUniqueDir());
EXPECT_EQ(0, ActualFileSize());
- int total_path_cost = SizeInUsageFile();
+ int total_path_cost = SizeByQuotaUtil();
operation()->Truncate(URLForPath(child_file1_path_), 8000,
base::Bind(&AssertFileErrorEq, base::PLATFORM_FILE_OK));
@@ -297,7 +297,7 @@ TEST_F(FileSystemQuotaTest, TestCopySuccessSrcDirRecursive) {
int64 expected_usage = all_file_size + total_path_cost;
EXPECT_EQ(all_file_size, ActualFileSize());
- EXPECT_EQ(expected_usage, SizeInUsageFile());
+ EXPECT_EQ(expected_usage, SizeByQuotaUtil());
GetUsageAndQuotaFromQuotaManager();
EXPECT_EQ(quota::kQuotaStatusOk, quota_status());
EXPECT_EQ(expected_usage, usage());
@@ -323,7 +323,7 @@ TEST_F(FileSystemQuotaTest, TestCopySuccessSrcDirRecursive) {
VirtualPath::BaseName(grandchild_file1_path_))));
EXPECT_EQ(2 * all_file_size, ActualFileSize());
- EXPECT_EQ(expected_usage, SizeInUsageFile());
+ EXPECT_EQ(expected_usage, SizeByQuotaUtil());
GetUsageAndQuotaFromQuotaManager();
EXPECT_EQ(quota::kQuotaStatusOk, quota_status());
EXPECT_EQ(expected_usage, usage());
@@ -337,7 +337,7 @@ TEST_F(FileSystemQuotaTest, TestCopySuccessSrcDirRecursive) {
expected_usage += grandchild_file_size + grandchild_path_cost_;
EXPECT_EQ(2 * child_file_size + 3 * grandchild_file_size, ActualFileSize());
- EXPECT_EQ(expected_usage, SizeInUsageFile());
+ EXPECT_EQ(expected_usage, SizeByQuotaUtil());
GetUsageAndQuotaFromQuotaManager();
EXPECT_EQ(quota::kQuotaStatusOk, quota_status());
EXPECT_EQ(expected_usage, usage());
diff --git a/webkit/fileapi/file_system_test_helper.cc b/webkit/fileapi/file_system_test_helper.cc
index 554b035..e8743e4 100644
--- a/webkit/fileapi/file_system_test_helper.cc
+++ b/webkit/fileapi/file_system_test_helper.cc
@@ -16,6 +16,7 @@
#include "webkit/fileapi/file_util_helper.h"
#include "webkit/fileapi/mock_file_system_options.h"
#include "webkit/fileapi/sandbox_mount_point_provider.h"
+#include "webkit/fileapi/test_mount_point_provider.h"
#include "webkit/quota/mock_special_storage_policy.h"
namespace fileapi {
@@ -41,12 +42,10 @@ void FileSystemTestOriginHelper::SetUp(
void FileSystemTestOriginHelper::SetUp(
FileSystemContext* file_system_context, FileSystemFileUtil* file_util) {
- DCHECK(file_system_context->sandbox_provider());
-
file_util_ = file_util;
file_system_context_ = file_system_context;
if (!file_util_)
- file_util_ = file_system_context->sandbox_provider()->GetFileUtil();
+ file_util_ = file_system_context->GetFileUtil(type_);
DCHECK(file_util_);
// Prepare the origin's root directory.
@@ -55,9 +54,9 @@ void FileSystemTestOriginHelper::SetUp(
origin_, type_, FilePath(), true /* create */);
// Initialize the usage cache file.
- FilePath usage_cache_path = file_system_context_->
- sandbox_provider()->GetUsageCachePathForOriginAndType(origin_, type_);
- FileSystemUsageCache::UpdateUsage(usage_cache_path, 0);
+ FilePath usage_cache_path = GetUsageCachePath();
+ if (!usage_cache_path.empty())
+ FileSystemUsageCache::UpdateUsage(usage_cache_path, 0);
}
void FileSystemTestOriginHelper::SetUp(
@@ -76,7 +75,12 @@ void FileSystemTestOriginHelper::SetUp(
base_dir,
CreateAllowFileAccessOptions());
- DCHECK(file_system_context_->sandbox_provider());
+ if (type_ == kFileSystemTypeTest) {
+ file_system_context_->RegisterMountPointProvider(
+ type_,
+ new TestMountPointProvider(file_system_context_->file_task_runner(),
+ base_dir));
+ }
// Prepare the origin's root directory.
FileSystemMountPointProvider* mount_point_provider =
@@ -91,11 +95,10 @@ void FileSystemTestOriginHelper::SetUp(
DCHECK(file_util_);
- // Initialize the usage cache file. This code assumes that we're either using
- // OFSFU or we've mocked it out in the sandbox provider.
- FilePath usage_cache_path = file_system_context_->
- sandbox_provider()->GetUsageCachePathForOriginAndType(origin_, type_);
- FileSystemUsageCache::UpdateUsage(usage_cache_path, 0);
+ // Initialize the usage cache file.
+ FilePath usage_cache_path = GetUsageCachePath();
+ if (!usage_cache_path.empty())
+ FileSystemUsageCache::UpdateUsage(usage_cache_path, 0);
}
void FileSystemTestOriginHelper::TearDown() {
@@ -128,6 +131,9 @@ GURL FileSystemTestOriginHelper::GetURLForPath(const FilePath& path) const {
}
FilePath FileSystemTestOriginHelper::GetUsageCachePath() const {
+ if (type_ != kFileSystemTypeTemporary &&
+ type_ != kFileSystemTypePersistent)
+ return FilePath();
return file_system_context_->
sandbox_provider()->GetUsageCachePathForOriginAndType(origin_, type_);
}
@@ -152,11 +158,8 @@ base::PlatformFileError FileSystemTestOriginHelper::SameFileUtilMove(
}
int64 FileSystemTestOriginHelper::GetCachedOriginUsage() const {
- return FileSystemUsageCache::GetUsage(GetUsageCachePath());
-}
-
-bool FileSystemTestOriginHelper::RevokeUsageCache() const {
- return file_util::Delete(GetUsageCachePath(), false);
+ return file_system_context_->GetQuotaUtil(type_)->GetOriginUsageOnFileThread(
+ origin_, type_);
}
int64 FileSystemTestOriginHelper::ComputeCurrentOriginUsage() const {
diff --git a/webkit/fileapi/file_system_test_helper.h b/webkit/fileapi/file_system_test_helper.h
index 4ebfb8e..9aab095 100644
--- a/webkit/fileapi/file_system_test_helper.h
+++ b/webkit/fileapi/file_system_test_helper.h
@@ -55,6 +55,8 @@ class FileSystemTestOriginHelper {
FilePath GetLocalPath(const FilePath& path);
FilePath GetLocalPathFromASCII(const std::string& path);
GURL GetURLForPath(const FilePath& path) const;
+
+ // Returns empty path if filesystem type is neither temporary nor persistent.
FilePath GetUsageCachePath() const;
// Creates a new FileSystemPath for the given |path|.
@@ -73,8 +75,8 @@ class FileSystemTestOriginHelper {
const FileSystemPath& src,
const FileSystemPath& dest) const;
+ // This returns cached usage size returned by QuotaUtil.
int64 GetCachedOriginUsage() const;
- bool RevokeUsageCache() const;
// This doesn't work with OFSFU.
int64 ComputeCurrentOriginUsage() const;
diff --git a/webkit/fileapi/file_writer_delegate_unittest.cc b/webkit/fileapi/file_writer_delegate_unittest.cc
index ee4f1d7..1ce152e 100644
--- a/webkit/fileapi/file_writer_delegate_unittest.cc
+++ b/webkit/fileapi/file_writer_delegate_unittest.cc
@@ -81,6 +81,7 @@ class FileWriterDelegateTest : public PlatformTest {
public:
FileWriterDelegateTest()
: loop_(MessageLoop::TYPE_IO),
+ test_helper_(GURL("http://example.com"), kFileSystemTypeTest),
file_(base::kInvalidPlatformFileValue) {}
protected:
diff --git a/webkit/fileapi/obfuscated_file_util_unittest.cc b/webkit/fileapi/obfuscated_file_util_unittest.cc
index beb0f19..96d6759 100644
--- a/webkit/fileapi/obfuscated_file_util_unittest.cc
+++ b/webkit/fileapi/obfuscated_file_util_unittest.cc
@@ -208,13 +208,17 @@ class ObfuscatedFileUtilTest : public testing::Test {
void RevokeUsageCache() {
quota_manager_->ResetUsageTracker(test_helper_.storage_type());
- ASSERT_TRUE(test_helper_.RevokeUsageCache());
+ file_util::Delete(test_helper_.GetUsageCachePath(), false);
}
- int64 SizeInUsageFile() {
+ int64 SizeByQuotaUtil() {
return test_helper_.GetCachedOriginUsage();
}
+ int64 SizeInUsageFile() {
+ return FileSystemUsageCache::GetUsage(test_helper_.GetUsageCachePath());
+ }
+
int64 usage() const { return usage_; }
FileSystemPath CreatePathFromUTF8(const std::string& path) {
@@ -1487,11 +1491,20 @@ TEST_F(ObfuscatedFileUtilTest, TestRevokeUsageCache) {
expected_quota += test_case.data_file_size;
}
}
+
+ // Usually raw size in usage cache and the usage returned by QuotaUtil
+ // should be same.
EXPECT_EQ(expected_quota, SizeInUsageFile());
+ EXPECT_EQ(expected_quota, SizeByQuotaUtil());
+
RevokeUsageCache();
EXPECT_EQ(-1, SizeInUsageFile());
+ EXPECT_EQ(expected_quota, SizeByQuotaUtil());
+
+ // This should reconstruct the cache.
GetUsageFromQuotaManager();
EXPECT_EQ(expected_quota, SizeInUsageFile());
+ EXPECT_EQ(expected_quota, SizeByQuotaUtil());
EXPECT_EQ(expected_quota, usage());
}
diff --git a/webkit/fileapi/test_mount_point_provider.cc b/webkit/fileapi/test_mount_point_provider.cc
index cf0aa4f..d91c8298 100644
--- a/webkit/fileapi/test_mount_point_provider.cc
+++ b/webkit/fileapi/test_mount_point_provider.cc
@@ -57,13 +57,6 @@ class TestFileSystemQuotaUtil : public FileSystemQuotaUtil {
FileSystemType type,
int64 delta) OVERRIDE {
usage_ += delta;
- if (proxy) {
- proxy->NotifyStorageModified(
- quota::QuotaClient::kFileSystem,
- origin_url,
- FileSystemTypeToQuotaStorageType(type),
- delta);
- }
}
virtual void StartUpdateOriginOnFileThread(
const GURL& origin_url,