Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(81)

Unified Diff: webkit/browser/blob/blob_storage_context_unittest.cc

Issue 231923002: Move blob_storage_host from webkit/ to content/ (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: nits Created 6 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « webkit/browser/blob/blob_storage_context.h ('k') | webkit/browser/blob/blob_storage_host.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: webkit/browser/blob/blob_storage_context_unittest.cc
diff --git a/webkit/browser/blob/blob_storage_context_unittest.cc b/webkit/browser/blob/blob_storage_context_unittest.cc
deleted file mode 100644
index e2c115c21a128d7a5f3298b213b23e3b6d0e3f37..0000000000000000000000000000000000000000
--- a/webkit/browser/blob/blob_storage_context_unittest.cc
+++ /dev/null
@@ -1,208 +0,0 @@
-// 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.
-
-#include "base/files/file_path.h"
-#include "base/memory/ref_counted.h"
-#include "base/memory/scoped_ptr.h"
-#include "base/message_loop/message_loop.h"
-#include "base/time/time.h"
-#include "testing/gtest/include/gtest/gtest.h"
-#include "webkit/browser/blob/blob_data_handle.h"
-#include "webkit/browser/blob/blob_storage_context.h"
-#include "webkit/browser/blob/blob_storage_host.h"
-
-namespace webkit_blob {
-
-namespace {
-void SetupBasicBlob(BlobStorageHost* host, const std::string& id) {
- EXPECT_TRUE(host->StartBuildingBlob(id));
- BlobData::Item item;
- item.SetToBytes("1", 1);
- EXPECT_TRUE(host->AppendBlobDataItem(id, item));
- EXPECT_TRUE(host->FinishBuildingBlob(id, "text/plain"));
- EXPECT_FALSE(host->StartBuildingBlob(id));
-}
-} // namespace
-
-TEST(BlobStorageContextTest, IncrementDecrementRef) {
- BlobStorageContext context;
- BlobStorageHost host(&context);
- base::MessageLoop fake_io_message_loop;
-
- // Build up a basic blob.
- const std::string kId("id");
- SetupBasicBlob(&host, kId);
-
- // Make sure it's there, finish building implies a ref of one.
- scoped_ptr<BlobDataHandle> blob_data_handle;
- blob_data_handle = context.GetBlobDataFromUUID(kId);
- EXPECT_TRUE(blob_data_handle);
- blob_data_handle.reset();
-
- // Make sure its still there after inc/dec.
- EXPECT_TRUE(host.IncrementBlobRefCount(kId));
- EXPECT_TRUE(host.DecrementBlobRefCount(kId));
- blob_data_handle = context.GetBlobDataFromUUID(kId);
- EXPECT_TRUE(blob_data_handle);
- blob_data_handle.reset();
-
- // Make sure it goes away in the end.
- EXPECT_TRUE(host.DecrementBlobRefCount(kId));
- blob_data_handle = context.GetBlobDataFromUUID(kId);
- EXPECT_FALSE(blob_data_handle);
- EXPECT_FALSE(host.DecrementBlobRefCount(kId));
- EXPECT_FALSE(host.IncrementBlobRefCount(kId));
-}
-
-TEST(BlobStorageContextTest, BlobDataHandle) {
- BlobStorageContext context;
- BlobStorageHost host(&context);
- base::MessageLoop fake_io_message_loop;
-
- // Build up a basic blob.
- const std::string kId("id");
- SetupBasicBlob(&host, kId);
-
- // Get a handle to it.
- scoped_ptr<BlobDataHandle> blob_data_handle =
- context.GetBlobDataFromUUID(kId);
- EXPECT_TRUE(blob_data_handle);
-
- // Drop the host's ref to it.
- EXPECT_TRUE(host.DecrementBlobRefCount(kId));
-
- // Should still be there due to the handle.
- scoped_ptr<BlobDataHandle> another_handle =
- context.GetBlobDataFromUUID(kId);
- EXPECT_TRUE(another_handle);
-
- // Should disappear after dropping both handles.
- blob_data_handle.reset();
- another_handle.reset();
- blob_data_handle = context.GetBlobDataFromUUID(kId);
- EXPECT_FALSE(blob_data_handle);
-}
-
-TEST(BlobStorageContextTest, CompoundBlobs) {
- const std::string kId1("id1");
- const std::string kId2("id2");
- const std::string kId2Prime("id2.prime");
-
- base::MessageLoop fake_io_message_loop;
-
- // Setup a set of blob data for testing.
- base::Time time1, time2;
- base::Time::FromString("Tue, 15 Nov 1994, 12:45:26 GMT", &time1);
- base::Time::FromString("Mon, 14 Nov 1994, 11:30:49 GMT", &time2);
-
- scoped_refptr<BlobData> blob_data1(new BlobData(kId1));
- blob_data1->AppendData("Data1");
- blob_data1->AppendData("Data2");
- blob_data1->AppendFile(base::FilePath(FILE_PATH_LITERAL("File1.txt")),
- 10, 1024, time1);
-
- scoped_refptr<BlobData> blob_data2(new BlobData(kId2));
- blob_data2->AppendData("Data3");
- blob_data2->AppendBlob(kId1, 8, 100);
- blob_data2->AppendFile(base::FilePath(FILE_PATH_LITERAL("File2.txt")),
- 0, 20, time2);
-
- scoped_refptr<BlobData> canonicalized_blob_data2(new BlobData(kId2Prime));
- canonicalized_blob_data2->AppendData("Data3");
- canonicalized_blob_data2->AppendData("a2___", 2);
- canonicalized_blob_data2->AppendFile(
- base::FilePath(FILE_PATH_LITERAL("File1.txt")),
- 10, 98, time1);
- canonicalized_blob_data2->AppendFile(
- base::FilePath(FILE_PATH_LITERAL("File2.txt")), 0, 20, time2);
-
- BlobStorageContext context;
- scoped_ptr<BlobDataHandle> blob_data_handle;
-
- // Test a blob referring to only data and a file.
- blob_data_handle = context.AddFinishedBlob(blob_data1.get());
- ASSERT_TRUE(blob_data_handle.get());
- EXPECT_TRUE(*(blob_data_handle->data()) == *blob_data1.get());
-
- // Test a blob composed in part with another blob.
- blob_data_handle = context.AddFinishedBlob(blob_data2.get());
- ASSERT_TRUE(blob_data_handle.get());
- EXPECT_TRUE(*(blob_data_handle->data()) == *canonicalized_blob_data2.get());
-}
-
-TEST(BlobStorageContextTest, PublicBlobUrls) {
- BlobStorageContext context;
- BlobStorageHost host(&context);
- base::MessageLoop fake_io_message_loop;
-
- // Build up a basic blob.
- const std::string kId("id");
- SetupBasicBlob(&host, kId);
-
- // Now register a url for that blob.
- GURL kUrl("blob:id");
- EXPECT_TRUE(host.RegisterPublicBlobURL(kUrl, kId));
- scoped_ptr<BlobDataHandle> blob_data_handle =
- context.GetBlobDataFromPublicURL(kUrl);
- ASSERT_TRUE(blob_data_handle.get());
- EXPECT_EQ(kId, blob_data_handle->data()->uuid());
- blob_data_handle.reset();
-
- // The url registration should keep the blob alive even after
- // explicit references are dropped.
- EXPECT_TRUE(host.DecrementBlobRefCount(kId));
- blob_data_handle = context.GetBlobDataFromPublicURL(kUrl);
- EXPECT_TRUE(blob_data_handle);
- blob_data_handle.reset();
-
- // Finally get rid of the url registration and the blob.
- EXPECT_TRUE(host.RevokePublicBlobURL(kUrl));
- blob_data_handle = context.GetBlobDataFromPublicURL(kUrl);
- EXPECT_TRUE(!blob_data_handle.get());
- EXPECT_FALSE(host.RevokePublicBlobURL(kUrl));
-}
-
-TEST(BlobStorageContextTest, HostCleanup) {
- BlobStorageContext context;
- scoped_ptr<BlobStorageHost> host(new BlobStorageHost(&context));
- base::MessageLoop fake_io_message_loop;
-
- // Build up a basic blob and register a url
- const std::string kId("id");
- GURL kUrl("blob:id");
- SetupBasicBlob(host.get(), kId);
- EXPECT_TRUE(host->RegisterPublicBlobURL(kUrl, kId));
-
- // All should disappear upon host deletion.
- host.reset();
- scoped_ptr<BlobDataHandle> handle = context.GetBlobDataFromPublicURL(kUrl);
- EXPECT_TRUE(!handle.get());
- handle = context.GetBlobDataFromUUID(kId);
- EXPECT_TRUE(!handle.get());
-}
-
-TEST(BlobStorageContextTest, EarlyContextDeletion) {
- scoped_ptr<BlobStorageContext> context(new BlobStorageContext);
- BlobStorageHost host(context.get());
- base::MessageLoop fake_io_message_loop;
-
- // Deleting the context should not induce crashes.
- context.reset();
-
- const std::string kId("id");
- GURL kUrl("blob:id");
- EXPECT_FALSE(host.StartBuildingBlob(kId));
- BlobData::Item item;
- item.SetToBytes("1", 1);
- EXPECT_FALSE(host.AppendBlobDataItem(kId, item));
- EXPECT_FALSE(host.FinishBuildingBlob(kId, "text/plain"));
- EXPECT_FALSE(host.RegisterPublicBlobURL(kUrl, kId));
- EXPECT_FALSE(host.IncrementBlobRefCount(kId));
- EXPECT_FALSE(host.DecrementBlobRefCount(kId));
- EXPECT_FALSE(host.RevokePublicBlobURL(kUrl));
-}
-
-// TODO(michaeln): tests for the depcrecated url stuff
-
-} // namespace webkit_blob
« no previous file with comments | « webkit/browser/blob/blob_storage_context.h ('k') | webkit/browser/blob/blob_storage_host.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698