diff options
author | kinuko@chromium.org <kinuko@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2013-05-21 05:15:26 +0000 |
---|---|---|
committer | kinuko@chromium.org <kinuko@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2013-05-21 05:15:26 +0000 |
commit | 28f051c316b821ea200d82a1ce42f7c672c41933 (patch) | |
tree | a461d5a14b79d667cad2b11b14320424b00704a1 /webkit/browser/fileapi/sandbox_database_test_helper.cc | |
parent | 952ce9c3af14a489e2ccd575ffa61f18f636232b (diff) | |
download | chromium_src-28f051c316b821ea200d82a1ce42f7c672c41933.zip chromium_src-28f051c316b821ea200d82a1ce42f7c672c41933.tar.gz chromium_src-28f051c316b821ea200d82a1ce42f7c672c41933.tar.bz2 |
Move FileAPI sandboxed filesystem related code from webkit/fileapi to webkit/browser/fileapi
This moves following files from webkit/fileapi to webkit/browser/fileapi:
- obfuscated_file_util*
- sandbox_database_test_helper*
- sandbox_directory_database*
- sandbox_file_stream_writer*
- sandbox_mount_point_provider*
- sandbox_origin_database*
- sandbox_quota_observer*
BUG=239710
TBR=avi@chromium.org, calvinlo@chromium.org, thestig@chromium.org, tzik@chromium.org
Review URL: https://codereview.chromium.org/15442002
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@201229 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'webkit/browser/fileapi/sandbox_database_test_helper.cc')
-rw-r--r-- | webkit/browser/fileapi/sandbox_database_test_helper.cc | 101 |
1 files changed, 101 insertions, 0 deletions
diff --git a/webkit/browser/fileapi/sandbox_database_test_helper.cc b/webkit/browser/fileapi/sandbox_database_test_helper.cc new file mode 100644 index 0000000..19c3aae --- /dev/null +++ b/webkit/browser/fileapi/sandbox_database_test_helper.cc @@ -0,0 +1,101 @@ +// 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. + +#include "webkit/browser/fileapi/sandbox_database_test_helper.h" + +#include <algorithm> +#include <functional> +#include <vector> + +#include "base/file_util.h" +#include "base/stl_util.h" +#include "testing/gtest/include/gtest/gtest.h" +#include "webkit/fileapi/file_system_util.h" + +namespace fileapi { + +void CorruptDatabase(const base::FilePath& db_path, + leveldb::FileType type, + ptrdiff_t offset, + size_t size) { + file_util::FileEnumerator file_enum(db_path, false /* not recursive */, + file_util::FileEnumerator::DIRECTORIES | + file_util::FileEnumerator::FILES); + base::FilePath file_path; + base::FilePath picked_file_path; + uint64 picked_file_number = kuint64max; + + while (!(file_path = file_enum.Next()).empty()) { + uint64 number = kuint64max; + leveldb::FileType file_type; + EXPECT_TRUE(leveldb::ParseFileName(FilePathToString(file_path.BaseName()), + &number, &file_type)); + if (file_type == type && + (picked_file_number == kuint64max || picked_file_number < number)) { + picked_file_path = file_path; + picked_file_number = number; + } + } + + EXPECT_FALSE(picked_file_path.empty()); + EXPECT_NE(kuint64max, picked_file_number); + + bool created = true; + base::PlatformFileError error = base::PLATFORM_FILE_ERROR_FAILED; + base::PlatformFile file = + CreatePlatformFile(picked_file_path, + base::PLATFORM_FILE_OPEN | + base::PLATFORM_FILE_READ | + base::PLATFORM_FILE_WRITE, + &created, &error); + EXPECT_EQ(base::PLATFORM_FILE_OK, error); + EXPECT_FALSE(created); + + base::PlatformFileInfo file_info; + EXPECT_TRUE(base::GetPlatformFileInfo(file, &file_info)); + if (offset < 0) + offset += file_info.size; + EXPECT_GE(offset, 0); + EXPECT_LE(offset, file_info.size); + + size = std::min(size, static_cast<size_t>(file_info.size - offset)); + + std::vector<char> buf(size); + int read_size = base::ReadPlatformFile(file, offset, + vector_as_array(&buf), buf.size()); + EXPECT_LT(0, read_size); + EXPECT_GE(buf.size(), static_cast<size_t>(read_size)); + buf.resize(read_size); + + std::transform(buf.begin(), buf.end(), buf.begin(), + std::logical_not<char>()); + + int written_size = base::WritePlatformFile(file, offset, + vector_as_array(&buf), buf.size()); + EXPECT_GT(written_size, 0); + EXPECT_EQ(buf.size(), static_cast<size_t>(written_size)); + + base::ClosePlatformFile(file); +} + +void DeleteDatabaseFile(const base::FilePath& db_path, + leveldb::FileType type) { + file_util::FileEnumerator file_enum(db_path, false /* not recursive */, + file_util::FileEnumerator::DIRECTORIES | + file_util::FileEnumerator::FILES); + base::FilePath file_path; + while (!(file_path = file_enum.Next()).empty()) { + uint64 number = kuint64max; + leveldb::FileType file_type; + EXPECT_TRUE(leveldb::ParseFileName(FilePathToString(file_path.BaseName()), + &number, &file_type)); + if (file_type == type) { + file_util::Delete(file_path, false); + // We may have multiple files for the same type, so don't break here. + } + } + +} + +} // namespace fileapi |