| Index: base/files/file_proxy_unittest.cc
|
| diff --git a/base/files/file_util_proxy_unittest.cc b/base/files/file_proxy_unittest.cc
|
| similarity index 52%
|
| copy from base/files/file_util_proxy_unittest.cc
|
| copy to base/files/file_proxy_unittest.cc
|
| index 30c77d39884c3ce82004bc78e6a9871f62f08936..4300450f47e409fea9796a220a3d1813f8490107 100644
|
| --- a/base/files/file_util_proxy_unittest.cc
|
| +++ b/base/files/file_proxy_unittest.cc
|
| @@ -2,29 +2,27 @@
|
| // Use of this source code is governed by a BSD-style license that can be
|
| // found in the LICENSE file.
|
|
|
| -#include "base/files/file_util_proxy.h"
|
| +#include "base/files/file_proxy.h"
|
|
|
| #include <map>
|
|
|
| #include "base/bind.h"
|
| #include "base/file_util.h"
|
| +#include "base/files/file.h"
|
| #include "base/files/scoped_temp_dir.h"
|
| #include "base/logging.h"
|
| #include "base/memory/weak_ptr.h"
|
| #include "base/message_loop/message_loop.h"
|
| -#include "base/platform_file.h"
|
| #include "base/threading/thread.h"
|
| #include "testing/gtest/include/gtest/gtest.h"
|
|
|
| namespace base {
|
|
|
| -class FileUtilProxyTest : public testing::Test {
|
| +class FileProxyTest : public testing::Test {
|
| public:
|
| - FileUtilProxyTest()
|
| - : file_thread_("FileUtilProxyTestFileThread"),
|
| + FileProxyTest()
|
| + : file_thread_("FileProxyTestFileThread"),
|
| error_(File::FILE_OK),
|
| - created_(false),
|
| - file_(kInvalidPlatformFileValue),
|
| bytes_written_(-1),
|
| weak_factory_(this) {}
|
|
|
| @@ -33,30 +31,19 @@ class FileUtilProxyTest : public testing::Test {
|
| ASSERT_TRUE(file_thread_.Start());
|
| }
|
|
|
| - virtual void TearDown() OVERRIDE {
|
| - if (file_ != kInvalidPlatformFileValue)
|
| - ClosePlatformFile(file_);
|
| - }
|
| -
|
| void DidFinish(File::Error error) {
|
| error_ = error;
|
| MessageLoop::current()->QuitWhenIdle();
|
| }
|
|
|
| - void DidCreateOrOpen(File::Error error,
|
| - PassPlatformFile file,
|
| - bool created) {
|
| + void DidCreateOrOpen(File::Error error) {
|
| error_ = error;
|
| - file_ = file.ReleaseValue();
|
| - created_ = created;
|
| MessageLoop::current()->QuitWhenIdle();
|
| }
|
|
|
| void DidCreateTemporary(File::Error error,
|
| - PassPlatformFile file,
|
| const FilePath& path) {
|
| error_ = error;
|
| - file_ = file.ReleaseValue();
|
| path_ = path;
|
| MessageLoop::current()->QuitWhenIdle();
|
| }
|
| @@ -85,15 +72,13 @@ class FileUtilProxyTest : public testing::Test {
|
| }
|
|
|
| protected:
|
| - PlatformFile GetTestPlatformFile(int flags) {
|
| - if (file_ != kInvalidPlatformFileValue)
|
| - return file_;
|
| - bool created;
|
| - PlatformFileError error;
|
| - file_ = CreatePlatformFile(test_path(), flags, &created, &error);
|
| - EXPECT_EQ(PLATFORM_FILE_OK, error);
|
| - EXPECT_NE(kInvalidPlatformFileValue, file_);
|
| - return file_;
|
| + void CreateProxy(uint32 flags, FileProxy* proxy) {
|
| + proxy->set_task_runner(file_task_runner());
|
| + proxy->CreateOrOpen(
|
| + test_path(), flags,
|
| + Bind(&FileProxyTest::DidCreateOrOpen, weak_factory_.GetWeakPtr()));
|
| + MessageLoop::current()->Run();
|
| + EXPECT_TRUE(proxy->IsValid());
|
| }
|
|
|
| TaskRunner* file_task_runner() const {
|
| @@ -107,110 +92,98 @@ class FileUtilProxyTest : public testing::Test {
|
|
|
| ScopedTempDir dir_;
|
| File::Error error_;
|
| - bool created_;
|
| - PlatformFile file_;
|
| + FileProxy proxy_;
|
| FilePath path_;
|
| File::Info file_info_;
|
| std::vector<char> buffer_;
|
| int bytes_written_;
|
| - WeakPtrFactory<FileUtilProxyTest> weak_factory_;
|
| + WeakPtrFactory<FileProxyTest> weak_factory_;
|
| };
|
|
|
| -TEST_F(FileUtilProxyTest, CreateOrOpen_Create) {
|
| - FileUtilProxy::CreateOrOpen(
|
| - file_task_runner(),
|
| +TEST_F(FileProxyTest, CreateOrOpen_Create) {
|
| + FileProxy proxy;
|
| + proxy.set_task_runner(file_task_runner());
|
| + proxy.CreateOrOpen(
|
| test_path(),
|
| - PLATFORM_FILE_CREATE | PLATFORM_FILE_READ,
|
| - Bind(&FileUtilProxyTest::DidCreateOrOpen, weak_factory_.GetWeakPtr()));
|
| + File::FLAG_CREATE | File::FLAG_READ,
|
| + Bind(&FileProxyTest::DidCreateOrOpen, weak_factory_.GetWeakPtr()));
|
| MessageLoop::current()->Run();
|
|
|
| EXPECT_EQ(File::FILE_OK, error_);
|
| - EXPECT_TRUE(created_);
|
| - EXPECT_NE(kInvalidPlatformFileValue, file_);
|
| + EXPECT_TRUE(proxy.IsValid());
|
| + EXPECT_TRUE(proxy.created());
|
| EXPECT_TRUE(PathExists(test_path()));
|
| }
|
|
|
| -TEST_F(FileUtilProxyTest, CreateOrOpen_Open) {
|
| +TEST_F(FileProxyTest, CreateOrOpen_Open) {
|
| // Creates a file.
|
| file_util::WriteFile(test_path(), NULL, 0);
|
| ASSERT_TRUE(PathExists(test_path()));
|
|
|
| // Opens the created file.
|
| - FileUtilProxy::CreateOrOpen(
|
| - file_task_runner(),
|
| + FileProxy proxy(file_task_runner());
|
| + proxy.CreateOrOpen(
|
| test_path(),
|
| - PLATFORM_FILE_OPEN | PLATFORM_FILE_READ,
|
| - Bind(&FileUtilProxyTest::DidCreateOrOpen, weak_factory_.GetWeakPtr()));
|
| + File::FLAG_OPEN | File::FLAG_READ,
|
| + Bind(&FileProxyTest::DidCreateOrOpen, weak_factory_.GetWeakPtr()));
|
| MessageLoop::current()->Run();
|
|
|
| EXPECT_EQ(File::FILE_OK, error_);
|
| - EXPECT_FALSE(created_);
|
| - EXPECT_NE(kInvalidPlatformFileValue, file_);
|
| + EXPECT_TRUE(proxy.IsValid());
|
| + EXPECT_FALSE(proxy.created());
|
| }
|
|
|
| -TEST_F(FileUtilProxyTest, CreateOrOpen_OpenNonExistent) {
|
| - FileUtilProxy::CreateOrOpen(
|
| - file_task_runner(),
|
| +TEST_F(FileProxyTest, CreateOrOpen_OpenNonExistent) {
|
| + FileProxy proxy(file_task_runner());
|
| + proxy.CreateOrOpen(
|
| test_path(),
|
| - PLATFORM_FILE_OPEN | PLATFORM_FILE_READ,
|
| - Bind(&FileUtilProxyTest::DidCreateOrOpen, weak_factory_.GetWeakPtr()));
|
| + File::FLAG_OPEN | File::FLAG_READ,
|
| + Bind(&FileProxyTest::DidCreateOrOpen, weak_factory_.GetWeakPtr()));
|
| MessageLoop::current()->Run();
|
| EXPECT_EQ(File::FILE_ERROR_NOT_FOUND, error_);
|
| - EXPECT_FALSE(created_);
|
| - EXPECT_EQ(kInvalidPlatformFileValue, file_);
|
| + EXPECT_FALSE(proxy.IsValid());
|
| + EXPECT_FALSE(proxy.created());
|
| EXPECT_FALSE(PathExists(test_path()));
|
| }
|
|
|
| -TEST_F(FileUtilProxyTest, Close) {
|
| +TEST_F(FileProxyTest, Close) {
|
| // Creates a file.
|
| - PlatformFile file = GetTestPlatformFile(
|
| - PLATFORM_FILE_CREATE | PLATFORM_FILE_WRITE);
|
| + FileProxy proxy;
|
| + CreateProxy(File::FLAG_CREATE | File::FLAG_WRITE, &proxy);
|
|
|
| #if defined(OS_WIN)
|
| // This fails on Windows if the file is not closed.
|
| - EXPECT_FALSE(base::Move(test_path(),
|
| - test_dir_path().AppendASCII("new")));
|
| + EXPECT_FALSE(base::Move(test_path(), test_dir_path().AppendASCII("new")));
|
| #endif
|
|
|
| - FileUtilProxy::Close(
|
| - file_task_runner(),
|
| - file,
|
| - Bind(&FileUtilProxyTest::DidFinish, weak_factory_.GetWeakPtr()));
|
| + proxy.Close(Bind(&FileProxyTest::DidFinish, weak_factory_.GetWeakPtr()));
|
| MessageLoop::current()->Run();
|
| EXPECT_EQ(File::FILE_OK, error_);
|
| + EXPECT_FALSE(proxy.IsValid());
|
|
|
| // Now it should pass on all platforms.
|
| EXPECT_TRUE(base::Move(test_path(), test_dir_path().AppendASCII("new")));
|
| }
|
|
|
| -TEST_F(FileUtilProxyTest, CreateTemporary) {
|
| - FileUtilProxy::CreateTemporary(
|
| - file_task_runner(), 0 /* additional_file_flags */,
|
| - Bind(&FileUtilProxyTest::DidCreateTemporary, weak_factory_.GetWeakPtr()));
|
| - MessageLoop::current()->Run();
|
| - EXPECT_EQ(File::FILE_OK, error_);
|
| - EXPECT_TRUE(PathExists(path_));
|
| - EXPECT_NE(kInvalidPlatformFileValue, file_);
|
| -
|
| - // The file should be writable.
|
| -#if defined(OS_WIN)
|
| - HANDLE hEvent = CreateEvent(NULL, FALSE, FALSE, NULL);
|
| - OVERLAPPED overlapped = {0};
|
| - overlapped.hEvent = hEvent;
|
| - DWORD bytes_written;
|
| - if (!::WriteFile(file_, "test", 4, &bytes_written, &overlapped)) {
|
| - // Temporary file is created with ASYNC flag, so WriteFile may return 0
|
| - // with ERROR_IO_PENDING.
|
| - EXPECT_EQ(ERROR_IO_PENDING, GetLastError());
|
| - GetOverlappedResult(file_, &overlapped, &bytes_written, TRUE);
|
| +TEST_F(FileProxyTest, CreateTemporary) {
|
| + {
|
| + FileProxy proxy(file_task_runner());
|
| + proxy.CreateTemporary(
|
| + 0 /* additional_file_flags */,
|
| + Bind(&FileProxyTest::DidCreateTemporary, weak_factory_.GetWeakPtr()));
|
| + MessageLoop::current()->Run();
|
| +
|
| + EXPECT_TRUE(proxy.IsValid());
|
| + EXPECT_EQ(File::FILE_OK, error_);
|
| + EXPECT_TRUE(PathExists(path_));
|
| +
|
| + // The file should be writable.
|
| + proxy.Write(0, "test", 4,
|
| + Bind(&FileProxyTest::DidWrite, weak_factory_.GetWeakPtr()));
|
| + MessageLoop::current()->Run();
|
| + EXPECT_EQ(File::FILE_OK, error_);
|
| + EXPECT_EQ(4, bytes_written_);
|
| }
|
| - EXPECT_EQ(4, bytes_written);
|
| -#else
|
| - // On POSIX ASYNC flag does not affect synchronous read/write behavior.
|
| - EXPECT_EQ(4, WritePlatformFile(file_, 0, "test", 4));
|
| -#endif
|
| - EXPECT_TRUE(ClosePlatformFile(file_));
|
| - file_ = kInvalidPlatformFileValue;
|
|
|
| // Make sure the written data can be read from the returned path.
|
| std::string data;
|
| @@ -221,17 +194,17 @@ TEST_F(FileUtilProxyTest, CreateTemporary) {
|
| EXPECT_TRUE(base::DeleteFile(path_, false));
|
| }
|
|
|
| -TEST_F(FileUtilProxyTest, GetFileInfo_File) {
|
| +TEST_F(FileProxyTest, GetFileInfo_File) {
|
| // Setup.
|
| ASSERT_EQ(4, file_util::WriteFile(test_path(), "test", 4));
|
| File::Info expected_info;
|
| GetFileInfo(test_path(), &expected_info);
|
|
|
| // Run.
|
| - FileUtilProxy::GetFileInfo(
|
| - file_task_runner(),
|
| - test_path(),
|
| - Bind(&FileUtilProxyTest::DidGetFileInfo, weak_factory_.GetWeakPtr()));
|
| + FileProxy proxy;
|
| + CreateProxy(File::FLAG_OPEN | File::FLAG_READ, &proxy);
|
| + proxy.GetInfo(
|
| + Bind(&FileProxyTest::DidGetFileInfo, weak_factory_.GetWeakPtr()));
|
| MessageLoop::current()->Run();
|
|
|
| // Verify.
|
| @@ -244,30 +217,7 @@ TEST_F(FileUtilProxyTest, GetFileInfo_File) {
|
| EXPECT_EQ(expected_info.creation_time, file_info_.creation_time);
|
| }
|
|
|
| -TEST_F(FileUtilProxyTest, GetFileInfo_Directory) {
|
| - // Setup.
|
| - ASSERT_TRUE(base::CreateDirectory(test_path()));
|
| - File::Info expected_info;
|
| - GetFileInfo(test_path(), &expected_info);
|
| -
|
| - // Run.
|
| - FileUtilProxy::GetFileInfo(
|
| - file_task_runner(),
|
| - test_path(),
|
| - Bind(&FileUtilProxyTest::DidGetFileInfo, weak_factory_.GetWeakPtr()));
|
| - MessageLoop::current()->Run();
|
| -
|
| - // Verify.
|
| - EXPECT_EQ(File::FILE_OK, error_);
|
| - EXPECT_EQ(expected_info.size, file_info_.size);
|
| - EXPECT_EQ(expected_info.is_directory, file_info_.is_directory);
|
| - EXPECT_EQ(expected_info.is_symbolic_link, file_info_.is_symbolic_link);
|
| - EXPECT_EQ(expected_info.last_modified, file_info_.last_modified);
|
| - EXPECT_EQ(expected_info.last_accessed, file_info_.last_accessed);
|
| - EXPECT_EQ(expected_info.creation_time, file_info_.creation_time);
|
| -}
|
| -
|
| -TEST_F(FileUtilProxyTest, Read) {
|
| +TEST_F(FileProxyTest, Read) {
|
| // Setup.
|
| const char expected_data[] = "bleh";
|
| int expected_bytes = arraysize(expected_data);
|
| @@ -275,12 +225,10 @@ TEST_F(FileUtilProxyTest, Read) {
|
| file_util::WriteFile(test_path(), expected_data, expected_bytes));
|
|
|
| // Run.
|
| - FileUtilProxy::Read(
|
| - file_task_runner(),
|
| - GetTestPlatformFile(PLATFORM_FILE_OPEN | PLATFORM_FILE_READ),
|
| - 0, // offset
|
| - 128,
|
| - Bind(&FileUtilProxyTest::DidRead, weak_factory_.GetWeakPtr()));
|
| + FileProxy proxy;
|
| + CreateProxy(File::FLAG_OPEN | File::FLAG_READ, &proxy);
|
| +
|
| + proxy.Read(0, 128, Bind(&FileProxyTest::DidRead, weak_factory_.GetWeakPtr()));
|
| MessageLoop::current()->Run();
|
|
|
| // Verify.
|
| @@ -291,29 +239,21 @@ TEST_F(FileUtilProxyTest, Read) {
|
| }
|
| }
|
|
|
| -TEST_F(FileUtilProxyTest, WriteAndFlush) {
|
| +TEST_F(FileProxyTest, WriteAndFlush) {
|
| + FileProxy proxy;
|
| + CreateProxy(File::FLAG_CREATE | File::FLAG_WRITE, &proxy);
|
| +
|
| const char data[] = "foo!";
|
| int data_bytes = ARRAYSIZE_UNSAFE(data);
|
| - PlatformFile file = GetTestPlatformFile(
|
| - PLATFORM_FILE_CREATE | PLATFORM_FILE_WRITE);
|
| -
|
| - FileUtilProxy::Write(
|
| - file_task_runner(),
|
| - file,
|
| - 0, // offset
|
| - data,
|
| - data_bytes,
|
| - Bind(&FileUtilProxyTest::DidWrite, weak_factory_.GetWeakPtr()));
|
| + proxy.Write(0, data, data_bytes,
|
| + Bind(&FileProxyTest::DidWrite, weak_factory_.GetWeakPtr()));
|
| MessageLoop::current()->Run();
|
| EXPECT_EQ(File::FILE_OK, error_);
|
| EXPECT_EQ(data_bytes, bytes_written_);
|
|
|
| // Flush the written data. (So that the following read should always
|
| // succeed. On some platforms it may work with or without this flush.)
|
| - FileUtilProxy::Flush(
|
| - file_task_runner(),
|
| - file,
|
| - Bind(&FileUtilProxyTest::DidFinish, weak_factory_.GetWeakPtr()));
|
| + proxy.Flush(Bind(&FileProxyTest::DidFinish, weak_factory_.GetWeakPtr()));
|
| MessageLoop::current()->Run();
|
| EXPECT_EQ(File::FILE_OK, error_);
|
|
|
| @@ -325,18 +265,16 @@ TEST_F(FileUtilProxyTest, WriteAndFlush) {
|
| }
|
| }
|
|
|
| -TEST_F(FileUtilProxyTest, Touch) {
|
| +TEST_F(FileProxyTest, SetTimes) {
|
| + FileProxy proxy;
|
| + CreateProxy(
|
| + File::FLAG_CREATE | File::FLAG_WRITE | File::FLAG_WRITE_ATTRIBUTES, &proxy);
|
| +
|
| Time last_accessed_time = Time::Now() - TimeDelta::FromDays(12345);
|
| Time last_modified_time = Time::Now() - TimeDelta::FromHours(98765);
|
|
|
| - FileUtilProxy::Touch(
|
| - file_task_runner(),
|
| - GetTestPlatformFile(PLATFORM_FILE_CREATE |
|
| - PLATFORM_FILE_WRITE |
|
| - PLATFORM_FILE_WRITE_ATTRIBUTES),
|
| - last_accessed_time,
|
| - last_modified_time,
|
| - Bind(&FileUtilProxyTest::DidFinish, weak_factory_.GetWeakPtr()));
|
| + proxy.SetTimes(last_accessed_time, last_modified_time,
|
| + Bind(&FileProxyTest::DidFinish, weak_factory_.GetWeakPtr()));
|
| MessageLoop::current()->Run();
|
| EXPECT_EQ(File::FILE_OK, error_);
|
|
|
| @@ -351,7 +289,7 @@ TEST_F(FileUtilProxyTest, Touch) {
|
| static_cast<int>(info.last_accessed.ToDoubleT()));
|
| }
|
|
|
| -TEST_F(FileUtilProxyTest, Truncate_Shrink) {
|
| +TEST_F(FileProxyTest, SetLength_Shrink) {
|
| // Setup.
|
| const char kTestData[] = "0123456789";
|
| ASSERT_EQ(10, file_util::WriteFile(test_path(), kTestData, 10));
|
| @@ -360,11 +298,10 @@ TEST_F(FileUtilProxyTest, Truncate_Shrink) {
|
| ASSERT_EQ(10, info.size);
|
|
|
| // Run.
|
| - FileUtilProxy::Truncate(
|
| - file_task_runner(),
|
| - GetTestPlatformFile(PLATFORM_FILE_OPEN | PLATFORM_FILE_WRITE),
|
| - 7,
|
| - Bind(&FileUtilProxyTest::DidFinish, weak_factory_.GetWeakPtr()));
|
| + FileProxy proxy;
|
| + CreateProxy(File::FLAG_OPEN | File::FLAG_WRITE, &proxy);
|
| + proxy.SetLength(7,
|
| + Bind(&FileProxyTest::DidFinish, weak_factory_.GetWeakPtr()));
|
| MessageLoop::current()->Run();
|
|
|
| // Verify.
|
| @@ -378,7 +315,7 @@ TEST_F(FileUtilProxyTest, Truncate_Shrink) {
|
| EXPECT_EQ(kTestData[i], buffer[i]);
|
| }
|
|
|
| -TEST_F(FileUtilProxyTest, Truncate_Expand) {
|
| +TEST_F(FileProxyTest, SetLength_Expand) {
|
| // Setup.
|
| const char kTestData[] = "9876543210";
|
| ASSERT_EQ(10, file_util::WriteFile(test_path(), kTestData, 10));
|
| @@ -387,11 +324,10 @@ TEST_F(FileUtilProxyTest, Truncate_Expand) {
|
| ASSERT_EQ(10, info.size);
|
|
|
| // Run.
|
| - FileUtilProxy::Truncate(
|
| - file_task_runner(),
|
| - GetTestPlatformFile(PLATFORM_FILE_OPEN | PLATFORM_FILE_WRITE),
|
| - 53,
|
| - Bind(&FileUtilProxyTest::DidFinish, weak_factory_.GetWeakPtr()));
|
| + FileProxy proxy;
|
| + CreateProxy(File::FLAG_OPEN | File::FLAG_WRITE, &proxy);
|
| + proxy.SetLength(53,
|
| + Bind(&FileProxyTest::DidFinish, weak_factory_.GetWeakPtr()));
|
| MessageLoop::current()->Run();
|
|
|
| // Verify.
|
|
|