diff options
author | jochen@chromium.org <jochen@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-03-29 07:21:13 +0000 |
---|---|---|
committer | jochen@chromium.org <jochen@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-03-29 07:21:13 +0000 |
commit | f58330c4b964edd22ef02325390975a013a3f34a (patch) | |
tree | 15061bcc0ca596409a7113cde0bffc2b49206a0c | |
parent | 82d76938133d016ac5d9cc4b56d603f96876e7f3 (diff) | |
download | chromium_src-f58330c4b964edd22ef02325390975a013a3f34a.zip chromium_src-f58330c4b964edd22ef02325390975a013a3f34a.tar.gz chromium_src-f58330c4b964edd22ef02325390975a013a3f34a.tar.bz2 |
Don't show extension state in cookie tree list.
BUG=38659
TEST=Unit tests in browsing_data_local_storage_helper_unittest.cc and browsing_data_database_helper_unittest.cc
Review URL: http://codereview.chromium.org/1405002
Patch from Mattias Nissler.
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@42935 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r-- | chrome/browser/browsing_data_appcache_helper.cc | 13 | ||||
-rw-r--r-- | chrome/browser/browsing_data_database_helper.cc | 9 | ||||
-rw-r--r-- | chrome/browser/browsing_data_database_helper.h | 6 | ||||
-rw-r--r-- | chrome/browser/browsing_data_database_helper_unittest.cc | 80 | ||||
-rw-r--r-- | chrome/browser/browsing_data_local_storage_helper.cc | 6 | ||||
-rw-r--r-- | chrome/browser/browsing_data_local_storage_helper.h | 4 | ||||
-rw-r--r-- | chrome/browser/browsing_data_local_storage_helper_unittest.cc | 9 | ||||
-rw-r--r-- | chrome/browser/cookies_tree_model.cc | 24 | ||||
-rw-r--r-- | chrome/browser/cookies_tree_model.h | 2 | ||||
-rw-r--r-- | chrome/chrome_tests.gypi | 1 |
10 files changed, 115 insertions, 39 deletions
diff --git a/chrome/browser/browsing_data_appcache_helper.cc b/chrome/browser/browsing_data_appcache_helper.cc index 8fa342e..adfa2c6 100644 --- a/chrome/browser/browsing_data_appcache_helper.cc +++ b/chrome/browser/browsing_data_appcache_helper.cc @@ -7,6 +7,7 @@ #include "chrome/browser/chrome_thread.h" #include "chrome/browser/net/chrome_url_request_context.h" #include "chrome/browser/profile.h" +#include "chrome/common/url_constants.h" #include "webkit/appcache/appcache_database.h" #include "webkit/appcache/appcache_storage.h" @@ -63,6 +64,18 @@ void BrowsingDataAppCacheHelper::DeleteAppCacheGroup( void BrowsingDataAppCacheHelper::OnFetchComplete(int rv) { if (ChromeThread::CurrentlyOn(ChromeThread::IO)) { + // Filter out appache info entries for extensions. Extension state is not + // considered browsing data. + typedef std::map<GURL, appcache::AppCacheInfoVector> InfoByOrigin; + InfoByOrigin& origin_map = info_collection_->infos_by_origin; + for (InfoByOrigin::iterator origin = origin_map.begin(); + origin != origin_map.end();) { + InfoByOrigin::iterator current = origin; + ++origin; + if (current->first.SchemeIs(chrome::kExtensionScheme)) + origin_map.erase(current); + } + appcache_info_callback_ = NULL; ChromeThread::PostTask(ChromeThread::UI, FROM_HERE, NewRunnableMethod( this, &BrowsingDataAppCacheHelper::OnFetchComplete, rv)); diff --git a/chrome/browser/browsing_data_database_helper.cc b/chrome/browser/browsing_data_database_helper.cc index 9c3acf0..5b950cf 100644 --- a/chrome/browser/browsing_data_database_helper.cc +++ b/chrome/browser/browsing_data_database_helper.cc @@ -56,6 +56,13 @@ void BrowsingDataDatabaseHelper::FetchDatabaseInfoInFileThread() { if (tracker_.get() && tracker_->GetAllOriginsInfo(&origins_info)) { for (std::vector<webkit_database::OriginInfo>::const_iterator ori = origins_info.begin(); ori != origins_info.end(); ++ori) { + const std::string origin_identifier(UTF16ToUTF8(ori->GetOrigin())); + if (StartsWithASCII(origin_identifier, + std::string(chrome::kExtensionScheme), + true)) { + // Extension state is not considered browsing data. + continue; + } scoped_ptr<WebKit::WebSecurityOrigin> web_security_origin( WebKit::WebSecurityOrigin::createFromDatabaseIdentifier( ori->GetOrigin())); @@ -69,7 +76,7 @@ void BrowsingDataDatabaseHelper::FetchDatabaseInfoInFileThread() { database_info_.push_back(DatabaseInfo( web_security_origin->host().utf8(), UTF16ToUTF8(*db), - UTF16ToUTF8(ori->GetOrigin()), + origin_identifier, UTF16ToUTF8(ori->GetDatabaseDescription(*db)), file_info.size, file_info.last_modified)); diff --git a/chrome/browser/browsing_data_database_helper.h b/chrome/browser/browsing_data_database_helper.h index cacba8b..9f48b49 100644 --- a/chrome/browser/browsing_data_database_helper.h +++ b/chrome/browser/browsing_data_database_helper.h @@ -42,12 +42,6 @@ class BrowsingDataDatabaseHelper last_modified(last_modified) { } - bool IsExtensionSchemeData() { - return StartsWithASCII(origin_identifier, - std::string(chrome::kExtensionScheme), - true); - } - bool IsFileSchemeData() { return StartsWithASCII(origin_identifier, std::string(chrome::kFileScheme), diff --git a/chrome/browser/browsing_data_database_helper_unittest.cc b/chrome/browser/browsing_data_database_helper_unittest.cc new file mode 100644 index 0000000..19c7c20 --- /dev/null +++ b/chrome/browser/browsing_data_database_helper_unittest.cc @@ -0,0 +1,80 @@ +// Copyright (c) 2010 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 "chrome/browser/browsing_data_database_helper.h" +#include "chrome/test/in_process_browser_test.h" +#include "chrome/test/testing_profile.h" +#include "chrome/test/ui_test_utils.h" + +static const char kTestIdentifier1[] = "http_www.google.com_0"; + +static const char kTestIdentifierExtension[] = + "chrome-extension_behllobkkfkfnphdnhnkndlbkcpglgmj_0"; + +class BrowsingDataDatabaseHelperTest : public InProcessBrowserTest { + public: + virtual void CreateDatabases() { + webkit_database::DatabaseTracker* db_tracker = + testing_profile_.GetDatabaseTracker(); + string16 db_name = ASCIIToUTF16("db"); + string16 description = ASCIIToUTF16("db_description"); + int64 size; + int64 available; + string16 identifier1(UTF8ToUTF16(kTestIdentifier1)); + db_tracker->DatabaseOpened(identifier1, db_name, description, 1, &size, + &available); + db_tracker->DatabaseClosed(identifier1, db_name); + FilePath db_path1 = db_tracker->GetFullDBFilePath(identifier1, db_name); + file_util::CreateDirectory(db_path1.DirName()); + ASSERT_EQ(0, file_util::WriteFile(db_path1, NULL, 0)); + string16 identifierExtension(UTF8ToUTF16(kTestIdentifierExtension)); + db_tracker->DatabaseOpened(identifierExtension, db_name, description, 1, + &size, &available); + db_tracker->DatabaseClosed(identifierExtension, db_name); + FilePath db_path2 = + db_tracker->GetFullDBFilePath(identifierExtension, db_name); + file_util::CreateDirectory(db_path2.DirName()); + ASSERT_EQ(0, file_util::WriteFile(db_path2, NULL, 0)); + std::vector<webkit_database::OriginInfo> origins; + db_tracker->GetAllOriginsInfo(&origins); + ASSERT_EQ(2U, origins.size()); + } + + protected: + TestingProfile testing_profile_; +}; + +// Called back by BrowsingDataDatabaseHelper on the UI thread once the database +// information has been retrieved. +class StopTestOnCallback { + public: + explicit StopTestOnCallback( + BrowsingDataDatabaseHelper* database_helper) + : database_helper_(database_helper) { + DCHECK(database_helper_); + } + + void Callback(const std::vector<BrowsingDataDatabaseHelper::DatabaseInfo>& + database_info_list) { + DCHECK(ChromeThread::CurrentlyOn(ChromeThread::UI)); + ASSERT_EQ(1UL, database_info_list.size()); + EXPECT_EQ(std::string(kTestIdentifier1), + database_info_list.at(0).origin_identifier); + MessageLoop::current()->Quit(); + } + + private: + BrowsingDataDatabaseHelper* database_helper_; +}; + +IN_PROC_BROWSER_TEST_F(BrowsingDataDatabaseHelperTest, FetchData) { + CreateDatabases(); + scoped_refptr<BrowsingDataDatabaseHelper> database_helper( + new BrowsingDataDatabaseHelper(&testing_profile_)); + StopTestOnCallback stop_test_on_callback(database_helper); + database_helper->StartFetching( + NewCallback(&stop_test_on_callback, &StopTestOnCallback::Callback)); + // Blocks until StopTestOnCallback::Callback is notified. + ui_test_utils::RunMessageLoop(); +} diff --git a/chrome/browser/browsing_data_local_storage_helper.cc b/chrome/browser/browsing_data_local_storage_helper.cc index dfb2da0..b29a65a 100644 --- a/chrome/browser/browsing_data_local_storage_helper.cc +++ b/chrome/browser/browsing_data_local_storage_helper.cc @@ -5,6 +5,7 @@ #include "chrome/browser/browsing_data_local_storage_helper.h" #include "base/file_util.h" +#include "base/string_util.h" #include "base/message_loop.h" #include "chrome/browser/chrome_thread.h" #include "chrome/browser/in_process_webkit/webkit_context.h" @@ -69,6 +70,11 @@ void BrowsingDataLocalStorageHelper::FetchLocalStorageInfoInWebKitThread() { scoped_ptr<WebKit::WebSecurityOrigin> web_security_origin( WebKit::WebSecurityOrigin::createFromDatabaseIdentifier( webkit_glue::FilePathToWebString(file_path.BaseName()))); + if (EqualsASCII(web_security_origin->protocol(), + chrome::kExtensionScheme)) { + // Extension state is not considered browsing data. + continue; + } file_util::FileInfo file_info; bool ret = file_util::GetFileInfo(file_path, &file_info); if (ret) { diff --git a/chrome/browser/browsing_data_local_storage_helper.h b/chrome/browser/browsing_data_local_storage_helper.h index 35ca6bd..2022498 100644 --- a/chrome/browser/browsing_data_local_storage_helper.h +++ b/chrome/browser/browsing_data_local_storage_helper.h @@ -47,10 +47,6 @@ class BrowsingDataLocalStorageHelper last_modified(last_modified) { } - bool IsExtensionSchemeData() { - return protocol == chrome::kExtensionScheme; - } - bool IsFileSchemeData() { return protocol == chrome::kFileScheme; } diff --git a/chrome/browser/browsing_data_local_storage_helper_unittest.cc b/chrome/browser/browsing_data_local_storage_helper_unittest.cc index 2f3a5a9..e98c5f1 100644 --- a/chrome/browser/browsing_data_local_storage_helper_unittest.cc +++ b/chrome/browser/browsing_data_local_storage_helper_unittest.cc @@ -25,13 +25,18 @@ static const FilePath::CharType kTestFile1[] = static const FilePath::CharType kTestFileInvalid[] = FILE_PATH_LITERAL("http_www.google.com_localstorage_0.foo"); +// This is only here to test that extension state is not listed by the helper. +static const FilePath::CharType kTestFileExtension[] = FILE_PATH_LITERAL( + "chrome-extension_behllobkkfkfnphdnhnkndlbkcpglgmj_0.localstorage"); + + class BrowsingDataLocalStorageHelperTest : public InProcessBrowserTest { protected: void CreateLocalStorageFilesForTest() { FilePath storage_path = GetLocalStoragePathForTestingProfile(); file_util::CreateDirectory(storage_path); const FilePath::CharType* kFilesToCreate[] = { - kTestFile0, kTestFile1, kTestFileInvalid, + kTestFile0, kTestFile1, kTestFileInvalid, kTestFileExtension }; for (size_t i = 0; i < arraysize(kFilesToCreate); ++i) { FilePath file_path = storage_path.Append(kFilesToCreate[i]); @@ -144,5 +149,5 @@ IN_PROC_BROWSER_TEST_F(BrowsingDataLocalStorageHelperTest, DeleteSingleFile) { ASSERT_FALSE(FilePath(kTestFile0) == file_path.BaseName()); ++num_files; } - ASSERT_EQ(2, num_files); + ASSERT_EQ(3, num_files); } diff --git a/chrome/browser/cookies_tree_model.cc b/chrome/browser/cookies_tree_model.cc index 7fd0179..46dcb4c 100644 --- a/chrome/browser/cookies_tree_model.cc +++ b/chrome/browser/cookies_tree_model.cc @@ -499,8 +499,6 @@ void CookiesTreeModel::PopulateDatabaseInfoWithFilter( std::wstring origin_node_name; if (database_info->IsFileSchemeData()) origin_node_name = UTF8ToWide(kFileOriginNodeName); - else if (database_info->IsExtensionSchemeData()) - origin_node_name = FormExtensionNodeName(database_info->host); else origin_node_name = UTF8ToWide(database_info->host); @@ -538,8 +536,6 @@ void CookiesTreeModel::PopulateLocalStorageInfoWithFilter( std::wstring origin_node_name; if (local_storage_info->IsFileSchemeData()) origin_node_name = UTF8ToWide(kFileOriginNodeName); - else if (local_storage_info->IsExtensionSchemeData()) - origin_node_name = FormExtensionNodeName(local_storage_info->host); else origin_node_name = UTF8ToWide(local_storage_info->host); @@ -575,23 +571,3 @@ void CookiesTreeModel::NotifyObserverEndBatch() { TreeModelEndBatch(this)); } } - -std::wstring CookiesTreeModel::FormExtensionNodeName( - const std::string& extension_id) { - Extension* extension = - profile_->GetExtensionsService()->GetExtensionById(extension_id, true); - std::wstring extension_name = extension ? - UTF8ToWide(extension->name()) : - l10n_util::GetString(IDS_UNKNOWN_PLUGIN_NAME); - - // Since the extension_name will be concatenated with a prefix, we need - // to explicitly set the extension_name to be LTR format if there is no - // strong RTL charater in it. Otherwise, if the prefix is an RTL word, - // the concatenated result might be wrong. For extension named - // "Great Extension!" the concatenated result would be something like - // "!Great Extension :NOISNETXE", in which capital letters "NOISNETXE" - // stand for the Hebrew word for "extension". - base::i18n::AdjustStringForLocaleDirection(extension_name, &extension_name); - return l10n_util::GetStringF(IDS_TASK_MANAGER_EXTENSION_PREFIX, - extension_name); -} diff --git a/chrome/browser/cookies_tree_model.h b/chrome/browser/cookies_tree_model.h index 50f2e4a..7b68640 100644 --- a/chrome/browser/cookies_tree_model.h +++ b/chrome/browser/cookies_tree_model.h @@ -414,8 +414,6 @@ class CookiesTreeModel : public TreeNodeModel<CookieTreeNode> { void PopulateDatabaseInfoWithFilter(const std::wstring& filter); void PopulateLocalStorageInfoWithFilter(const std::wstring& filter); - std::wstring FormExtensionNodeName(const std::string& extension_id); - void NotifyObserverBeginBatch(); void NotifyObserverEndBatch(); diff --git a/chrome/chrome_tests.gypi b/chrome/chrome_tests.gypi index 7ae58bf..98333db 100644 --- a/chrome/chrome_tests.gypi +++ b/chrome/chrome_tests.gypi @@ -1204,6 +1204,7 @@ 'browser/autocomplete/autocomplete_browsertest.cc', 'browser/browser_browsertest.cc', 'browser/browser_init_browsertest.cc', + 'browser/browsing_data_database_helper_unittest.cc', 'browser/browsing_data_local_storage_helper_unittest.cc', 'browser/crash_recovery_browsertest.cc', 'browser/dom_ui/file_browse_browsertest.cc', |