diff options
author | jianli@chromium.org <jianli@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-08-31 02:42:36 +0000 |
---|---|---|
committer | jianli@chromium.org <jianli@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-08-31 02:42:36 +0000 |
commit | 8107004fbfe9f7ea4be59f6620273c1206c12f42 (patch) | |
tree | f86046c0bb77f471f60d088626ad291360b356ff /webkit/blob/blob_storage_controller_unittest.cc | |
parent | 766f613f1c7022941e2e182543d0208a61210a16 (diff) | |
download | chromium_src-8107004fbfe9f7ea4be59f6620273c1206c12f42.zip chromium_src-8107004fbfe9f7ea4be59f6620273c1206c12f42.tar.gz chromium_src-8107004fbfe9f7ea4be59f6620273c1206c12f42.tar.bz2 |
Support handling blob URL and resolve blob references in upload data.
BUG=none
TEST=unittest
Review URL: http://codereview.chromium.org/3282003
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@57938 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'webkit/blob/blob_storage_controller_unittest.cc')
-rw-r--r-- | webkit/blob/blob_storage_controller_unittest.cc | 172 |
1 files changed, 163 insertions, 9 deletions
diff --git a/webkit/blob/blob_storage_controller_unittest.cc b/webkit/blob/blob_storage_controller_unittest.cc index 3bd0b63..e977585 100644 --- a/webkit/blob/blob_storage_controller_unittest.cc +++ b/webkit/blob/blob_storage_controller_unittest.cc @@ -6,10 +6,13 @@ #include "base/time.h" #include "base/ref_counted.h" #include "base/scoped_ptr.h" +#include "net/base/upload_data.h" #include "testing/gtest/include/gtest/gtest.h" #include "webkit/blob/blob_data.h" #include "webkit/blob/blob_storage_controller.h" +using net::UploadData; + namespace webkit_blob { TEST(BlobStorageControllerTest, RegisterBlobUrl) { @@ -68,18 +71,169 @@ TEST(BlobStorageControllerTest, RegisterBlobUrl) { ASSERT_TRUE(blob_data_found != NULL); EXPECT_TRUE(*blob_data_found == *blob_data1); - // Test registering a blob URL referring to non-existent blob URL. - GURL nonexistent_blob_url("blob://url_none"); - GURL blob_url4("blob://url_4"); - blob_storage_controller->RegisterBlobUrlFrom(blob_url4, nonexistent_blob_url); - - blob_data_found = blob_storage_controller->GetBlobDataFromUrl(blob_url4); - EXPECT_FALSE(blob_data_found != NULL); - // Test unregistering a blob URL. blob_storage_controller->UnregisterBlobUrl(blob_url3); blob_data_found = blob_storage_controller->GetBlobDataFromUrl(blob_url3); - EXPECT_FALSE(blob_data_found != NULL); + EXPECT_TRUE(!blob_data_found); +} + +TEST(BlobStorageControllerTest, ResolveBlobReferencesInUploadData) { + // Setup blob data for testing. + base::Time time1, time2; + base::Time::FromString(L"Tue, 15 Nov 1994, 12:45:26 GMT", &time1); + base::Time::FromString(L"Mon, 14 Nov 1994, 11:30:49 GMT", &time2); + + scoped_ptr<BlobStorageController> blob_storage_controller( + new BlobStorageController()); + + scoped_refptr<BlobData> blob_data = new BlobData(); + + GURL blob_url0("blob://url_0"); + blob_storage_controller->RegisterBlobUrl(blob_url0, blob_data); + + blob_data->AppendData("BlobData"); + blob_data->AppendFile( + FilePath(FILE_PATH_LITERAL("BlobFile.txt")), 0, 20, time1); + + GURL blob_url1("blob://url_1"); + blob_storage_controller->RegisterBlobUrl(blob_url1, blob_data); + + GURL blob_url2("blob://url_2"); + blob_storage_controller->RegisterBlobUrlFrom(blob_url2, blob_url1); + + GURL blob_url3("blob://url_3"); + blob_storage_controller->RegisterBlobUrlFrom(blob_url3, blob_url2); + + // Setup upload data elements for comparison. + UploadData::Element blob_element1, blob_element2; + blob_element1.SetToBytes( + blob_data->items().at(0).data().c_str() + + static_cast<int>(blob_data->items().at(0).offset()), + static_cast<int>(blob_data->items().at(0).length())); + blob_element2.SetToFilePathRange( + blob_data->items().at(1).file_path(), + blob_data->items().at(1).offset(), + blob_data->items().at(1).length(), + blob_data->items().at(1).expected_modification_time()); + + UploadData::Element upload_element1, upload_element2; + upload_element1.SetToBytes("Hello", 5); + upload_element2.SetToFilePathRange( + FilePath(FILE_PATH_LITERAL("foo1.txt")), 0, 20, time2); + + // Test no blob reference. + scoped_refptr<UploadData> upload_data = new UploadData(); + upload_data->AppendBytes( + &upload_element1.bytes().at(0), + upload_element1.bytes().size()); + upload_data->AppendFileRange( + upload_element2.file_path(), + upload_element2.file_range_offset(), + upload_element2.file_range_length(), + upload_element2.expected_file_modification_time()); + + blob_storage_controller->ResolveBlobReferencesInUploadData(upload_data.get()); + ASSERT_EQ(upload_data->elements()->size(), 2U); + EXPECT_TRUE(upload_data->elements()->at(0) == upload_element1); + EXPECT_TRUE(upload_data->elements()->at(1) == upload_element2); + + // Test having only one blob reference that refers to empty blob data. + upload_data = new UploadData(); + upload_data->AppendBlob(blob_url0); + + blob_storage_controller->ResolveBlobReferencesInUploadData(upload_data.get()); + ASSERT_EQ(upload_data->elements()->size(), 0U); + + // Test having only one blob reference. + upload_data = new UploadData(); + upload_data->AppendBlob(blob_url1); + + blob_storage_controller->ResolveBlobReferencesInUploadData(upload_data.get()); + ASSERT_EQ(upload_data->elements()->size(), 2U); + EXPECT_TRUE(upload_data->elements()->at(0) == blob_element1); + EXPECT_TRUE(upload_data->elements()->at(1) == blob_element2); + + // Test having one blob reference at the beginning. + upload_data = new UploadData(); + upload_data->AppendBlob(blob_url1); + upload_data->AppendBytes( + &upload_element1.bytes().at(0), + upload_element1.bytes().size()); + upload_data->AppendFileRange( + upload_element2.file_path(), + upload_element2.file_range_offset(), + upload_element2.file_range_length(), + upload_element2.expected_file_modification_time()); + + blob_storage_controller->ResolveBlobReferencesInUploadData(upload_data.get()); + ASSERT_EQ(upload_data->elements()->size(), 4U); + EXPECT_TRUE(upload_data->elements()->at(0) == blob_element1); + EXPECT_TRUE(upload_data->elements()->at(1) == blob_element2); + EXPECT_TRUE(upload_data->elements()->at(2) == upload_element1); + EXPECT_TRUE(upload_data->elements()->at(3) == upload_element2); + + // Test having one blob reference at the end. + upload_data = new UploadData(); + upload_data->AppendBytes( + &upload_element1.bytes().at(0), + upload_element1.bytes().size()); + upload_data->AppendFileRange( + upload_element2.file_path(), + upload_element2.file_range_offset(), + upload_element2.file_range_length(), + upload_element2.expected_file_modification_time()); + upload_data->AppendBlob(blob_url1); + + blob_storage_controller->ResolveBlobReferencesInUploadData(upload_data.get()); + ASSERT_EQ(upload_data->elements()->size(), 4U); + EXPECT_TRUE(upload_data->elements()->at(0) == upload_element1); + EXPECT_TRUE(upload_data->elements()->at(1) == upload_element2); + EXPECT_TRUE(upload_data->elements()->at(2) == blob_element1); + EXPECT_TRUE(upload_data->elements()->at(3) == blob_element2); + + // Test having one blob reference in the middle. + upload_data = new UploadData(); + upload_data->AppendBytes( + &upload_element1.bytes().at(0), + upload_element1.bytes().size()); + upload_data->AppendBlob(blob_url1); + upload_data->AppendFileRange( + upload_element2.file_path(), + upload_element2.file_range_offset(), + upload_element2.file_range_length(), + upload_element2.expected_file_modification_time()); + + blob_storage_controller->ResolveBlobReferencesInUploadData(upload_data.get()); + ASSERT_EQ(upload_data->elements()->size(), 4U); + EXPECT_TRUE(upload_data->elements()->at(0) == upload_element1); + EXPECT_TRUE(upload_data->elements()->at(1) == blob_element1); + EXPECT_TRUE(upload_data->elements()->at(2) == blob_element2); + EXPECT_TRUE(upload_data->elements()->at(3) == upload_element2); + + // Test having multiple blob references. + upload_data = new UploadData(); + upload_data->AppendBlob(blob_url1); + upload_data->AppendBytes( + &upload_element1.bytes().at(0), + upload_element1.bytes().size()); + upload_data->AppendBlob(blob_url2); + upload_data->AppendBlob(blob_url3); + upload_data->AppendFileRange( + upload_element2.file_path(), + upload_element2.file_range_offset(), + upload_element2.file_range_length(), + upload_element2.expected_file_modification_time()); + + blob_storage_controller->ResolveBlobReferencesInUploadData(upload_data.get()); + ASSERT_EQ(upload_data->elements()->size(), 8U); + EXPECT_TRUE(upload_data->elements()->at(0) == blob_element1); + EXPECT_TRUE(upload_data->elements()->at(1) == blob_element2); + EXPECT_TRUE(upload_data->elements()->at(2) == upload_element1); + EXPECT_TRUE(upload_data->elements()->at(3) == blob_element1); + EXPECT_TRUE(upload_data->elements()->at(4) == blob_element2); + EXPECT_TRUE(upload_data->elements()->at(5) == blob_element1); + EXPECT_TRUE(upload_data->elements()->at(6) == blob_element2); + EXPECT_TRUE(upload_data->elements()->at(7) == upload_element2); } } // namespace webkit_blob |