diff options
author | dmikurube@chromium.org <dmikurube@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-04-07 01:48:08 +0000 |
---|---|---|
committer | dmikurube@chromium.org <dmikurube@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-04-07 01:48:08 +0000 |
commit | 87ab48f75ba659749ca43fdfaa5e2d156fb63ad3 (patch) | |
tree | 60d8490d438d477bbb2df0c54bfbf4dfa4519dc2 | |
parent | 385d19e955583fcd24930fa2256a3b8e7fbf456a (diff) | |
download | chromium_src-87ab48f75ba659749ca43fdfaa5e2d156fb63ad3.zip chromium_src-87ab48f75ba659749ca43fdfaa5e2d156fb63ad3.tar.gz chromium_src-87ab48f75ba659749ca43fdfaa5e2d156fb63ad3.tar.bz2 |
Add a unittest for FileSystemOperation::Write().
BUG=none
TEST=FileSystemOperationTest.TestWrite
Review URL: http://codereview.chromium.org/6770004
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@80735 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r-- | chrome/chrome_tests.gypi | 1 | ||||
-rw-r--r-- | webkit/fileapi/file_system_operation_unittest.cc | 2 | ||||
-rw-r--r-- | webkit/fileapi/file_system_operation_write_unittest.cc | 253 |
3 files changed, 254 insertions, 2 deletions
diff --git a/chrome/chrome_tests.gypi b/chrome/chrome_tests.gypi index 0b6c5e7..0e3e208 100644 --- a/chrome/chrome_tests.gypi +++ b/chrome/chrome_tests.gypi @@ -1908,6 +1908,7 @@ '../testing/gtest_mac_unittest.mm', '../third_party/cld/encodings/compact_lang_det/compact_lang_det_unittest_small.cc', '../webkit/fileapi/file_system_dir_url_request_job_unittest.cc', + '../webkit/fileapi/file_system_operation_write_unittest.cc', '../webkit/fileapi/file_system_url_request_job_unittest.cc', ], 'conditions': [ diff --git a/webkit/fileapi/file_system_operation_unittest.cc b/webkit/fileapi/file_system_operation_unittest.cc index 9cd128c..69a79fe 100644 --- a/webkit/fileapi/file_system_operation_unittest.cc +++ b/webkit/fileapi/file_system_operation_unittest.cc @@ -707,8 +707,6 @@ TEST_F(FileSystemOperationTest, TestRemoveSuccess) { EXPECT_FALSE(file_util::DirectoryExists(parent_dir.path())); } -// TODO(ericu): Add tests for Write, Cancel. - TEST_F(FileSystemOperationTest, TestTruncate) { ScopedTempDir dir; ASSERT_TRUE(dir.CreateUniqueTempDir()); diff --git a/webkit/fileapi/file_system_operation_write_unittest.cc b/webkit/fileapi/file_system_operation_write_unittest.cc new file mode 100644 index 0000000..e331338 --- /dev/null +++ b/webkit/fileapi/file_system_operation_write_unittest.cc @@ -0,0 +1,253 @@ +// Copyright (c) 2011 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. +// +// NOTE: These tests are run as part of "unit_tests" (in chrome/test/unit) +// rather than as part of test_shell_tests because they rely on being able +// to instantiate a MessageLoop of type TYPE_IO. test_shell_tests uses +// TYPE_UI, which URLRequest doesn't allow. +// + +#include "webkit/fileapi/file_system_operation.h" + +#include "base/logging.h" +#include "base/message_loop.h" +#include "base/memory/scoped_ptr.h" +#include "base/memory/scoped_temp_dir.h" +#include "base/message_loop.h" +#include "googleurl/src/gurl.h" +#include "net/url_request/url_request.h" +#include "net/url_request/url_request_context.h" +#include "net/url_request/url_request_job.h" +#include "testing/gtest/include/gtest/gtest.h" +#include "webkit/blob/blob_data.h" +#include "webkit/blob/blob_storage_controller.h" +#include "webkit/blob/blob_url_request_job.h" +#include "webkit/fileapi/file_system_callback_dispatcher.h" +#include "webkit/fileapi/file_system_file_util.h" + +namespace fileapi { + +class TestURLRequestContext : public net::URLRequestContext { + public: + webkit_blob::BlobStorageController* blob_storage_controller() { + return &blob_storage_controller_; + } + + private: + webkit_blob::BlobStorageController blob_storage_controller_; +}; + +static net::URLRequestJob* BlobURLRequestJobFactory(net::URLRequest* request, + const std::string& scheme) { + webkit_blob::BlobStorageController* blob_storage_controller = + static_cast<TestURLRequestContext*>(request->context())-> + blob_storage_controller(); + return new webkit_blob::BlobURLRequestJob( + request, + blob_storage_controller->GetBlobDataFromUrl(request->url()), + base::MessageLoopProxy::CreateForCurrentThread()); +} + +class MockDispatcher; + +class FileSystemOperationTest : public testing::Test { + public: + FileSystemOperationTest() + : loop_(MessageLoop::TYPE_IO), + status_(base::PLATFORM_FILE_OK), + bytes_written_(0), + complete_(false) {} + + FileSystemOperation* operation(); + + void set_failure_status(base::PlatformFileError status) { + EXPECT_FALSE(complete_); + EXPECT_EQ(status_, base::PLATFORM_FILE_OK); + EXPECT_NE(status, base::PLATFORM_FILE_OK); + complete_ = true; + status_ = status; + } + base::PlatformFileError status() const { return status_; } + void add_bytes_written(int64 bytes, bool complete) { + bytes_written_ += bytes; + EXPECT_FALSE(complete_); + complete_ = complete; + } + int64 bytes_written() const { return bytes_written_; } + bool complete() const { return complete_; } + + virtual void SetUp(); + virtual void TearDown(); + + protected: + MessageLoop loop_; + + ScopedTempDir dir_; + FilePath file_; + + // For post-operation status. + base::PlatformFileError status_; + int64 bytes_written_; + bool complete_; + + DISALLOW_COPY_AND_ASSIGN(FileSystemOperationTest); +}; + +class MockDispatcher : public FileSystemCallbackDispatcher { + public: + MockDispatcher(FileSystemOperationTest* test) : test_(test) { } + + virtual void DidFail(base::PlatformFileError status) { + test_->set_failure_status(status); + MessageLoop::current()->Quit(); + } + + virtual void DidSucceed() { + ADD_FAILURE(); + } + + virtual void DidReadMetadata( + const base::PlatformFileInfo& info, + const FilePath& platform_path) { + ADD_FAILURE(); + } + + virtual void DidReadDirectory( + const std::vector<base::FileUtilProxy::Entry>& entries, + bool /* has_more */) { + ADD_FAILURE(); + } + + virtual void DidOpenFileSystem(const std::string&, const FilePath&) { + ADD_FAILURE(); + } + + virtual void DidWrite(int64 bytes, bool complete) { + test_->add_bytes_written(bytes, complete); + MessageLoop::current()->Quit(); + } + + private: + FileSystemOperationTest* test_; +}; + +void FileSystemOperationTest::SetUp() { + ASSERT_TRUE(dir_.CreateUniqueTempDir()); + file_util::CreateTemporaryFileInDir(dir_.path(), &file_); + net::URLRequest::RegisterProtocolFactory("blob", &BlobURLRequestJobFactory); +} + +void FileSystemOperationTest::TearDown() { + net::URLRequest::RegisterProtocolFactory("blob", NULL); +} + +FileSystemOperation* FileSystemOperationTest::operation() { + FileSystemOperation* operation = new FileSystemOperation( + new MockDispatcher(this), + base::MessageLoopProxy::CreateForCurrentThread(), + NULL, + FileSystemFileUtil::GetInstance()); + operation->file_system_operation_context()->set_src_type( + kFileSystemTypeTemporary); + operation->file_system_operation_context()->set_dest_type( + kFileSystemTypeTemporary); + return operation; +} + +TEST_F(FileSystemOperationTest, TestWriteSuccess) { + GURL blob_url("blob:success"); + scoped_refptr<webkit_blob::BlobData> blob_data(new webkit_blob::BlobData()); + blob_data->AppendData("Hello, world!\n"); + + scoped_refptr<TestURLRequestContext> url_request_context( + new TestURLRequestContext()); + url_request_context->blob_storage_controller()-> + RegisterBlobUrl(blob_url, blob_data); + + operation()->Write(url_request_context, file_, blob_url, 0); + MessageLoop::current()->Run(); + + url_request_context->blob_storage_controller()->UnregisterBlobUrl(blob_url); + + EXPECT_EQ(14, bytes_written()); + EXPECT_EQ(base::PLATFORM_FILE_OK, status()); + EXPECT_TRUE(complete()); +} + +TEST_F(FileSystemOperationTest, TestWriteZero) { + GURL blob_url("blob:zero"); + scoped_refptr<webkit_blob::BlobData> blob_data(new webkit_blob::BlobData()); + blob_data->AppendData(""); + + scoped_refptr<TestURLRequestContext> url_request_context( + new TestURLRequestContext()); + url_request_context->blob_storage_controller()-> + RegisterBlobUrl(blob_url, blob_data); + + operation()->Write(url_request_context, file_, blob_url, 0); + MessageLoop::current()->Run(); + + url_request_context->blob_storage_controller()->UnregisterBlobUrl(blob_url); + + EXPECT_EQ(0, bytes_written()); + EXPECT_EQ(base::PLATFORM_FILE_OK, status()); + EXPECT_TRUE(complete()); +} + +TEST_F(FileSystemOperationTest, TestWriteInvalidBlobUrl) { + scoped_refptr<TestURLRequestContext> url_request_context( + new TestURLRequestContext()); + + operation()->Write(url_request_context, file_, GURL("blob:invalid"), 0); + MessageLoop::current()->Run(); + + EXPECT_EQ(0, bytes_written()); + EXPECT_EQ(base::PLATFORM_FILE_OK, status()); + EXPECT_TRUE(complete()); +} + +TEST_F(FileSystemOperationTest, TestWriteInvalidFile) { + GURL blob_url("blob:writeinvalidfile"); + scoped_refptr<webkit_blob::BlobData> blob_data(new webkit_blob::BlobData()); + blob_data->AppendData("It\'ll not be written."); + + scoped_refptr<TestURLRequestContext> url_request_context( + new TestURLRequestContext()); + url_request_context->blob_storage_controller()-> + RegisterBlobUrl(blob_url, blob_data); + + operation()->Write(url_request_context, + FilePath(FILE_PATH_LITERAL("/nonexist")), blob_url, 0); + MessageLoop::current()->Run(); + + url_request_context->blob_storage_controller()->UnregisterBlobUrl(blob_url); + + EXPECT_EQ(0, bytes_written()); + EXPECT_EQ(base::PLATFORM_FILE_ERROR_NOT_FOUND, status()); + EXPECT_TRUE(complete()); +} + +TEST_F(FileSystemOperationTest, TestWriteDir) { + GURL blob_url("blob:writedir"); + scoped_refptr<webkit_blob::BlobData> blob_data(new webkit_blob::BlobData()); + blob_data->AppendData("It\'ll not be written, too."); + + scoped_refptr<TestURLRequestContext> url_request_context( + new TestURLRequestContext()); + url_request_context->blob_storage_controller()-> + RegisterBlobUrl(blob_url, blob_data); + + operation()->Write(url_request_context, dir_.path(), blob_url, 0); + MessageLoop::current()->Run(); + + url_request_context->blob_storage_controller()->UnregisterBlobUrl(blob_url); + + EXPECT_EQ(0, bytes_written()); + EXPECT_EQ(base::PLATFORM_FILE_ERROR_ACCESS_DENIED, status()); + EXPECT_TRUE(complete()); +} + +// TODO(ericu,dmikurube): Add tests for Cancel. + +} // namespace fileapi |