Index: chrome/browser/browsing_data_database_helper_browsertest.cc |
diff --git a/chrome/browser/browsing_data_database_helper_browsertest.cc b/chrome/browser/browsing_data_database_helper_browsertest.cc |
index 82b47fb1f81c1b0a9044dc3060baf7a10e16543e..0c901b3fb830a8028d790c9841837039ae0a6514 100644 |
--- a/chrome/browser/browsing_data_database_helper_browsertest.cc |
+++ b/chrome/browser/browsing_data_database_helper_browsertest.cc |
@@ -10,11 +10,49 @@ |
#include "chrome/test/testing_profile.h" |
#include "chrome/test/ui_test_utils.h" |
+namespace { |
static const char kTestIdentifier1[] = "http_www.google.com_0"; |
static const char kTestIdentifierExtension[] = |
"chrome-extension_behllobkkfkfnphdnhnkndlbkcpglgmj_0"; |
+class TestCompletionCallback { |
+ public: |
+ TestCompletionCallback() |
+ : have_result_(false), |
+ waiting_for_result_(false) { |
+ } |
+ |
+ const std::vector<BrowsingDataDatabaseHelper::DatabaseInfo>& result() { |
+ WaitForResult(); |
+ return result_; |
+ } |
+ |
+ void callback(const std::vector< |
+ BrowsingDataDatabaseHelper::DatabaseInfo>& info) { |
+ have_result_ = true; |
+ result_ = info; |
+ if (waiting_for_result_) |
+ MessageLoop::current()->Quit(); |
+ } |
+ |
+ private: |
+ void WaitForResult() { |
+ while (!have_result_) { |
Paweł Hajdan Jr.
2011/02/05 12:44:51
Is this loop needed? Generally we should only run
|
+ waiting_for_result_ = true; |
+ MessageLoop::current()->Run(); |
+ waiting_for_result_ = false; |
+ } |
+ } |
+ |
+ bool have_result_; |
+ bool waiting_for_result_; |
+ std::vector<BrowsingDataDatabaseHelper::DatabaseInfo> result_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(TestCompletionCallback); |
+}; |
+} // namespace |
+ |
class BrowsingDataDatabaseHelperTest : public InProcessBrowserTest { |
public: |
virtual void CreateDatabases() { |
@@ -81,3 +119,56 @@ IN_PROC_BROWSER_TEST_F(BrowsingDataDatabaseHelperTest, FetchData) { |
// Blocks until StopTestOnCallback::Callback is notified. |
ui_test_utils::RunMessageLoop(); |
} |
+ |
+IN_PROC_BROWSER_TEST_F(BrowsingDataDatabaseHelperTest, CannedAddDatabase) { |
+ const GURL origin1("http://host1:1/"); |
+ const GURL origin2("http://host2:1/"); |
+ const char origin_str1[] = "http_host1_1"; |
+ const char origin_str2[] = "http_host2_1"; |
+ const char db1[] = "db1"; |
+ const char db2[] = "db2"; |
+ const char db3[] = "db3"; |
+ |
+ scoped_refptr<CannedBrowsingDataDatabaseHelper> helper( |
+ new CannedBrowsingDataDatabaseHelper(&testing_profile_)); |
+ helper->AddDatabase(origin1, db1, ""); |
+ helper->AddDatabase(origin1, db2, ""); |
+ helper->AddDatabase(origin2, db3, ""); |
+ |
+ TestCompletionCallback callback; |
+ helper->StartFetching( |
+ NewCallback(&callback, &TestCompletionCallback::callback)); |
+ |
+ std::vector<BrowsingDataDatabaseHelper::DatabaseInfo> result = |
+ callback.result(); |
+ |
+ ASSERT_EQ(3u, result.size()); |
+ EXPECT_STREQ(origin_str1, result[0].origin_identifier.c_str()); |
+ EXPECT_STREQ(db1, result[0].database_name.c_str()); |
+ EXPECT_STREQ(origin_str1, result[1].origin_identifier.c_str()); |
+ EXPECT_STREQ(db2, result[1].database_name.c_str()); |
+ EXPECT_STREQ(origin_str2, result[2].origin_identifier.c_str()); |
+ EXPECT_STREQ(db3, result[2].database_name.c_str()); |
+} |
+ |
+IN_PROC_BROWSER_TEST_F(BrowsingDataDatabaseHelperTest, CannedUnique) { |
+ const GURL origin("http://host1:1/"); |
+ const char origin_str[] = "http_host1_1"; |
+ const char db[] = "db1"; |
+ |
+ scoped_refptr<CannedBrowsingDataDatabaseHelper> helper( |
+ new CannedBrowsingDataDatabaseHelper(&testing_profile_)); |
+ helper->AddDatabase(origin, db, ""); |
+ helper->AddDatabase(origin, db, ""); |
+ |
+ TestCompletionCallback callback; |
+ helper->StartFetching( |
+ NewCallback(&callback, &TestCompletionCallback::callback)); |
+ |
+ std::vector<BrowsingDataDatabaseHelper::DatabaseInfo> result = |
+ callback.result(); |
+ |
+ ASSERT_EQ(1u, result.size()); |
+ EXPECT_STREQ(origin_str, result[0].origin_identifier.c_str()); |
+ EXPECT_STREQ(db, result[0].database_name.c_str()); |
+} |