Chromium Code Reviews| 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()); |
| +} |