| Index: webkit/browser/fileapi/file_system_operation_runner_unittest.cc
|
| diff --git a/webkit/browser/fileapi/file_system_operation_runner_unittest.cc b/webkit/browser/fileapi/file_system_operation_runner_unittest.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..5965096a73cc955c3970ff4ec7675c7ae87b7168
|
| --- /dev/null
|
| +++ b/webkit/browser/fileapi/file_system_operation_runner_unittest.cc
|
| @@ -0,0 +1,149 @@
|
| +// 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.
|
| +
|
| +#include "base/basictypes.h"
|
| +#include "base/files/file_path.h"
|
| +#include "base/files/scoped_temp_dir.h"
|
| +#include "base/message_loop/message_loop.h"
|
| +#include "base/platform_file.h"
|
| +#include "testing/gtest/include/gtest/gtest.h"
|
| +#include "webkit/browser/fileapi/file_system_context.h"
|
| +#include "webkit/browser/fileapi/file_system_operation_runner.h"
|
| +#include "webkit/browser/fileapi/mock_file_system_context.h"
|
| +
|
| +namespace fileapi {
|
| +
|
| +void GetStatus(bool* done,
|
| + base::PlatformFileError *status_out,
|
| + base::PlatformFileError status) {
|
| + ASSERT_FALSE(*done);
|
| + *done = true;
|
| + *status_out = status;
|
| +}
|
| +
|
| +void GetCancelStatus(bool* operation_done,
|
| + bool* cancel_done,
|
| + base::PlatformFileError *status_out,
|
| + base::PlatformFileError status) {
|
| + // Cancel callback must be always called after the operation's callback.
|
| + ASSERT_TRUE(*operation_done);
|
| + ASSERT_FALSE(*cancel_done);
|
| + *cancel_done = true;
|
| + *status_out = status;
|
| +}
|
| +
|
| +class FileSystemOperationRunnerTest : public testing::Test {
|
| + protected:
|
| + FileSystemOperationRunnerTest() {}
|
| + virtual ~FileSystemOperationRunnerTest() {}
|
| +
|
| + virtual void SetUp() OVERRIDE {
|
| + ASSERT_TRUE(base_.CreateUniqueTempDir());
|
| + base::FilePath base_dir = base_.path();
|
| + file_system_context_ =
|
| + CreateFileSystemContextForTesting(NULL, base_dir);
|
| + }
|
| +
|
| + virtual void TearDown() OVERRIDE {
|
| + file_system_context_ = NULL;
|
| + base::MessageLoop::current()->RunUntilIdle();
|
| + }
|
| +
|
| + FileSystemURL URL(const std::string& path) {
|
| + return file_system_context_->CreateCrackedFileSystemURL(
|
| + GURL("http://example.com"), kFileSystemTypeTemporary,
|
| + base::FilePath::FromUTF8Unsafe(path));
|
| + }
|
| +
|
| + FileSystemOperationRunner* operation_runner() {
|
| + return file_system_context_->operation_runner();
|
| + }
|
| +
|
| + private:
|
| + base::ScopedTempDir base_;
|
| + base::MessageLoop message_loop_;
|
| + scoped_refptr<FileSystemContext> file_system_context_;
|
| +
|
| + DISALLOW_COPY_AND_ASSIGN(FileSystemOperationRunnerTest);
|
| +};
|
| +
|
| +TEST_F(FileSystemOperationRunnerTest, NotFoundError) {
|
| + bool done = false;
|
| + base::PlatformFileError status = base::PLATFORM_FILE_ERROR_FAILED;
|
| +
|
| + // Regular NOT_FOUND error, which is called asynchronously.
|
| + operation_runner()->Truncate(URL("foo"), 0,
|
| + base::Bind(&GetStatus, &done, &status));
|
| + ASSERT_FALSE(done);
|
| + base::MessageLoop::current()->RunUntilIdle();
|
| + ASSERT_TRUE(done);
|
| + ASSERT_EQ(base::PLATFORM_FILE_ERROR_NOT_FOUND, status);
|
| +}
|
| +
|
| +TEST_F(FileSystemOperationRunnerTest, InvalidURLError) {
|
| + bool done = false;
|
| + base::PlatformFileError status = base::PLATFORM_FILE_ERROR_FAILED;
|
| +
|
| + // Invalid URL error, which calls DidFinish synchronously.
|
| + operation_runner()->Truncate(FileSystemURL(), 0,
|
| + base::Bind(&GetStatus, &done, &status));
|
| + // The error call back shouldn't be fired synchronously.
|
| + ASSERT_FALSE(done);
|
| +
|
| + base::MessageLoop::current()->RunUntilIdle();
|
| + ASSERT_TRUE(done);
|
| + ASSERT_EQ(base::PLATFORM_FILE_ERROR_INVALID_URL, status);
|
| +}
|
| +
|
| +TEST_F(FileSystemOperationRunnerTest, NotFoundErrorAndCancel) {
|
| + bool done = false;
|
| + bool cancel_done = false;
|
| + base::PlatformFileError status = base::PLATFORM_FILE_ERROR_FAILED;
|
| + base::PlatformFileError cancel_status = base::PLATFORM_FILE_ERROR_FAILED;
|
| +
|
| + // Call Truncate with non-existent URL, and try to cancel it immediately
|
| + // after that (before its callback is fired).
|
| + FileSystemOperationRunner::OperationID id =
|
| + operation_runner()->Truncate(URL("foo"), 0,
|
| + base::Bind(&GetStatus, &done, &status));
|
| + operation_runner()->Cancel(id, base::Bind(&GetCancelStatus,
|
| + &done, &cancel_done,
|
| + &cancel_status));
|
| +
|
| + ASSERT_FALSE(done);
|
| + ASSERT_FALSE(cancel_done);
|
| + base::MessageLoop::current()->RunUntilIdle();
|
| +
|
| + ASSERT_TRUE(done);
|
| + ASSERT_TRUE(cancel_done);
|
| + ASSERT_EQ(base::PLATFORM_FILE_ERROR_ABORT, status);
|
| + ASSERT_EQ(base::PLATFORM_FILE_OK, cancel_status);
|
| +}
|
| +
|
| +TEST_F(FileSystemOperationRunnerTest, InvalidURLErrorAndCancel) {
|
| + bool done = false;
|
| + bool cancel_done = false;
|
| + base::PlatformFileError status = base::PLATFORM_FILE_ERROR_FAILED;
|
| + base::PlatformFileError cancel_status = base::PLATFORM_FILE_ERROR_FAILED;
|
| +
|
| + // Call Truncate with invalid URL, and try to cancel it immediately
|
| + // after that (before its callback is fired).
|
| + FileSystemOperationRunner::OperationID id =
|
| + operation_runner()->Truncate(FileSystemURL(), 0,
|
| + base::Bind(&GetStatus, &done, &status));
|
| + operation_runner()->Cancel(id, base::Bind(&GetCancelStatus,
|
| + &done, &cancel_done,
|
| + &cancel_status));
|
| +
|
| + ASSERT_FALSE(done);
|
| + ASSERT_FALSE(cancel_done);
|
| + base::MessageLoop::current()->RunUntilIdle();
|
| +
|
| + ASSERT_TRUE(done);
|
| + ASSERT_TRUE(cancel_done);
|
| + ASSERT_EQ(base::PLATFORM_FILE_ERROR_INVALID_URL, status);
|
| + ASSERT_EQ(base::PLATFORM_FILE_ERROR_INVALID_OPERATION, cancel_status);
|
| +}
|
| +
|
| +} // namespace fileapi
|
|
|