Index: chrome/browser/importer/firefox_importer_browsertest.cc |
diff --git a/chrome/browser/importer/firefox_importer_unittest.cc b/chrome/browser/importer/firefox_importer_browsertest.cc |
similarity index 54% |
copy from chrome/browser/importer/firefox_importer_unittest.cc |
copy to chrome/browser/importer/firefox_importer_browsertest.cc |
index b021871fb507d76e51e210d8f62d1d7ac71762c7..fb6cc2496484a83b472f0c8331aa78287038555b 100644 |
--- a/chrome/browser/importer/firefox_importer_unittest.cc |
+++ b/chrome/browser/importer/firefox_importer_browsertest.cc |
@@ -1,773 +1,517 @@ |
-// Copyright (c) 2012 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 "testing/gtest/include/gtest/gtest.h" |
- |
-#include "base/bind.h" |
-#include "base/file_util.h" |
-#include "base/files/file_path.h" |
-#include "base/path_service.h" |
-#include "base/stl_util.h" |
-#include "base/string16.h" |
-#include "base/string_util.h" |
-#include "base/utf_string_conversions.h" |
-#include "chrome/browser/history/history_types.h" |
-#include "chrome/browser/importer/firefox2_importer.h" |
-#include "chrome/browser/importer/firefox_importer_unittest_utils.h" |
-#include "chrome/browser/importer/firefox_importer_utils.h" |
-#include "chrome/browser/importer/importer_bridge.h" |
-#include "chrome/browser/importer/importer_data_types.h" |
-#include "chrome/browser/importer/importer_host.h" |
-#include "chrome/browser/importer/importer_progress_observer.h" |
-#include "chrome/browser/importer/importer_unittest_utils.h" |
-#include "chrome/browser/importer/nss_decryptor.h" |
-#include "chrome/browser/search_engines/template_url.h" |
-#include "chrome/common/chrome_paths.h" |
-#include "chrome/test/base/testing_profile.h" |
-#include "content/public/common/password_form.h" |
- |
-// TODO(estade): some of these are disabled on mac. http://crbug.com/48007 |
-// TODO(jschuh): Disabled on Win64 build. http://crbug.com/179688 |
-#if defined(OS_MACOSX) || (defined(OS_WIN) && defined(ARCH_CPU_X86_64)) |
-#define MAYBE_IMPORTER(x) DISABLED_##x |
-#else |
-#define MAYBE_IMPORTER(x) x |
-#endif |
- |
-// TODO(jschuh): Disabled on Win64 build. http://crbug.com/179688 |
-#if defined(OS_WIN) && defined(ARCH_CPU_X86_64) |
-#define MAYBE_NSS(x) DISABLED_##x |
-#else |
-#define MAYBE_NSS(x) x |
-#endif |
- |
-namespace { |
- |
-const BookmarkInfo kFirefox2Bookmarks[] = { |
- {true, 2, {L"Bookmarks Toolbar Folder", L"Folder"}, |
- L"On Toolbar's Subfolder", |
- "http://on.toolbar/bookmark/folder"}, |
- {true, 1, {L"Bookmarks Toolbar Folder"}, |
- L"On Bookmark Toolbar", |
- "http://on.toolbar/bookmark"}, |
- {false, 1, {L"Folder"}, |
- L"New Bookmark", |
- "http://domain/"}, |
- {false, 0, {}, |
- L"<Name>", |
- "http://domain.com/q?a=%22er%22&b=%3C%20%20%3E"}, |
- {false, 0, {}, |
- L"Google Home Page", |
- "http://www.google.com/"}, |
- {false, 0, {}, |
- L"\x4E2D\x6587", |
- "http://chinese.site.cn/path?query=1#ref"}, |
- {false, 0, {}, |
- L"mail", |
- "mailto:username@host"}, |
-}; |
- |
-struct PasswordInfo { |
- const char* origin; |
- const char* action; |
- const char* realm; |
- const wchar_t* username_element; |
- const wchar_t* username; |
- const wchar_t* password_element; |
- const wchar_t* password; |
- bool blacklisted; |
-}; |
- |
-const PasswordInfo kFirefox2Passwords[] = { |
- {"https://www.google.com/", "", "https://www.google.com/", |
- L"", L"", L"", L"", true}, |
- {"http://localhost:8080/", "", "http://localhost:8080/corp.google.com", |
- L"", L"http", L"", L"Http1+1abcdefg", false}, |
- {"http://localhost:8080/", "http://localhost:8080/", "http://localhost:8080/", |
- L"loginuser", L"usr", L"loginpass", L"pwd", false}, |
- {"http://localhost:8080/", "http://localhost:8080/", "http://localhost:8080/", |
- L"loginuser", L"firefox", L"loginpass", L"firefox", false}, |
- {"http://localhost/", "", "http://localhost/", |
- L"loginuser", L"hello", L"", L"world", false}, |
-}; |
- |
-struct KeywordInfo { |
- const wchar_t* keyword; |
- const char* url; |
-}; |
- |
-const KeywordInfo kFirefox2Keywords[] = { |
- // Searh plugins |
- { L"amazon.com", |
- "http://www.amazon.com/exec/obidos/external-search/?field-keywords=" |
- "{searchTerms}&mode=blended" }, |
- { L"answers.com", |
- "http://www.answers.com/main/ntquery?s={searchTerms}&gwp=13" }, |
- { L"search.creativecommons.org", |
- "http://search.creativecommons.org/?q={searchTerms}" }, |
- { L"search.ebay.com", |
- "http://search.ebay.com/search/search.dll?query={searchTerms}&" |
- "MfcISAPICommand=GetResult&ht=1&ebaytag1=ebayreg&srchdesc=n&" |
- "maxRecordsReturned=300&maxRecordsPerPage=50&SortProperty=MetaEndSort" }, |
- { L"google.com", |
- "http://www.google.com/search?q={searchTerms}&ie=utf-8&oe=utf-8&aq=t" }, |
- { L"search.yahoo.com", |
- "http://search.yahoo.com/search?p={searchTerms}&ei=UTF-8" }, |
- { L"flickr.com", |
- "http://www.flickr.com/photos/tags/?q={searchTerms}" }, |
- { L"imdb.com", |
- "http://www.imdb.com/find?q={searchTerms}" }, |
- { L"webster.com", |
- "http://www.webster.com/cgi-bin/dictionary?va={searchTerms}" }, |
- // Search keywords. |
- { L"google", "http://www.google.com/" }, |
- { L"< > & \" ' \\ /", "http://g.cn/"}, |
-}; |
- |
-const int kDefaultFirefox2KeywordIndex = 8; |
- |
-class FirefoxObserver : public ProfileWriter, |
- public importer::ImporterProgressObserver { |
- public: |
- FirefoxObserver() : ProfileWriter(NULL) { |
- bookmark_count_ = 0; |
- history_count_ = 0; |
- password_count_ = 0; |
- keyword_count_ = 0; |
- } |
- |
- // importer::ImporterProgressObserver: |
- virtual void ImportStarted() OVERRIDE {} |
- virtual void ImportItemStarted(importer::ImportItem item) OVERRIDE {} |
- virtual void ImportItemEnded(importer::ImportItem item) OVERRIDE {} |
- virtual void ImportEnded() OVERRIDE { |
- MessageLoop::current()->Quit(); |
- EXPECT_EQ(arraysize(kFirefox2Bookmarks), bookmark_count_); |
- EXPECT_EQ(1U, history_count_); |
- EXPECT_EQ(arraysize(kFirefox2Passwords), password_count_); |
- EXPECT_EQ(arraysize(kFirefox2Keywords), keyword_count_); |
- } |
- |
- virtual bool BookmarkModelIsLoaded() const OVERRIDE { |
- // Profile is ready for writing. |
- return true; |
- } |
- |
- virtual bool TemplateURLServiceIsLoaded() const OVERRIDE { |
- return true; |
- } |
- |
- virtual void AddPasswordForm(const content::PasswordForm& form) OVERRIDE { |
- PasswordInfo p = kFirefox2Passwords[password_count_]; |
- EXPECT_EQ(p.origin, form.origin.spec()); |
- EXPECT_EQ(p.realm, form.signon_realm); |
- EXPECT_EQ(p.action, form.action.spec()); |
- EXPECT_EQ(WideToUTF16(p.username_element), form.username_element); |
- EXPECT_EQ(WideToUTF16(p.username), form.username_value); |
- EXPECT_EQ(WideToUTF16(p.password_element), form.password_element); |
- EXPECT_EQ(WideToUTF16(p.password), form.password_value); |
- EXPECT_EQ(p.blacklisted, form.blacklisted_by_user); |
- ++password_count_; |
- } |
- |
- virtual void AddHistoryPage(const history::URLRows& page, |
- history::VisitSource visit_source) OVERRIDE { |
- ASSERT_EQ(1U, page.size()); |
- EXPECT_EQ("http://en-us.www.mozilla.com/", page[0].url().spec()); |
- EXPECT_EQ(ASCIIToUTF16("Firefox Updated"), page[0].title()); |
- EXPECT_EQ(history::SOURCE_FIREFOX_IMPORTED, visit_source); |
- ++history_count_; |
- } |
- |
- virtual void AddBookmarks(const std::vector<BookmarkEntry>& bookmarks, |
- const string16& top_level_folder_name) OVERRIDE { |
- for (size_t i = 0; i < bookmarks.size(); ++i) { |
- if (FindBookmarkEntry(bookmarks[i], kFirefox2Bookmarks, |
- arraysize(kFirefox2Bookmarks))) |
- ++bookmark_count_; |
- } |
- } |
- |
- virtual void AddKeywords(ScopedVector<TemplateURL> template_urls, |
- bool unique_on_host_and_path) OVERRIDE { |
- for (size_t i = 0; i < template_urls.size(); ++i) { |
- // The order might not be deterministic, look in the expected list for |
- // that template URL. |
- bool found = false; |
- string16 keyword = template_urls[i]->keyword(); |
- for (size_t j = 0; j < arraysize(kFirefox2Keywords); ++j) { |
- if (template_urls[i]->keyword() == |
- WideToUTF16Hack(kFirefox2Keywords[j].keyword)) { |
- EXPECT_EQ(kFirefox2Keywords[j].url, template_urls[i]->url()); |
- found = true; |
- break; |
- } |
- } |
- EXPECT_TRUE(found); |
- ++keyword_count_; |
- } |
- } |
- |
- virtual void AddFavicons( |
- const std::vector<history::ImportedFaviconUsage>& favicons) OVERRIDE { |
- } |
- |
- private: |
- virtual ~FirefoxObserver() {} |
- |
- size_t bookmark_count_; |
- size_t history_count_; |
- size_t password_count_; |
- size_t keyword_count_; |
-}; |
- |
-const BookmarkInfo kFirefox3Bookmarks[] = { |
- {true, 1, {L"Bookmarks Toolbar"}, |
- L"Toolbar", |
- "http://site/"}, |
- {false, 0, {}, |
- L"Title", |
- "http://www.google.com/"}, |
-}; |
- |
-const PasswordInfo kFirefox3Passwords[] = { |
- {"http://localhost:8080/", "http://localhost:8080/", "http://localhost:8080/", |
- L"loginuser", L"abc", L"loginpass", L"123", false}, |
- {"http://localhost:8080/", "", "http://localhost:8080/localhost", |
- L"", L"http", L"", L"Http1+1abcdefg", false}, |
-}; |
- |
-const KeywordInfo kFirefox3Keywords[] = { |
- { L"amazon.com", |
- "http://www.amazon.com/exec/obidos/external-search/?field-keywords=" |
- "{searchTerms}&mode=blended" }, |
- { L"answers.com", |
- "http://www.answers.com/main/ntquery?s={searchTerms}&gwp=13" }, |
- { L"search.creativecommons.org", |
- "http://search.creativecommons.org/?q={searchTerms}" }, |
- { L"search.ebay.com", |
- "http://search.ebay.com/search/search.dll?query={searchTerms}&" |
- "MfcISAPICommand=GetResult&ht=1&ebaytag1=ebayreg&srchdesc=n&" |
- "maxRecordsReturned=300&maxRecordsPerPage=50&SortProperty=MetaEndSort" }, |
- { L"google.com", |
- "http://www.google.com/search?q={searchTerms}&ie=utf-8&oe=utf-8&aq=t" }, |
- { L"en.wikipedia.org", |
- "http://en.wikipedia.org/wiki/Special:Search?search={searchTerms}" }, |
- { L"search.yahoo.com", |
- "http://search.yahoo.com/search?p={searchTerms}&ei=UTF-8" }, |
- { L"flickr.com", |
- "http://www.flickr.com/photos/tags/?q={searchTerms}" }, |
- { L"imdb.com", |
- "http://www.imdb.com/find?q={searchTerms}" }, |
- { L"webster.com", |
- "http://www.webster.com/cgi-bin/dictionary?va={searchTerms}" }, |
- // Search keywords. |
- { L"\x4E2D\x6587", "http://www.google.com/" }, |
-}; |
- |
-const int kDefaultFirefox3KeywordIndex = 8; |
- |
-class Firefox3Observer : public ProfileWriter, |
- public importer::ImporterProgressObserver { |
- public: |
- Firefox3Observer() |
- : ProfileWriter(NULL), bookmark_count_(0), history_count_(0), |
- password_count_(0), keyword_count_(0), import_search_engines_(true) { |
- } |
- |
- explicit Firefox3Observer(bool import_search_engines) |
- : ProfileWriter(NULL), bookmark_count_(0), history_count_(0), |
- password_count_(0), keyword_count_(0), |
- import_search_engines_(import_search_engines) { |
- } |
- |
- // importer::ImporterProgressObserver: |
- virtual void ImportStarted() OVERRIDE {} |
- virtual void ImportItemStarted(importer::ImportItem item) OVERRIDE {} |
- virtual void ImportItemEnded(importer::ImportItem item) OVERRIDE {} |
- virtual void ImportEnded() OVERRIDE { |
- MessageLoop::current()->Quit(); |
- EXPECT_EQ(arraysize(kFirefox3Bookmarks), bookmark_count_); |
- EXPECT_EQ(1U, history_count_); |
- EXPECT_EQ(arraysize(kFirefox3Passwords), password_count_); |
- if (import_search_engines_) |
- EXPECT_EQ(arraysize(kFirefox3Keywords), keyword_count_); |
- } |
- |
- virtual bool BookmarkModelIsLoaded() const OVERRIDE { |
- // Profile is ready for writing. |
- return true; |
- } |
- |
- virtual bool TemplateURLServiceIsLoaded() const OVERRIDE { |
- return true; |
- } |
- |
- virtual void AddPasswordForm(const content::PasswordForm& form) OVERRIDE { |
- PasswordInfo p = kFirefox3Passwords[password_count_]; |
- EXPECT_EQ(p.origin, form.origin.spec()); |
- EXPECT_EQ(p.realm, form.signon_realm); |
- EXPECT_EQ(p.action, form.action.spec()); |
- EXPECT_EQ(WideToUTF16(p.username_element), form.username_element); |
- EXPECT_EQ(WideToUTF16(p.username), form.username_value); |
- EXPECT_EQ(WideToUTF16(p.password_element), form.password_element); |
- EXPECT_EQ(WideToUTF16(p.password), form.password_value); |
- EXPECT_EQ(p.blacklisted, form.blacklisted_by_user); |
- ++password_count_; |
- } |
- |
- virtual void AddHistoryPage(const history::URLRows& page, |
- history::VisitSource visit_source) OVERRIDE { |
- ASSERT_EQ(3U, page.size()); |
- EXPECT_EQ("http://www.google.com/", page[0].url().spec()); |
- EXPECT_EQ(ASCIIToUTF16("Google"), page[0].title()); |
- EXPECT_EQ("http://www.google.com/", page[1].url().spec()); |
- EXPECT_EQ(ASCIIToUTF16("Google"), page[1].title()); |
- EXPECT_EQ("http://www.cs.unc.edu/~jbs/resources/perl/perl-cgi/programs/" |
- "form1-POST.html", page[2].url().spec()); |
- EXPECT_EQ(ASCIIToUTF16("example form (POST)"), page[2].title()); |
- EXPECT_EQ(history::SOURCE_FIREFOX_IMPORTED, visit_source); |
- ++history_count_; |
- } |
- |
- virtual void AddBookmarks(const std::vector<BookmarkEntry>& bookmarks, |
- const string16& top_level_folder_name) OVERRIDE { |
- for (size_t i = 0; i < bookmarks.size(); ++i) { |
- if (FindBookmarkEntry(bookmarks[i], kFirefox3Bookmarks, |
- arraysize(kFirefox3Bookmarks))) |
- ++bookmark_count_; |
- } |
- } |
- |
- virtual void AddKeywords(ScopedVector<TemplateURL> template_urls, |
- bool unique_on_host_and_path) OVERRIDE { |
- for (size_t i = 0; i < template_urls.size(); ++i) { |
- // The order might not be deterministic, look in the expected list for |
- // that template URL. |
- bool found = false; |
- string16 keyword = template_urls[i]->keyword(); |
- for (size_t j = 0; j < arraysize(kFirefox3Keywords); ++j) { |
- if (template_urls[i]->keyword() == |
- WideToUTF16Hack(kFirefox3Keywords[j].keyword)) { |
- EXPECT_EQ(kFirefox3Keywords[j].url, template_urls[i]->url()); |
- found = true; |
- break; |
- } |
- } |
- EXPECT_TRUE(found); |
- ++keyword_count_; |
- } |
- } |
- |
- virtual void AddFavicons( |
- const std::vector<history::ImportedFaviconUsage>& favicons) OVERRIDE { |
- } |
- |
- private: |
- virtual ~Firefox3Observer() {} |
- |
- size_t bookmark_count_; |
- size_t history_count_; |
- size_t password_count_; |
- size_t keyword_count_; |
- bool import_search_engines_; |
-}; |
- |
-} // namespace |
- |
-class FirefoxProfileImporterTest : public ImporterTest { |
- protected: |
- virtual void SetUp() OVERRIDE { |
- ImporterTest::SetUp(); |
- // Creates a new profile in a new subdirectory in the temp directory. |
- base::FilePath test_path = temp_dir_.path().AppendASCII("ImporterTest"); |
- file_util::Delete(test_path, true); |
- file_util::CreateDirectory(test_path); |
- profile_path_ = test_path.AppendASCII("profile"); |
- app_path_ = test_path.AppendASCII("app"); |
- file_util::CreateDirectory(app_path_); |
- } |
- |
- void Firefox3xImporterTest(std::string profile_dir, |
- importer::ImporterProgressObserver* observer, |
- ProfileWriter* writer, |
- bool import_search_plugins) { |
- base::FilePath data_path; |
- ASSERT_TRUE(PathService::Get(chrome::DIR_TEST_DATA, &data_path)); |
- data_path = data_path.AppendASCII(profile_dir); |
- ASSERT_TRUE(file_util::CopyDirectory(data_path, profile_path_, true)); |
- ASSERT_TRUE(PathService::Get(chrome::DIR_TEST_DATA, &data_path)); |
- data_path = data_path.AppendASCII("firefox3_nss"); |
- ASSERT_TRUE(file_util::CopyDirectory(data_path, profile_path_, false)); |
- |
- base::FilePath search_engine_path = app_path_; |
- search_engine_path = search_engine_path.AppendASCII("searchplugins"); |
- file_util::CreateDirectory(search_engine_path); |
- if (import_search_plugins) { |
- ASSERT_TRUE(PathService::Get(chrome::DIR_TEST_DATA, &data_path)); |
- data_path = data_path.AppendASCII("firefox3_searchplugins"); |
- if (!file_util::PathExists(data_path)) { |
- // TODO(maruel): Create search test data that we can open source! |
- LOG(ERROR) << L"Missing internal test data"; |
- return; |
- } |
- ASSERT_TRUE(file_util::CopyDirectory(data_path, |
- search_engine_path, false)); |
- } |
- |
- MessageLoop* loop = MessageLoop::current(); |
- importer::SourceProfile source_profile; |
- source_profile.importer_type = importer::TYPE_FIREFOX3; |
- source_profile.app_path = app_path_; |
- source_profile.source_path = profile_path_; |
- scoped_refptr<ImporterHost> host(new ImporterHost); |
- host->SetObserver(observer); |
- int items = importer::HISTORY | importer::PASSWORDS | importer::FAVORITES; |
- if (import_search_plugins) |
- items = items | importer::SEARCH_ENGINES; |
- loop->PostTask(FROM_HERE, base::Bind( |
- &ImporterHost::StartImportSettings, host.get(), source_profile, |
- profile_.get(), items, make_scoped_refptr(writer))); |
- loop->Run(); |
- } |
- |
- base::FilePath profile_path_; |
- base::FilePath app_path_; |
-}; |
- |
-TEST_F(FirefoxProfileImporterTest, MAYBE_IMPORTER(Firefox2Importer)) { |
- base::FilePath data_path; |
- ASSERT_TRUE(PathService::Get(chrome::DIR_TEST_DATA, &data_path)); |
- data_path = data_path.AppendASCII("firefox2_profile"); |
- ASSERT_TRUE(file_util::CopyDirectory(data_path, profile_path_, true)); |
- ASSERT_TRUE(PathService::Get(chrome::DIR_TEST_DATA, &data_path)); |
- data_path = data_path.AppendASCII("firefox2_nss"); |
- ASSERT_TRUE(file_util::CopyDirectory(data_path, profile_path_, false)); |
- |
- base::FilePath search_engine_path = app_path_; |
- search_engine_path = search_engine_path.AppendASCII("searchplugins"); |
- file_util::CreateDirectory(search_engine_path); |
- ASSERT_TRUE(PathService::Get(chrome::DIR_TEST_DATA, &data_path)); |
- data_path = data_path.AppendASCII("firefox2_searchplugins"); |
- if (!file_util::PathExists(data_path)) { |
- // TODO(maruel): Create test data that we can open source! |
- LOG(ERROR) << L"Missing internal test data"; |
- return; |
- } |
- ASSERT_TRUE(file_util::CopyDirectory(data_path, search_engine_path, false)); |
- |
- MessageLoop* loop = MessageLoop::current(); |
- scoped_refptr<ImporterHost> host(new ImporterHost); |
- FirefoxObserver* observer = new FirefoxObserver(); |
- host->SetObserver(observer); |
- importer::SourceProfile source_profile; |
- source_profile.importer_type = importer::TYPE_FIREFOX2; |
- source_profile.app_path = app_path_; |
- source_profile.source_path = profile_path_; |
- |
- loop->PostTask(FROM_HERE, base::Bind( |
- &ImporterHost::StartImportSettings, |
- host.get(), |
- source_profile, |
- profile_.get(), |
- importer::HISTORY | importer::PASSWORDS | |
- importer::FAVORITES | importer::SEARCH_ENGINES, |
- make_scoped_refptr(observer))); |
- loop->Run(); |
-} |
- |
-TEST_F(FirefoxProfileImporterTest, MAYBE_IMPORTER(Firefox30Importer)) { |
- scoped_refptr<Firefox3Observer> observer(new Firefox3Observer()); |
- Firefox3xImporterTest("firefox3_profile", observer.get(), observer.get(), |
- true); |
-} |
- |
-TEST_F(FirefoxProfileImporterTest, MAYBE_IMPORTER(Firefox35Importer)) { |
- bool import_search_engines = false; |
- scoped_refptr<Firefox3Observer> observer( |
- new Firefox3Observer(import_search_engines)); |
- Firefox3xImporterTest("firefox35_profile", observer.get(), observer.get(), |
- import_search_engines); |
-} |
- |
-// The following 2 tests require the use of the NSSDecryptor, on OSX this needs |
-// to run in a separate process, so we use a proxy object so we can share the |
-// same test between platforms. |
-TEST(FirefoxImporterTest, MAYBE_NSS(Firefox2NSS3Decryptor)) { |
- base::FilePath nss_path; |
- ASSERT_TRUE(PathService::Get(chrome::DIR_TEST_DATA, &nss_path)); |
-#if defined(OS_MACOSX) |
- nss_path = nss_path.AppendASCII("firefox2_nss_mac"); |
-#else |
- nss_path = nss_path.AppendASCII("firefox2_nss"); |
-#endif // !OS_MACOSX |
- base::FilePath db_path; |
- ASSERT_TRUE(PathService::Get(chrome::DIR_TEST_DATA, &db_path)); |
- db_path = db_path.AppendASCII("firefox2_profile"); |
- |
- FFUnitTestDecryptorProxy decryptor_proxy; |
- ASSERT_TRUE(decryptor_proxy.Setup(nss_path)); |
- |
- ASSERT_TRUE(decryptor_proxy.DecryptorInit(nss_path, db_path)); |
- EXPECT_EQ(ASCIIToUTF16("hello"), |
- decryptor_proxy.Decrypt("MDIEEPgAAAAAAAAAAAAAAAAAAAEwFAYIKoZIhvcNAwcECBJ" |
- "M63MpT9rtBAjMCm7qo/EhlA==")); |
- // Test UTF-16 encoding. |
- EXPECT_EQ(WideToUTF16(L"\x4E2D"), |
- decryptor_proxy.Decrypt("MDIEEPgAAAAAAAAAAAAAAAAAAAEwFAYIKoZIhvcNAwcECN9" |
- "OQ5ZFmhb8BAiFo1Z+fUvaIQ==")); |
-} |
- |
-TEST(FirefoxImporterTest, MAYBE_NSS(Firefox3NSS3Decryptor)) { |
- base::FilePath nss_path; |
- ASSERT_TRUE(PathService::Get(chrome::DIR_TEST_DATA, &nss_path)); |
-#if defined(OS_MACOSX) |
- nss_path = nss_path.AppendASCII("firefox3_nss_mac"); |
-#else |
- nss_path = nss_path.AppendASCII("firefox3_nss"); |
-#endif // !OS_MACOSX |
- base::FilePath db_path; |
- ASSERT_TRUE(PathService::Get(chrome::DIR_TEST_DATA, &db_path)); |
- db_path = db_path.AppendASCII("firefox3_profile"); |
- |
- FFUnitTestDecryptorProxy decryptor_proxy; |
- ASSERT_TRUE(decryptor_proxy.Setup(nss_path)); |
- |
- ASSERT_TRUE(decryptor_proxy.DecryptorInit(nss_path, db_path)); |
- EXPECT_EQ(ASCIIToUTF16("hello"), |
- decryptor_proxy.Decrypt("MDIEEPgAAAAAAAAAAAAAAAAAAAEwFAYIKoZIhvcNAwcECKa" |
- "jtRg4qFSHBAhv9luFkXgDJA==")); |
- // Test UTF-16 encoding. |
- EXPECT_EQ(WideToUTF16(L"\x4E2D"), |
- decryptor_proxy.Decrypt("MDIEEPgAAAAAAAAAAAAAAAAAAAEwFAYIKoZIhvcNAwcECLW" |
- "qqiccfQHWBAie74hxnULxlw==")); |
-} |
- |
-TEST(FirefoxImporterTest, Firefox2BookmarkParse) { |
- bool result; |
- |
- // Tests charset. |
- std::string charset; |
- result = Firefox2Importer::ParseCharsetFromLine( |
- "<META HTTP-EQUIV=\"Content-Type\" " |
- "CONTENT=\"text/html; charset=UTF-8\">", |
- &charset); |
- EXPECT_TRUE(result); |
- EXPECT_EQ("UTF-8", charset); |
- |
- // Escaped characters in name. |
- string16 folder_name; |
- bool is_toolbar_folder; |
- base::Time folder_add_date; |
- result = Firefox2Importer::ParseFolderNameFromLine( |
- "<DT><H3 ADD_DATE=\"1207558707\" >< >" |
- " & " ' \\ /</H3>", |
- charset, &folder_name, &is_toolbar_folder, &folder_add_date); |
- EXPECT_TRUE(result); |
- EXPECT_EQ(ASCIIToUTF16("< > & \" ' \\ /"), folder_name); |
- EXPECT_FALSE(is_toolbar_folder); |
- EXPECT_TRUE(base::Time::FromTimeT(1207558707) == folder_add_date); |
- |
- // Empty name and toolbar folder attribute. |
- result = Firefox2Importer::ParseFolderNameFromLine( |
- "<DT><H3 PERSONAL_TOOLBAR_FOLDER=\"true\"></H3>", |
- charset, &folder_name, &is_toolbar_folder, &folder_add_date); |
- EXPECT_TRUE(result); |
- EXPECT_EQ(string16(), folder_name); |
- EXPECT_TRUE(is_toolbar_folder); |
- |
- // Unicode characters in title and shortcut. |
- string16 title; |
- GURL url, favicon; |
- string16 shortcut; |
- string16 post_data; |
- base::Time add_date; |
- result = Firefox2Importer::ParseBookmarkFromLine( |
- "<DT><A HREF=\"http://chinese.site.cn/path?query=1#ref\" " |
- "SHORTCUTURL=\"\xE4\xB8\xAD\">\xE4\xB8\xAD\xE6\x96\x87</A>", |
- charset, &title, &url, &favicon, &shortcut, &add_date, &post_data); |
- EXPECT_TRUE(result); |
- EXPECT_EQ(L"\x4E2D\x6587", UTF16ToWide(title)); |
- EXPECT_EQ("http://chinese.site.cn/path?query=1#ref", url.spec()); |
- EXPECT_EQ(L"\x4E2D", UTF16ToWide(shortcut)); |
- EXPECT_EQ(string16(), post_data); |
- EXPECT_TRUE(base::Time() == add_date); |
- |
- // No shortcut, and url contains %22 ('"' character). |
- result = Firefox2Importer::ParseBookmarkFromLine( |
- "<DT><A HREF=\"http://domain.com/?q=%22<>%22\">name</A>", |
- charset, &title, &url, &favicon, &shortcut, &add_date, &post_data); |
- EXPECT_TRUE(result); |
- EXPECT_EQ(ASCIIToUTF16("name"), title); |
- EXPECT_EQ("http://domain.com/?q=%22%3C%3E%22", url.spec()); |
- EXPECT_EQ(string16(), shortcut); |
- EXPECT_EQ(string16(), post_data); |
- EXPECT_TRUE(base::Time() == add_date); |
- |
- result = Firefox2Importer::ParseBookmarkFromLine( |
- "<DT><A HREF=\"http://domain.com/?g="\"\">name</A>", |
- charset, &title, &url, &favicon, &shortcut, &add_date, &post_data); |
- EXPECT_TRUE(result); |
- EXPECT_EQ(ASCIIToUTF16("name"), title); |
- EXPECT_EQ("http://domain.com/?g=%22", url.spec()); |
- EXPECT_EQ(string16(), shortcut); |
- EXPECT_EQ(string16(), post_data); |
- EXPECT_TRUE(base::Time() == add_date); |
- |
- // Creation date. |
- result = Firefox2Importer::ParseBookmarkFromLine( |
- "<DT><A HREF=\"http://site/\" ADD_DATE=\"1121301154\">name</A>", |
- charset, &title, &url, &favicon, &shortcut, &add_date, &post_data); |
- EXPECT_TRUE(result); |
- EXPECT_EQ(ASCIIToUTF16("name"), title); |
- EXPECT_EQ(GURL("http://site/"), url); |
- EXPECT_EQ(string16(), shortcut); |
- EXPECT_EQ(string16(), post_data); |
- EXPECT_TRUE(base::Time::FromTimeT(1121301154) == add_date); |
- |
- // Post-data |
- result = Firefox2Importer::ParseBookmarkFromLine( |
- "<DT><A HREF=\"http://localhost:8080/test/hello.html\" ADD_DATE=\"" |
- "1212447159\" LAST_VISIT=\"1212447251\" LAST_MODIFIED=\"1212447248\"" |
- "SHORTCUTURL=\"post\" ICON=\"data:\" POST_DATA=\"lname%3D%25s\"" |
- "LAST_CHARSET=\"UTF-8\" ID=\"rdf:#$weKaR3\">Test Post keyword</A>", |
- charset, &title, &url, &favicon, &shortcut, &add_date, &post_data); |
- EXPECT_TRUE(result); |
- EXPECT_EQ(ASCIIToUTF16("Test Post keyword"), title); |
- EXPECT_EQ("http://localhost:8080/test/hello.html", url.spec()); |
- EXPECT_EQ(ASCIIToUTF16("post"), shortcut); |
- EXPECT_EQ(ASCIIToUTF16("lname%3D%25s"), post_data); |
- EXPECT_TRUE(base::Time::FromTimeT(1212447159) == add_date); |
- |
- // Invalid case. |
- result = Firefox2Importer::ParseBookmarkFromLine( |
- "<DT><A HREF=\"http://domain.com/?q=%22", |
- charset, &title, &url, &favicon, &shortcut, &add_date, &post_data); |
- EXPECT_FALSE(result); |
- EXPECT_EQ(string16(), title); |
- EXPECT_EQ("", url.spec()); |
- EXPECT_EQ(string16(), shortcut); |
- EXPECT_EQ(string16(), post_data); |
- EXPECT_TRUE(base::Time() == add_date); |
- |
- // Epiphany format. |
- result = Firefox2Importer::ParseMinimumBookmarkFromLine( |
- "<dt><a href=\"http://www.google.com/\">Google</a></dt>", |
- charset, &title, &url); |
- EXPECT_TRUE(result); |
- EXPECT_EQ(ASCIIToUTF16("Google"), title); |
- EXPECT_EQ("http://www.google.com/", url.spec()); |
-} |
- |
-TEST(FirefoxImporterTest, Firefox2BookmarkFileImport) { |
- base::FilePath path; |
- ASSERT_TRUE(PathService::Get(chrome::DIR_TEST_DATA, &path)); |
- path = path.AppendASCII("firefox2_importer"); |
- |
- // Import all bookmarks from a file which include an empty folder entry. |
- base::FilePath empty_folder_path = path.AppendASCII("empty_folder.html"); |
- std::set<GURL> default_urls; |
- Firefox2Importer* importer = new Firefox2Importer(); |
- importer->AddRef(); |
- std::vector<ProfileWriter::BookmarkEntry> bookmarks; |
- importer->ImportBookmarksFile(empty_folder_path, default_urls, |
- importer, &bookmarks, NULL, NULL); |
- EXPECT_EQ(3U, bookmarks.size()); |
- std::vector<ProfileWriter::BookmarkEntry>::iterator it; |
- ProfileWriter::BookmarkEntry entry; |
- std::vector<string16>::iterator path_it; |
- if (bookmarks.size() == 3) { |
- it = bookmarks.begin(); |
- entry = *it++; |
- EXPECT_EQ(ASCIIToUTF16("Empty"), entry.title); |
- EXPECT_TRUE(entry.is_folder); |
- EXPECT_EQ(base::Time::FromTimeT(1295938143), entry.creation_time); |
- EXPECT_EQ(1U, entry.path.size()); |
- if (entry.path.size() == 1) |
- EXPECT_EQ(ASCIIToUTF16("Empty's Parent"), entry.path.front()); |
- |
- entry = *it++; |
- EXPECT_EQ(ASCIIToUTF16("[Tamura Yukari.com]"), entry.title); |
- EXPECT_FALSE(entry.is_folder); |
- EXPECT_EQ(base::Time::FromTimeT(1234567890), entry.creation_time); |
- EXPECT_EQ(1U, entry.path.size()); |
- if (entry.path.size() == 1) |
- EXPECT_EQ(ASCIIToUTF16("Not Empty"), entry.path.front()); |
- EXPECT_EQ("http://www.tamurayukari.com/", entry.url.spec()); |
- |
- entry = *it++; |
- EXPECT_EQ(ASCIIToUTF16("Google"), entry.title); |
- EXPECT_FALSE(entry.is_folder); |
- EXPECT_EQ(base::Time::FromTimeT(0000000000), entry.creation_time); |
- EXPECT_EQ(1U, entry.path.size()); |
- if (entry.path.size() == 1) |
- EXPECT_EQ(ASCIIToUTF16("Not Empty But Default"), entry.path.front()); |
- EXPECT_EQ("http://www.google.com/", entry.url.spec()); |
- } |
- |
- // Import non-default bookmarks from a file. |
- bookmarks.clear(); |
- default_urls.insert(GURL("http://www.google.com/")); |
- importer->ImportBookmarksFile(empty_folder_path, default_urls, |
- importer, &bookmarks, NULL, NULL); |
- EXPECT_EQ(2U, bookmarks.size()); |
- if (bookmarks.size() == 2) { |
- it = bookmarks.begin(); |
- entry = *it++; |
- EXPECT_EQ(ASCIIToUTF16("Empty"), entry.title); |
- EXPECT_TRUE(entry.is_folder); |
- EXPECT_EQ(base::Time::FromTimeT(1295938143), entry.creation_time); |
- EXPECT_EQ(1U, entry.path.size()); |
- if (entry.path.size() == 1) |
- EXPECT_EQ(ASCIIToUTF16("Empty's Parent"), entry.path.front()); |
- |
- entry = *it++; |
- EXPECT_EQ(ASCIIToUTF16("[Tamura Yukari.com]"), entry.title); |
- EXPECT_FALSE(entry.is_folder); |
- EXPECT_EQ(base::Time::FromTimeT(1234567890), entry.creation_time); |
- EXPECT_EQ(1U, entry.path.size()); |
- if (entry.path.size() == 1) |
- EXPECT_EQ(ASCIIToUTF16("Not Empty"), entry.path.front()); |
- EXPECT_EQ("http://www.tamurayukari.com/", entry.url.spec()); |
- } |
- |
- // Import Epiphany bookmarks from a file |
- base::FilePath epiphany_path = path.AppendASCII("epiphany.html"); |
- bookmarks.clear(); |
- default_urls.clear(); |
- importer->ImportBookmarksFile(epiphany_path, default_urls, |
- importer, &bookmarks, NULL, NULL); |
- EXPECT_EQ(2U, bookmarks.size()); |
- if (bookmarks.size() == 2) { |
- it = bookmarks.begin(); |
- entry = *it++; |
- EXPECT_EQ(ASCIIToUTF16("[Tamura Yukari.com]"), entry.title); |
- EXPECT_EQ("http://www.tamurayukari.com/", entry.url.spec()); |
- EXPECT_EQ(0U, entry.path.size()); |
- entry = *it++; |
- EXPECT_EQ(ASCIIToUTF16("Google"), entry.title); |
- EXPECT_EQ("http://www.google.com/", entry.url.spec()); |
- EXPECT_EQ(0U, entry.path.size()); |
- } |
- |
- // Import Epiphany bookmarks from a file to bookmark bar. |
- bookmarks.clear(); |
- default_urls.clear(); |
- importer->ImportBookmarksFile(epiphany_path, default_urls, |
- importer, &bookmarks, NULL, NULL); |
- EXPECT_EQ(2U, bookmarks.size()); |
- if (bookmarks.size() == 2) { |
- it = bookmarks.begin(); |
- entry = *it++; |
- EXPECT_EQ(ASCIIToUTF16("[Tamura Yukari.com]"), entry.title); |
- EXPECT_EQ("http://www.tamurayukari.com/", entry.url.spec()); |
- EXPECT_EQ(0U, entry.path.size()); |
- entry = *it++; |
- EXPECT_EQ(ASCIIToUTF16("Google"), entry.title); |
- EXPECT_EQ("http://www.google.com/", entry.url.spec()); |
- EXPECT_EQ(0U, entry.path.size()); |
- } |
- |
- importer->Release(); |
-} |
+// Copyright (c) 2013 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/file_util.h" |
+#include "base/files/file_path.h" |
+#include "base/files/scoped_temp_dir.h" |
+#include "base/message_loop.h" |
+#include "base/path_service.h" |
+#include "base/stl_util.h" |
+#include "base/string16.h" |
+#include "base/string_util.h" |
+#include "base/utf_string_conversions.h" |
+#include "chrome/browser/history/history_types.h" |
+#include "chrome/browser/importer/external_process_importer_host.h" |
+#include "chrome/browser/importer/firefox_importer_unittest_utils.h" |
+#include "chrome/browser/importer/importer_data_types.h" |
+#include "chrome/browser/importer/importer_host.h" |
+#include "chrome/browser/importer/importer_progress_observer.h" |
+#include "chrome/browser/importer/importer_unittest_utils.h" |
+#include "chrome/browser/search_engines/template_url.h" |
+#include "chrome/browser/ui/browser.h" |
+#include "chrome/common/chrome_paths.h" |
+#include "chrome/test/base/in_process_browser_test.h" |
+#include "content/public/common/password_form.h" |
+#include "testing/gtest/include/gtest/gtest.h" |
+ |
+// TODO(estade): some of these are disabled on mac. http://crbug.com/48007 |
+// TODO(jschuh): Disabled on Win64 build. http://crbug.com/179688 |
+#if defined(OS_MACOSX) || (defined(OS_WIN) && defined(ARCH_CPU_X86_64)) |
+#define MAYBE_IMPORTER(x) DISABLED_##x |
+#else |
+#define MAYBE_IMPORTER(x) x |
+#endif |
+ |
+namespace { |
+ |
+const BookmarkInfo kFirefox2Bookmarks[] = { |
+ {true, 2, {L"Bookmarks Toolbar Folder", L"Folder"}, |
+ L"On Toolbar's Subfolder", |
+ "http://on.toolbar/bookmark/folder"}, |
+ {true, 1, {L"Bookmarks Toolbar Folder"}, |
+ L"On Bookmark Toolbar", |
+ "http://on.toolbar/bookmark"}, |
+ {false, 1, {L"Folder"}, |
+ L"New Bookmark", |
+ "http://domain/"}, |
+ {false, 0, {}, |
+ L"<Name>", |
+ "http://domain.com/q?a=%22er%22&b=%3C%20%20%3E"}, |
+ {false, 0, {}, |
+ L"Google Home Page", |
+ "http://www.google.com/"}, |
+ {false, 0, {}, |
+ L"\x4E2D\x6587", |
+ "http://chinese.site.cn/path?query=1#ref"}, |
+ {false, 1, {L"< > & \" ' \\ /"}, |
gab
2013/04/18 18:09:44
Was missing from the list of actually imported tes
Miranda Callahan
2013/04/18 18:25:19
Nice catch!
On 2013/04/18 18:09:44, gab wrote:
|
+ L"< > & \" ' \\ /", |
+ "http://g.cn/"}, |
+ {false, 0, {}, |
+ L"mail", |
+ "mailto:username@host"}, |
+}; |
+ |
+struct PasswordInfo { |
+ const char* origin; |
+ const char* action; |
+ const char* realm; |
+ const wchar_t* username_element; |
+ const wchar_t* username; |
+ const wchar_t* password_element; |
+ const wchar_t* password; |
+ bool blacklisted; |
+}; |
+ |
+const PasswordInfo kFirefox2Passwords[] = { |
+ {"https://www.google.com/", "", "https://www.google.com/", |
+ L"", L"", L"", L"", true}, |
+ {"http://localhost:8080/", "", "http://localhost:8080/corp.google.com", |
+ L"", L"http", L"", L"Http1+1abcdefg", false}, |
+ {"http://localhost:8080/", "http://localhost:8080/", "http://localhost:8080/", |
+ L"loginuser", L"usr", L"loginpass", L"pwd", false}, |
+ {"http://localhost:8080/", "http://localhost:8080/", "http://localhost:8080/", |
+ L"loginuser", L"firefox", L"loginpass", L"firefox", false}, |
+ {"http://localhost/", "", "http://localhost/", |
+ L"loginuser", L"hello", L"", L"world", false}, |
+}; |
+ |
+struct KeywordInfo { |
+ const wchar_t* keyword; |
+ const char* url; |
+}; |
+ |
+const KeywordInfo kFirefox2Keywords[] = { |
+ // Searh plugins |
+ { L"amazon.com", |
+ "http://www.amazon.com/exec/obidos/external-search/?field-keywords=" |
+ "{searchTerms}&mode=blended" }, |
+ { L"answers.com", |
+ "http://www.answers.com/main/ntquery?s={searchTerms}&gwp=13" }, |
+ { L"search.creativecommons.org", |
+ "http://search.creativecommons.org/?q={searchTerms}" }, |
+ { L"search.ebay.com", |
+ "http://search.ebay.com/search/search.dll?query={searchTerms}&" |
+ "MfcISAPICommand=GetResult&ht=1&ebaytag1=ebayreg&srchdesc=n&" |
+ "maxRecordsReturned=300&maxRecordsPerPage=50&SortProperty=MetaEndSort" }, |
+ { L"google.com", |
+ "http://www.google.com/search?q={searchTerms}&ie=utf-8&oe=utf-8&aq=t" }, |
+ { L"search.yahoo.com", |
+ "http://search.yahoo.com/search?p={searchTerms}&ei=UTF-8" }, |
+ { L"flickr.com", |
+ "http://www.flickr.com/photos/tags/?q={searchTerms}" }, |
+ { L"imdb.com", |
+ "http://www.imdb.com/find?q={searchTerms}" }, |
+ { L"webster.com", |
+ "http://www.webster.com/cgi-bin/dictionary?va={searchTerms}" }, |
+ // Search keywords. |
+ { L"google", "http://www.google.com/" }, |
+ { L"< > & \" ' \\ /", "http://g.cn/"}, |
+}; |
+ |
+const int kDefaultFirefox2KeywordIndex = 8; |
+ |
+class FirefoxObserver : public ProfileWriter, |
+ public importer::ImporterProgressObserver { |
+ public: |
+ FirefoxObserver() : ProfileWriter(NULL) { |
+ bookmark_count_ = 0; |
+ history_count_ = 0; |
+ password_count_ = 0; |
+ keyword_count_ = 0; |
+ } |
+ |
+ // importer::ImporterProgressObserver: |
+ virtual void ImportStarted() OVERRIDE {} |
+ virtual void ImportItemStarted(importer::ImportItem item) OVERRIDE {} |
+ virtual void ImportItemEnded(importer::ImportItem item) OVERRIDE {} |
+ virtual void ImportEnded() OVERRIDE { |
+ MessageLoop::current()->Quit(); |
+ EXPECT_EQ(arraysize(kFirefox2Bookmarks), bookmark_count_); |
+ EXPECT_EQ(1U, history_count_); |
+ EXPECT_EQ(arraysize(kFirefox2Passwords), password_count_); |
+ EXPECT_EQ(arraysize(kFirefox2Keywords), keyword_count_); |
+ } |
+ |
+ virtual bool BookmarkModelIsLoaded() const OVERRIDE { |
+ // Profile is ready for writing. |
+ return true; |
+ } |
+ |
+ virtual bool TemplateURLServiceIsLoaded() const OVERRIDE { |
+ return true; |
+ } |
+ |
+ virtual void AddPasswordForm(const content::PasswordForm& form) OVERRIDE { |
+ PasswordInfo p = kFirefox2Passwords[password_count_]; |
+ EXPECT_EQ(p.origin, form.origin.spec()); |
+ EXPECT_EQ(p.realm, form.signon_realm); |
+ EXPECT_EQ(p.action, form.action.spec()); |
+ EXPECT_EQ(WideToUTF16(p.username_element), form.username_element); |
+ EXPECT_EQ(WideToUTF16(p.username), form.username_value); |
+ EXPECT_EQ(WideToUTF16(p.password_element), form.password_element); |
+ EXPECT_EQ(WideToUTF16(p.password), form.password_value); |
+ EXPECT_EQ(p.blacklisted, form.blacklisted_by_user); |
+ ++password_count_; |
+ } |
+ |
+ virtual void AddHistoryPage(const history::URLRows& page, |
+ history::VisitSource visit_source) OVERRIDE { |
+ ASSERT_EQ(1U, page.size()); |
+ EXPECT_EQ("http://en-us.www.mozilla.com/", page[0].url().spec()); |
+ EXPECT_EQ(ASCIIToUTF16("Firefox Updated"), page[0].title()); |
+ EXPECT_EQ(history::SOURCE_FIREFOX_IMPORTED, visit_source); |
+ ++history_count_; |
+ } |
+ |
+ virtual void AddBookmarks(const std::vector<BookmarkEntry>& bookmarks, |
+ const string16& top_level_folder_name) OVERRIDE { |
+ ASSERT_LE(bookmark_count_ + bookmarks.size(), |
+ arraysize(kFirefox2Bookmarks)); |
+ // Importer should import the FF favorites the same as the list, in the same |
+ // order. |
+ for (size_t i = 0; i < bookmarks.size(); ++i) { |
+ EXPECT_NO_FATAL_FAILURE( |
+ TestEqualBookmarkEntry(bookmarks[i], |
+ kFirefox2Bookmarks[bookmark_count_])) << i; |
+ ++bookmark_count_; |
+ } |
+ } |
+ |
+ virtual void AddKeywords(ScopedVector<TemplateURL> template_urls, |
+ bool unique_on_host_and_path) OVERRIDE { |
+ for (size_t i = 0; i < template_urls.size(); ++i) { |
+ // The order might not be deterministic, look in the expected list for |
+ // that template URL. |
+ bool found = false; |
+ string16 keyword = template_urls[i]->keyword(); |
+ for (size_t j = 0; j < arraysize(kFirefox2Keywords); ++j) { |
+ if (template_urls[i]->keyword() == |
+ WideToUTF16Hack(kFirefox2Keywords[j].keyword)) { |
+ EXPECT_EQ(kFirefox2Keywords[j].url, template_urls[i]->url()); |
+ found = true; |
+ break; |
+ } |
+ } |
+ EXPECT_TRUE(found); |
+ ++keyword_count_; |
+ } |
+ } |
+ |
+ virtual void AddFavicons( |
+ const std::vector<history::ImportedFaviconUsage>& favicons) OVERRIDE { |
+ } |
+ |
+ private: |
+ virtual ~FirefoxObserver() {} |
+ |
+ size_t bookmark_count_; |
+ size_t history_count_; |
+ size_t password_count_; |
+ size_t keyword_count_; |
+}; |
+ |
+const BookmarkInfo kFirefox3Bookmarks[] = { |
+ {true, 1, {L"Bookmarks Toolbar"}, |
+ L"Toolbar", |
+ "http://site/"}, |
+ {false, 0, {}, |
+ L"Title", |
+ "http://www.google.com/"}, |
+}; |
+ |
+const PasswordInfo kFirefox3Passwords[] = { |
+ {"http://localhost:8080/", "http://localhost:8080/", "http://localhost:8080/", |
+ L"loginuser", L"abc", L"loginpass", L"123", false}, |
+ {"http://localhost:8080/", "", "http://localhost:8080/localhost", |
+ L"", L"http", L"", L"Http1+1abcdefg", false}, |
+}; |
+ |
+const KeywordInfo kFirefox3Keywords[] = { |
+ { L"amazon.com", |
+ "http://www.amazon.com/exec/obidos/external-search/?field-keywords=" |
+ "{searchTerms}&mode=blended" }, |
+ { L"answers.com", |
+ "http://www.answers.com/main/ntquery?s={searchTerms}&gwp=13" }, |
+ { L"search.creativecommons.org", |
+ "http://search.creativecommons.org/?q={searchTerms}" }, |
+ { L"search.ebay.com", |
+ "http://search.ebay.com/search/search.dll?query={searchTerms}&" |
+ "MfcISAPICommand=GetResult&ht=1&ebaytag1=ebayreg&srchdesc=n&" |
+ "maxRecordsReturned=300&maxRecordsPerPage=50&SortProperty=MetaEndSort" }, |
+ { L"google.com", |
+ "http://www.google.com/search?q={searchTerms}&ie=utf-8&oe=utf-8&aq=t" }, |
+ { L"en.wikipedia.org", |
+ "http://en.wikipedia.org/wiki/Special:Search?search={searchTerms}" }, |
+ { L"search.yahoo.com", |
+ "http://search.yahoo.com/search?p={searchTerms}&ei=UTF-8" }, |
+ { L"flickr.com", |
+ "http://www.flickr.com/photos/tags/?q={searchTerms}" }, |
+ { L"imdb.com", |
+ "http://www.imdb.com/find?q={searchTerms}" }, |
+ { L"webster.com", |
+ "http://www.webster.com/cgi-bin/dictionary?va={searchTerms}" }, |
+ // Search keywords. |
+ { L"\x4E2D\x6587", "http://www.google.com/" }, |
+}; |
+ |
+const int kDefaultFirefox3KeywordIndex = 8; |
+ |
+class Firefox3Observer : public ProfileWriter, |
+ public importer::ImporterProgressObserver { |
+ public: |
+ Firefox3Observer() |
+ : ProfileWriter(NULL), bookmark_count_(0), history_count_(0), |
+ password_count_(0), keyword_count_(0), import_search_engines_(true) { |
+ } |
+ |
+ explicit Firefox3Observer(bool import_search_engines) |
+ : ProfileWriter(NULL), bookmark_count_(0), history_count_(0), |
+ password_count_(0), keyword_count_(0), |
+ import_search_engines_(import_search_engines) { |
+ } |
+ |
+ // importer::ImporterProgressObserver: |
+ virtual void ImportStarted() OVERRIDE {} |
+ virtual void ImportItemStarted(importer::ImportItem item) OVERRIDE {} |
+ virtual void ImportItemEnded(importer::ImportItem item) OVERRIDE {} |
+ virtual void ImportEnded() OVERRIDE { |
+ MessageLoop::current()->Quit(); |
+ EXPECT_EQ(arraysize(kFirefox3Bookmarks), bookmark_count_); |
+ EXPECT_EQ(1U, history_count_); |
+ EXPECT_EQ(arraysize(kFirefox3Passwords), password_count_); |
+ if (import_search_engines_) |
+ EXPECT_EQ(arraysize(kFirefox3Keywords), keyword_count_); |
+ } |
+ |
+ virtual bool BookmarkModelIsLoaded() const OVERRIDE { |
+ // Profile is ready for writing. |
+ return true; |
+ } |
+ |
+ virtual bool TemplateURLServiceIsLoaded() const OVERRIDE { |
+ return true; |
+ } |
+ |
+ virtual void AddPasswordForm(const content::PasswordForm& form) OVERRIDE { |
+ PasswordInfo p = kFirefox3Passwords[password_count_]; |
+ EXPECT_EQ(p.origin, form.origin.spec()); |
+ EXPECT_EQ(p.realm, form.signon_realm); |
+ EXPECT_EQ(p.action, form.action.spec()); |
+ EXPECT_EQ(WideToUTF16(p.username_element), form.username_element); |
+ EXPECT_EQ(WideToUTF16(p.username), form.username_value); |
+ EXPECT_EQ(WideToUTF16(p.password_element), form.password_element); |
+ EXPECT_EQ(WideToUTF16(p.password), form.password_value); |
+ EXPECT_EQ(p.blacklisted, form.blacklisted_by_user); |
+ ++password_count_; |
+ } |
+ |
+ virtual void AddHistoryPage(const history::URLRows& page, |
+ history::VisitSource visit_source) OVERRIDE { |
+ ASSERT_EQ(3U, page.size()); |
+ EXPECT_EQ("http://www.google.com/", page[0].url().spec()); |
+ EXPECT_EQ(ASCIIToUTF16("Google"), page[0].title()); |
+ EXPECT_EQ("http://www.google.com/", page[1].url().spec()); |
+ EXPECT_EQ(ASCIIToUTF16("Google"), page[1].title()); |
+ EXPECT_EQ("http://www.cs.unc.edu/~jbs/resources/perl/perl-cgi/programs/" |
+ "form1-POST.html", page[2].url().spec()); |
+ EXPECT_EQ(ASCIIToUTF16("example form (POST)"), page[2].title()); |
+ EXPECT_EQ(history::SOURCE_FIREFOX_IMPORTED, visit_source); |
+ ++history_count_; |
+ } |
+ |
+ virtual void AddBookmarks(const std::vector<BookmarkEntry>& bookmarks, |
+ const string16& top_level_folder_name) OVERRIDE { |
+ |
+ ASSERT_LE(bookmark_count_ + bookmarks.size(), |
+ arraysize(kFirefox3Bookmarks)); |
+ // Importer should import the FF favorites the same as the list, in the same |
+ // order. |
+ for (size_t i = 0; i < bookmarks.size(); ++i) { |
+ EXPECT_NO_FATAL_FAILURE( |
+ TestEqualBookmarkEntry(bookmarks[i], |
+ kFirefox3Bookmarks[bookmark_count_])) << i; |
+ ++bookmark_count_; |
+ } |
+ } |
+ |
+ virtual void AddKeywords(ScopedVector<TemplateURL> template_urls, |
+ bool unique_on_host_and_path) OVERRIDE { |
+ for (size_t i = 0; i < template_urls.size(); ++i) { |
+ // The order might not be deterministic, look in the expected list for |
+ // that template URL. |
+ bool found = false; |
+ string16 keyword = template_urls[i]->keyword(); |
+ for (size_t j = 0; j < arraysize(kFirefox3Keywords); ++j) { |
+ if (template_urls[i]->keyword() == |
+ WideToUTF16Hack(kFirefox3Keywords[j].keyword)) { |
+ EXPECT_EQ(kFirefox3Keywords[j].url, template_urls[i]->url()); |
+ found = true; |
+ break; |
+ } |
+ } |
+ EXPECT_TRUE(found); |
+ ++keyword_count_; |
+ } |
+ } |
+ |
+ virtual void AddFavicons( |
+ const std::vector<history::ImportedFaviconUsage>& favicons) OVERRIDE { |
+ } |
+ |
+ private: |
+ virtual ~Firefox3Observer() {} |
+ |
+ size_t bookmark_count_; |
+ size_t history_count_; |
+ size_t password_count_; |
+ size_t keyword_count_; |
+ bool import_search_engines_; |
+}; |
+ |
+} // namespace |
+ |
+// These tests need to be browser tests in order to be able to run the OOP |
+// import (via ExternalProcessImporterHost) which launches a utility process on |
+// supported platforms. |
+class FirefoxProfileImporterBrowserTest : public InProcessBrowserTest { |
+ protected: |
+ virtual void SetUp() OVERRIDE { |
+ // Creates a new profile in a new subdirectory in the temp directory. |
+ ASSERT_TRUE(temp_dir_.CreateUniqueTempDir()); |
+ base::FilePath test_path = temp_dir_.path().AppendASCII("ImporterTest"); |
+ file_util::Delete(test_path, true); |
+ file_util::CreateDirectory(test_path); |
+ profile_path_ = test_path.AppendASCII("profile"); |
+ app_path_ = test_path.AppendASCII("app"); |
+ file_util::CreateDirectory(app_path_); |
+ |
+ // This will launch the browser test and thus needs to happen last. |
+ InProcessBrowserTest::SetUp(); |
+ } |
+ |
+ void Firefox3xImporterBrowserTest( |
+ std::string profile_dir, |
+ importer::ImporterProgressObserver* observer, |
+ ProfileWriter* writer, |
+ bool import_search_plugins) { |
+ base::FilePath data_path; |
+ ASSERT_TRUE(PathService::Get(chrome::DIR_TEST_DATA, &data_path)); |
+ data_path = data_path.AppendASCII(profile_dir); |
+ ASSERT_TRUE(file_util::CopyDirectory(data_path, profile_path_, true)); |
+ ASSERT_TRUE(PathService::Get(chrome::DIR_TEST_DATA, &data_path)); |
+ data_path = data_path.AppendASCII("firefox3_nss"); |
+ ASSERT_TRUE(file_util::CopyDirectory(data_path, profile_path_, false)); |
+ |
+ base::FilePath search_engine_path = app_path_; |
+ search_engine_path = search_engine_path.AppendASCII("searchplugins"); |
+ file_util::CreateDirectory(search_engine_path); |
+ if (import_search_plugins) { |
+ ASSERT_TRUE(PathService::Get(chrome::DIR_TEST_DATA, &data_path)); |
+ data_path = data_path.AppendASCII("firefox3_searchplugins"); |
+ if (!file_util::PathExists(data_path)) { |
+ // TODO(maruel): Create search test data that we can open source! |
+ LOG(ERROR) << L"Missing internal test data"; |
+ return; |
+ } |
+ ASSERT_TRUE(file_util::CopyDirectory(data_path, |
+ search_engine_path, false)); |
+ } |
+ |
+ importer::SourceProfile source_profile; |
+ source_profile.importer_type = importer::TYPE_FIREFOX3; |
+ source_profile.app_path = app_path_; |
+ source_profile.source_path = profile_path_; |
+ |
+ int items = importer::HISTORY | importer::PASSWORDS | importer::FAVORITES; |
+ if (import_search_plugins) |
+ items = items | importer::SEARCH_ENGINES; |
+ |
+ // TODO(gab): Use ExternalProcessImporterHost on both Windows and Linux. |
+ scoped_refptr<ImporterHost> host; |
+#if defined(OS_MACOSX) |
+ host = new ExternalProcessImporterHost; |
+#else |
+ host = new ImporterHost; |
+#endif |
+ host->SetObserver(observer); |
+ host->StartImportSettings(source_profile, browser()->profile(), |
+ items, make_scoped_refptr(writer)); |
+ MessageLoop::current()->Run(); |
+ } |
+ |
+ base::ScopedTempDir temp_dir_; |
+ base::FilePath profile_path_; |
+ base::FilePath app_path_; |
+}; |
+ |
+IN_PROC_BROWSER_TEST_F(FirefoxProfileImporterBrowserTest, |
+ MAYBE_IMPORTER(Firefox2Importer)) { |
+ base::FilePath data_path; |
+ ASSERT_TRUE(PathService::Get(chrome::DIR_TEST_DATA, &data_path)); |
+ data_path = data_path.AppendASCII("firefox2_profile"); |
+ ASSERT_TRUE(file_util::CopyDirectory(data_path, profile_path_, true)); |
+ ASSERT_TRUE(PathService::Get(chrome::DIR_TEST_DATA, &data_path)); |
+ data_path = data_path.AppendASCII("firefox2_nss"); |
+ ASSERT_TRUE(file_util::CopyDirectory(data_path, profile_path_, false)); |
+ |
+ base::FilePath search_engine_path = app_path_; |
+ search_engine_path = search_engine_path.AppendASCII("searchplugins"); |
+ file_util::CreateDirectory(search_engine_path); |
+ ASSERT_TRUE(PathService::Get(chrome::DIR_TEST_DATA, &data_path)); |
+ data_path = data_path.AppendASCII("firefox2_searchplugins"); |
+ if (!file_util::PathExists(data_path)) { |
+ // TODO(maruel): Create test data that we can open source! |
+ LOG(ERROR) << L"Missing internal test data"; |
+ return; |
+ } |
+ ASSERT_TRUE(file_util::CopyDirectory(data_path, search_engine_path, false)); |
+ |
+ importer::SourceProfile source_profile; |
+ source_profile.importer_type = importer::TYPE_FIREFOX2; |
+ source_profile.app_path = app_path_; |
+ source_profile.source_path = profile_path_; |
+ |
+ // TODO(gab): Use ExternalProcessImporterHost on both Windows and Linux. |
+ scoped_refptr<ImporterHost> host; |
+#if defined(OS_MACOSX) |
+ host = new ExternalProcessImporterHost; |
+#else |
+ host = new ImporterHost; |
+#endif |
+ FirefoxObserver* observer = new FirefoxObserver(); |
+ host->SetObserver(observer); |
+ host->StartImportSettings( |
+ source_profile, |
+ browser()->profile(), |
+ importer::HISTORY | importer::PASSWORDS | |
+ importer::FAVORITES | importer::SEARCH_ENGINES, |
+ make_scoped_refptr(observer)); |
+ MessageLoop::current()->Run(); |
+} |
+ |
+IN_PROC_BROWSER_TEST_F(FirefoxProfileImporterBrowserTest, |
+ MAYBE_IMPORTER(Firefox30Importer)) { |
+ scoped_refptr<Firefox3Observer> observer(new Firefox3Observer()); |
+ Firefox3xImporterBrowserTest("firefox3_profile", observer.get(), |
+ observer.get(), true); |
+} |
+ |
+IN_PROC_BROWSER_TEST_F(FirefoxProfileImporterBrowserTest, |
+ MAYBE_IMPORTER(Firefox35Importer)) { |
+ bool import_search_engines = false; |
+ scoped_refptr<Firefox3Observer> observer( |
+ new Firefox3Observer(import_search_engines)); |
+ Firefox3xImporterBrowserTest("firefox35_profile", observer.get(), |
+ observer.get(), import_search_engines); |
+} |