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

Unified Diff: chrome/utility/importer/firefox_importer_unittest.cc

Issue 2296633002: Fix Firefox bookmarks import. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: build fix Created 4 years 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 | « chrome/utility/importer/firefox_importer.cc ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/utility/importer/firefox_importer_unittest.cc
diff --git a/chrome/utility/importer/firefox_importer_unittest.cc b/chrome/utility/importer/firefox_importer_unittest.cc
index a7e0a40d33c9b9d1ad18626307a9042032bfcc04..1c2c0e2918321b497442ed482c4a87f106598da0 100644
--- a/chrome/utility/importer/firefox_importer_unittest.cc
+++ b/chrome/utility/importer/firefox_importer_unittest.cc
@@ -8,8 +8,14 @@
#include "base/strings/utf_string_conversions.h"
#include "build/build_config.h"
#include "chrome/common/chrome_paths.h"
+#include "chrome/common/importer/imported_bookmark_entry.h"
+#include "chrome/common/importer/importer_data_types.h"
+#include "chrome/common/importer/importer_url_row.h"
+#include "chrome/common/importer/mock_importer_bridge.h"
+#include "chrome/utility/importer/firefox_importer.h"
#include "chrome/utility/importer/firefox_importer_unittest_utils.h"
#include "chrome/utility/importer/nss_decryptor.h"
+#include "components/favicon_base/favicon_usage_data.h"
#include "sql/connection.h"
#include "testing/gtest/include/gtest/gtest.h"
@@ -39,11 +45,13 @@ TEST(FirefoxImporterTest, MAYBE_NSS(Firefox3NSS3Decryptor)) {
ASSERT_TRUE(decryptor_proxy.Setup(nss_path));
ASSERT_TRUE(decryptor_proxy.DecryptorInit(nss_path, db_path));
- EXPECT_EQ(base::ASCIIToUTF16("hello"),
+ EXPECT_EQ(
+ base::ASCIIToUTF16("hello"),
decryptor_proxy.Decrypt("MDIEEPgAAAAAAAAAAAAAAAAAAAEwFAYIKoZIhvcNAwcECKa"
"jtRg4qFSHBAhv9luFkXgDJA=="));
// Test UTF-16 encoding.
- EXPECT_EQ(base::WideToUTF16(L"\x4E2D"),
+ EXPECT_EQ(
+ base::WideToUTF16(L"\x4E2D"),
decryptor_proxy.Decrypt("MDIEEPgAAAAAAAAAAAAAAAAAAAEwFAYIKoZIhvcNAwcECLW"
"qqiccfQHWBAie74hxnULxlw=="));
@@ -115,3 +123,76 @@ TEST(FirefoxImporterTest, MAYBE_NSS(FirefoxNSSDecryptorDeduceAuthScheme)) {
EXPECT_EQ(autofill::PasswordForm::SCHEME_BASIC, forms[0].scheme);
EXPECT_EQ(autofill::PasswordForm::SCHEME_HTML, forms[1].scheme);
}
+
+TEST(FirefoxImporterTest, ImportBookmarks) {
+ using ::testing::_;
+ base::FilePath places_path;
+ ASSERT_TRUE(PathService::Get(chrome::DIR_TEST_DATA, &places_path));
+ places_path =
+ places_path.AppendASCII("import").AppendASCII("firefox").AppendASCII(
+ "48.0.2");
+ scoped_refptr<FirefoxImporter> importer = new FirefoxImporter;
+ importer::SourceProfile profile;
+ profile.source_path = places_path;
+ scoped_refptr<MockImporterBridge> bridge = new MockImporterBridge;
+ std::vector<ImportedBookmarkEntry> bookmarks;
+ favicon_base::FaviconUsageDataList favicons;
+ EXPECT_CALL(*bridge, NotifyStarted());
+ EXPECT_CALL(*bridge, NotifyItemStarted(importer::FAVORITES));
+ EXPECT_CALL(*bridge, AddBookmarks(_, _))
+ .WillOnce(::testing::SaveArg<0>(&bookmarks));
+ EXPECT_CALL(*bridge, SetFavicons(_))
+ .WillOnce(::testing::SaveArg<0>(&favicons));
+ EXPECT_CALL(*bridge, NotifyItemEnded(importer::FAVORITES));
+ EXPECT_CALL(*bridge, NotifyEnded());
+ importer->StartImport(profile, importer::FAVORITES, bridge.get());
+ ASSERT_EQ(6u, bookmarks.size());
+ EXPECT_EQ("https://www.mozilla.org/en-US/firefox/central/",
+ bookmarks[0].url.spec());
+ EXPECT_EQ("https://www.mozilla.org/en-US/firefox/help/",
+ bookmarks[1].url.spec());
+ EXPECT_EQ("https://www.mozilla.org/en-US/firefox/customize/",
+ bookmarks[2].url.spec());
+ EXPECT_EQ("https://www.mozilla.org/en-US/contribute/",
+ bookmarks[3].url.spec());
+ EXPECT_EQ("https://www.mozilla.org/en-US/about/", bookmarks[4].url.spec());
+ EXPECT_EQ("https://www.google.com/", bookmarks[5].url.spec());
+ ASSERT_EQ(5u, favicons.size());
+ EXPECT_EQ("http://www.mozilla.org/2005/made-up-favicon/0-1473403921346",
+ favicons[0].favicon_url.spec());
+ EXPECT_EQ("http://www.mozilla.org/2005/made-up-favicon/1-1473403921347",
+ favicons[1].favicon_url.spec());
+ EXPECT_EQ("http://www.mozilla.org/2005/made-up-favicon/2-1473403921348",
+ favicons[2].favicon_url.spec());
+ EXPECT_EQ("http://www.mozilla.org/2005/made-up-favicon/3-1473403921349",
+ favicons[3].favicon_url.spec());
+ EXPECT_EQ("http://www.mozilla.org/2005/made-up-favicon/4-1473403921349",
+ favicons[4].favicon_url.spec());
+}
+
+TEST(FirefoxImporterTest, ImportHistorySchema) {
+ using ::testing::_;
+ base::FilePath places_path;
+ ASSERT_TRUE(PathService::Get(chrome::DIR_TEST_DATA, &places_path));
+ places_path =
+ places_path.AppendASCII("import").AppendASCII("firefox").AppendASCII(
+ "48.0.2");
+ scoped_refptr<FirefoxImporter> ff_importer = new FirefoxImporter;
+ importer::SourceProfile profile;
+ profile.source_path = places_path;
+ scoped_refptr<MockImporterBridge> bridge = new MockImporterBridge;
+ std::vector<ImporterURLRow> history;
+ EXPECT_CALL(*bridge, NotifyStarted());
+ EXPECT_CALL(*bridge, NotifyItemStarted(importer::HISTORY));
+ EXPECT_CALL(*bridge, SetHistoryItems(_, _))
+ .WillOnce(::testing::SaveArg<0>(&history));
+ EXPECT_CALL(*bridge, NotifyItemEnded(importer::HISTORY));
+ EXPECT_CALL(*bridge, NotifyEnded());
+ ff_importer->StartImport(profile, importer::HISTORY, bridge.get());
+ ASSERT_EQ(3u, history.size());
+ EXPECT_EQ("https://www.mozilla.org/en-US/firefox/48.0.2/firstrun/learnmore/",
+ history[0].url.spec());
+ EXPECT_EQ("https://www.mozilla.org/en-US/firefox/48.0.2/firstrun/",
+ history[1].url.spec());
+ EXPECT_EQ("http://google.com/", history[2].url.spec());
+}
« no previous file with comments | « chrome/utility/importer/firefox_importer.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698