diff options
Diffstat (limited to 'chrome')
-rw-r--r-- | chrome/browser/browser.vcproj | 8 | ||||
-rwxr-xr-x | chrome/browser/importer/importer.cc | 39 | ||||
-rw-r--r-- | chrome/browser/importer/importer.h | 2 | ||||
-rw-r--r-- | chrome/browser/importer/toolbar_importer.cc | 593 | ||||
-rw-r--r-- | chrome/browser/importer/toolbar_importer.h | 169 | ||||
-rw-r--r-- | chrome/browser/importer/toolbar_importer_unittest.cc | 440 |
6 files changed, 0 insertions, 1251 deletions
diff --git a/chrome/browser/browser.vcproj b/chrome/browser/browser.vcproj index efb1ee4..ac31c0f 100644 --- a/chrome/browser/browser.vcproj +++ b/chrome/browser/browser.vcproj @@ -1285,14 +1285,6 @@ RelativePath=".\importer\mork_reader.h" > </File> - <File - RelativePath=".\importer\toolbar_importer.cc" - > - </File> - <File - RelativePath=".\importer\toolbar_importer.h" - > - </File> </Filter> <Filter Name="Drag & Drop" diff --git a/chrome/browser/importer/importer.cc b/chrome/browser/importer/importer.cc index f3cb392..f73e443 100755 --- a/chrome/browser/importer/importer.cc +++ b/chrome/browser/importer/importer.cc @@ -20,7 +20,6 @@ #include "chrome/browser/importer/firefox_importer_utils.h" #include "chrome/browser/importer/firefox_profile_lock.h" #include "chrome/browser/importer/ie_importer.h" -#include "chrome/browser/importer/toolbar_importer.h" #include "chrome/browser/search_engines/template_url_model.h" #include "chrome/browser/shell_integration.h" #include "chrome/browser/views/importer_lock_view.h" @@ -498,27 +497,6 @@ void ImporterHost::StartImportSettings(const ProfileInfo& profile_info, } } - if (profile_info.browser_type == GOOGLE_TOOLBAR5) { - if (!ToolbarImporterUtils::IsGoogleGAIACookieInstalled()) { - win_util::MessageBox( - NULL, - l10n_util::GetString(IDS_IMPORTER_GOOGLE_LOGIN_TEXT).c_str(), - L"", - MB_OK | MB_TOPMOST); - - GURL url("https://www.google.com/accounts/ServiceLogin"); - BrowsingInstance* instance = new BrowsingInstance(writer_->GetProfile()); - SiteInstance* site = instance->GetSiteInstanceForURL(url); - Browser* browser = BrowserList::GetLastActive(); - browser->AddTabWithURL(url, GURL(), PageTransition::TYPED, true, site); - - MessageLoop::current()->PostTask(FROM_HERE, NewRunnableMethod( - this, &ImporterHost::OnLockViewEnd, false)); - - is_source_readable_ = false; - } - } - // BookmarkModel should be loaded before adding IE favorites. So we observe // the BookmarkModel if needed, and start the task after it has been loaded. if ((items & FAVORITES) && !writer_->BookmarkModelIsLoaded()) { @@ -587,8 +565,6 @@ Importer* ImporterHost::CreateImporterByType(ProfileType type) { return new Firefox2Importer(); case FIREFOX3: return new Firefox3Importer(); - case GOOGLE_TOOLBAR5: - return new Toolbar5Importer(); } NOTREACHED(); return NULL; @@ -618,8 +594,6 @@ void ImporterHost::DetectSourceProfiles() { DetectIEProfiles(); DetectFirefoxProfiles(); } - - if (!FirstRun::IsChromeFirstRun()) DetectGoogleToolbarProfiles(); } void ImporterHost::DetectIEProfiles() { @@ -699,16 +673,3 @@ void ImporterHost::DetectFirefoxProfiles() { source_profiles_.push_back(firefox); } } - -void ImporterHost::DetectGoogleToolbarProfiles() { - if (!FirstRun::IsChromeFirstRun()) { - ProfileInfo* google_toolbar = new ProfileInfo(); - google_toolbar->browser_type = GOOGLE_TOOLBAR5; - google_toolbar->description = l10n_util::GetString( - IDS_IMPORT_FROM_GOOGLE_TOOLBAR); - google_toolbar->source_path.clear(); - google_toolbar->app_path.clear(); - google_toolbar->services_supported = FAVORITES; - source_profiles_.push_back(google_toolbar); - } -} diff --git a/chrome/browser/importer/importer.h b/chrome/browser/importer/importer.h index e169eb7..a94047d 100644 --- a/chrome/browser/importer/importer.h +++ b/chrome/browser/importer/importer.h @@ -30,7 +30,6 @@ enum ProfileType { MS_IE = 0, FIREFOX2, FIREFOX3, - GOOGLE_TOOLBAR5, // Identifies a 'bookmarks.html' file. BOOKMARKS_HTML }; @@ -279,7 +278,6 @@ class ImporterHost : public base::RefCounted<ImporterHost>, // Helper methods for detecting available profiles. void DetectIEProfiles(); void DetectFirefoxProfiles(); - void DetectGoogleToolbarProfiles(); // The list of profiles with the default one first. std::vector<ProfileInfo*> source_profiles_; diff --git a/chrome/browser/importer/toolbar_importer.cc b/chrome/browser/importer/toolbar_importer.cc deleted file mode 100644 index 350b2edb..0000000 --- a/chrome/browser/importer/toolbar_importer.cc +++ /dev/null @@ -1,593 +0,0 @@ -// Copyright (c) 2006-2008 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/importer/toolbar_importer.h" - -#include <limits> - -#include "base/string_util.h" -#include "base/rand_util.h" -#include "base/registry.h" -#include "chrome/browser/first_run.h" -#include "chrome/common/l10n_util.h" -#include "chrome/common/libxml_utils.h" -#include "net/base/cookie_monster.h" -#include "net/base/data_url.h" - -#include "generated_resources.h" - -// -// ToolbarImporterUtils -// -static const char* kGoogleDomainUrl = "http://.google.com/"; -static const wchar_t kSplitStringToken = L';'; -static const char* kGoogleDomainSecureCookieId = "SID="; - -bool ToolbarImporterUtils::IsGoogleGAIACookieInstalled() { - URLRequestContext* context = Profile::GetDefaultRequestContext(); - net::CookieMonster* store = context->cookie_store(); - GURL url(kGoogleDomainUrl); - net::CookieMonster::CookieOptions options; - options.set_include_httponly(); // The SID cookie might be httponly. - std::string cookies = store->GetCookiesWithOptions(url, options); - std::vector<std::string> cookie_list; - SplitString(cookies, kSplitStringToken, &cookie_list); - for (std::vector<std::string>::iterator current = cookie_list.begin(); - current != cookie_list.end(); - ++current) { - size_t position = (*current).find(kGoogleDomainSecureCookieId); - if (0 == position) - return true; - } - return false; -} - -// -// Toolbar5Importer -// -const char Toolbar5Importer::kXmlApiReplyXmlTag[] = "xml_api_reply"; -const char Toolbar5Importer::kBookmarksXmlTag[] = "bookmarks"; -const char Toolbar5Importer::kBookmarkXmlTag[] = "bookmark"; -const char Toolbar5Importer::kTitleXmlTag[] = "title"; -const char Toolbar5Importer::kUrlXmlTag[] = "url"; -const char Toolbar5Importer::kTimestampXmlTag[] = "timestamp"; -const char Toolbar5Importer::kLabelsXmlTag[] = "labels"; -const char Toolbar5Importer::kLabelsXmlCloseTag[] = "/labels"; -const char Toolbar5Importer::kLabelXmlTag[] = "label"; -const char Toolbar5Importer::kAttributesXmlTag[] = "attributes"; - -const char Toolbar5Importer::kRandomNumberToken[] = "{random_number}"; -const char Toolbar5Importer::kAuthorizationToken[] = "{auth_token}"; -const char Toolbar5Importer::kAuthorizationTokenPrefix[] = "/*"; -const char Toolbar5Importer::kAuthorizationTokenSuffix[] = "*/"; -const char Toolbar5Importer::kMaxNumToken[] = "{max_num}"; -const char Toolbar5Importer::kMaxTimestampToken[] = "{max_timestamp}"; - -const char Toolbar5Importer::kT5AuthorizationTokenUrl[] = - "http://www.google.com/notebook/token?zx={random_number}"; -const char Toolbar5Importer::kT5FrontEndUrlTemplate[] = - "http://www.google.com/notebook/toolbar?cmd=list&tok={auth_token}&" - "num={max_num}&min={max_timestamp}&all=0&zx={random_number}"; - -// Importer methods. - -// The constructor should set the initial state to NOT_USED. -Toolbar5Importer::Toolbar5Importer() - : writer_(NULL), - state_(NOT_USED), - items_to_import_(NONE), - token_fetcher_(NULL), - data_fetcher_(NULL) { -} - -// The destructor insures that the fetchers are currently not being used, as -// their thread-safe implementation requires that they are cancelled from the -// thread in which they were constructed. -Toolbar5Importer::~Toolbar5Importer() { - DCHECK(!token_fetcher_); - DCHECK(!data_fetcher_); -} - -void Toolbar5Importer::StartImport(ProfileInfo profile_info, - uint16 items, - ProfileWriter* writer, - MessageLoop* delagate_loop, - ImporterHost* host) { - DCHECK(writer); - DCHECK(host); - - importer_host_ = host; - delagate_loop_ = delagate_loop; - writer_ = writer; - items_to_import_ = items; - state_ = INITIALIZED; - - NotifyStarted(); - ContinueImport(); -} - -// The public cancel method serves two functions, as a callback from the UI -// as well as an internal callback in case of cancel. An internal callback -// is required since the URLFetcher must be destroyed from the thread it was -// created. -void Toolbar5Importer::Cancel() { - // In the case when the thread is not importing messages we are to - // cancel as soon as possible. - Importer::Cancel(); - - // If we are conducting network operations, post a message to the importer - // thread for synchronization. - if (NULL != delagate_loop_) { - if (delagate_loop_ != MessageLoop::current()) { - delagate_loop_->PostTask( - FROM_HERE, - NewRunnableMethod(this, &Toolbar5Importer::Cancel)); - } else { - EndImport(); - } - } -} - -void Toolbar5Importer::OnURLFetchComplete( - const URLFetcher* source, - const GURL& url, - const URLRequestStatus& status, - int response_code, - const ResponseCookies& cookies, - const std::string& data) { - if (cancelled()) { - EndImport(); - return; - } - - if (200 != response_code) { // HTTP/Ok - // Cancelling here will update the UI and bypass the rest of bookmark - // import. - EndImportBookmarks(); - return; - } - - switch (state_) { - case GET_AUTHORIZATION_TOKEN: - GetBookmarkDataFromServer(data); - break; - case GET_BOOKMARKS: - GetBookmarksFromServerDataResponse(data); - break; - default: - NOTREACHED() << "Invalid state."; - EndImportBookmarks(); - break; - } -} - -void Toolbar5Importer::ContinueImport() { - DCHECK((items_to_import_ == FAVORITES) || (items_to_import_ == NONE)) << - "The items requested are not supported"; - - // The order here is important. Each Begin... will clear the flag - // of its item before its task finishes and re-enters this method. - if (NONE == items_to_import_) { - EndImport(); - return; - } - if ((items_to_import_ & FAVORITES) && !cancelled()) { - items_to_import_ &= ~FAVORITES; - BeginImportBookmarks(); - return; - } - // TODO(brg): Import history, autocomplete, other toolbar information - // in a future release. - - // This code should not be reached, but gracefully handles the possibility - // that StartImport was called with unsupported items_to_import. - if (!cancelled()) - EndImport(); -} - -void Toolbar5Importer::EndImport() { - if (state_ != DONE) { - state_ = DONE; - // By spec the fetchers must be destroyed within the same - // thread they are created. The importer is destroyed in the ui_thread - // so when we complete in the file_thread we destroy them first. - if (NULL != token_fetcher_) { - delete token_fetcher_; - token_fetcher_ = NULL; - } - - if (NULL != data_fetcher_) { - delete data_fetcher_; - data_fetcher_ = NULL; - } - - NotifyEnded(); - } -} - -void Toolbar5Importer::BeginImportBookmarks() { - NotifyItemStarted(FAVORITES); - GetAuthenticationFromServer(); -} - -void Toolbar5Importer::EndImportBookmarks() { - NotifyItemEnded(FAVORITES); - ContinueImport(); -} - - -// Notebook front-end connection manager implementation follows. -void Toolbar5Importer::GetAuthenticationFromServer() { - if (cancelled()) { - EndImport(); - return; - } - - // Authentication is a token string retrieved from the authentication server - // To access it we call the url below with a random number replacing the - // value in the string. - state_ = GET_AUTHORIZATION_TOKEN; - - // Random number construction. - int random = base::RandInt(0, std::numeric_limits<int>::max()); - std::string random_string = UintToString(random); - - // Retrieve authorization token from the network. - std::string url_string(kT5AuthorizationTokenUrl); - url_string.replace(url_string.find(kRandomNumberToken), - arraysize(kRandomNumberToken) - 1, - random_string); - GURL url(url_string); - - token_fetcher_ = new URLFetcher(url, URLFetcher::GET, this); - token_fetcher_->set_request_context(Profile::GetDefaultRequestContext()); - token_fetcher_->Start(); -} - -void Toolbar5Importer::GetBookmarkDataFromServer(const std::string& response) { - if (cancelled()) { - EndImport(); - return; - } - - state_ = GET_BOOKMARKS; - - // Parse and verify the authorization token from the response. - std::string token; - if (!ParseAuthenticationTokenResponse(response, &token)) { - EndImportBookmarks(); - return; - } - - // Build the Toolbar FE connection string, and call the server for - // the xml blob. We must tag the connection string with a random number. - std::string conn_string = kT5FrontEndUrlTemplate; - int random = base::RandInt(0, std::numeric_limits<int>::max()); - std::string random_string = UintToString(random); - conn_string.replace(conn_string.find(kRandomNumberToken), - arraysize(kRandomNumberToken) - 1, - random_string); - conn_string.replace(conn_string.find(kAuthorizationToken), - arraysize(kAuthorizationToken) - 1, - token); - GURL url(conn_string); - - data_fetcher_ = new URLFetcher(url, URLFetcher::GET, this); - data_fetcher_->set_request_context(Profile::GetDefaultRequestContext()); - data_fetcher_->Start(); -} - -void Toolbar5Importer::GetBookmarksFromServerDataResponse( - const std::string& response) { - if (cancelled()) { - EndImport(); - return; - } - - state_ = PARSE_BOOKMARKS; - - XmlReader reader; - if (reader.Load(response) && !cancelled()) { - // Construct Bookmarks - std::vector<ProfileWriter::BookmarkEntry> bookmarks; - if (ParseBookmarksFromReader(&reader, &bookmarks)) - AddBookmarksToChrome(bookmarks); - } - EndImportBookmarks(); -} - -bool Toolbar5Importer::ParseAuthenticationTokenResponse( - const std::string& response, - std::string* token) { - DCHECK(token); - - *token = response; - size_t position = token->find(kAuthorizationTokenPrefix); - if (0 != position) - return false; - token->replace(position, arraysize(kAuthorizationTokenPrefix) - 1, ""); - - position = token->find(kAuthorizationTokenSuffix); - if (token->size() != (position + (arraysize(kAuthorizationTokenSuffix) - 1))) - return false; - token->replace(position, arraysize(kAuthorizationTokenSuffix) - 1, ""); - - return true; -} - -// Parsing -bool Toolbar5Importer::ParseBookmarksFromReader( - XmlReader* reader, - std::vector<ProfileWriter::BookmarkEntry>* bookmarks) { - DCHECK(reader); - DCHECK(bookmarks); - - // The XML blob returned from the server is described in the - // Toolbar-Notebook/Bookmarks Protocol document located at - // https://docs.google.com/a/google.com/Doc?docid=cgt3m7dr_24djt62m&hl=en - // We are searching for the section with structure - // <bookmarks><bookmark>...</bookmark><bookmark>...</bookmark></bookmarks> - - // Locate the |bookmarks| blob. - if (!reader->SkipToElement()) - return false; - - if (!LocateNextTagByName(reader, kBookmarksXmlTag)) - return false; - - // Parse each |bookmark| blob - while (LocateNextTagWithStopByName(reader, kBookmarkXmlTag, - kBookmarksXmlTag)) { - ProfileWriter::BookmarkEntry bookmark_entry; - std::vector<BookmarkFolderType> folders; - if (ExtractBookmarkInformation(reader, &bookmark_entry, &folders)) { - // For each folder we create a new bookmark entry. Duplicates will - // be detected when we attempt to create the bookmark in the profile. - for (std::vector<BookmarkFolderType>::iterator folder = folders.begin(); - folder != folders.end(); - ++folder) { - bookmark_entry.path = *folder; - bookmarks->push_back(bookmark_entry); - } - } - } - - if (0 == bookmarks->size()) - return false; - - return true; -} - -bool Toolbar5Importer::LocateNextOpenTag(XmlReader* reader) { - DCHECK(reader); - - while (!reader->SkipToElement()) { - if (!reader->Read()) - return false; - } - return true; -} - -bool Toolbar5Importer::LocateNextTagByName(XmlReader* reader, - const std::string& tag) { - DCHECK(reader); - - // Locate the |tag| blob. - while (tag != reader->NodeName()) { - if (!reader->Read() || !LocateNextOpenTag(reader)) - return false; - } - return true; -} - -bool Toolbar5Importer::LocateNextTagWithStopByName(XmlReader* reader, - const std::string& tag, - const std::string& stop) { - DCHECK(reader); - - DCHECK_NE(tag, stop); - // Locate the |tag| blob. - while (tag != reader->NodeName()) { - // Move to the next open tag. - if (!reader->Read() || !LocateNextOpenTag(reader)) - return false; - // If we encounter the stop word return false. - if (stop == reader->NodeName()) - return false; - } - return true; -} - -bool Toolbar5Importer::ExtractBookmarkInformation( - XmlReader* reader, - ProfileWriter::BookmarkEntry* bookmark_entry, - std::vector<BookmarkFolderType>* bookmark_folders) { - DCHECK(reader); - DCHECK(bookmark_entry); - DCHECK(bookmark_folders); - - // The following is a typical bookmark entry. - // The reader should be pointing to the <title> tag at the moment. - // - // <bookmark> - // <title>MyTitle</title> - // <url>http://www.sohu.com/</url> - // <timestamp>1153328691085181</timestamp> - // <id>N123nasdf239</id> - // <notebook_id>Bxxxxxxx</notebook_id> (for bookmarks, a special id is used) - // <section_id>Sxxxxxx</section_id> - // <has_highlight>0</has_highlight> - // <labels> - // <label>China</label> - // <label>^k</label> (if this special label is present, the note is deleted) - // </labels> - // <attributes> - // <attribute> - // <name>favicon_url</name> - // <value>http://www.sohu.com/favicon.ico</value> - // </attribute> - // <attribute> - // <name>favicon_timestamp</name> - // <value>1153328653</value> - // </attribute> - // <attribute> - // <name>notebook_name</name> - // <value>My notebook 0</value> - // </attribute> - // <attribute> - // <name>section_name</name> - // <value>My section 0</value> - // </attribute> - // </attributes> - // </bookmark> - // - // We parse the blob in order, title->url->timestamp etc. Any failure - // causes us to skip this bookmark. - - if (!ExtractTitleFromXmlReader(reader, bookmark_entry)) - return false; - if (!ExtractUrlFromXmlReader(reader, bookmark_entry)) - return false; - if (!ExtractTimeFromXmlReader(reader, bookmark_entry)) - return false; - if (!ExtractFoldersFromXmlReader(reader, bookmark_folders)) - return false; - - return true; -} - -bool Toolbar5Importer::ExtractNamedValueFromXmlReader(XmlReader* reader, - const std::string& name, - std::string* buffer) { - DCHECK(reader); - DCHECK(buffer); - - if (name != reader->NodeName()) - return false; - if (!reader->ReadElementContent(buffer)) - return false; - return true; -} - -bool Toolbar5Importer::ExtractTitleFromXmlReader( - XmlReader* reader, - ProfileWriter::BookmarkEntry* entry) { - DCHECK(reader); - DCHECK(entry); - - if (!LocateNextTagWithStopByName(reader, kTitleXmlTag, kUrlXmlTag)) - return false; - std::string buffer; - if (!ExtractNamedValueFromXmlReader(reader, kTitleXmlTag, &buffer)) { - return false; - } - entry->title = UTF8ToWide(buffer); - return true; -} - -bool Toolbar5Importer::ExtractUrlFromXmlReader( - XmlReader* reader, - ProfileWriter::BookmarkEntry* entry) { - DCHECK(reader); - DCHECK(entry); - - if (!LocateNextTagWithStopByName(reader, kUrlXmlTag, kTimestampXmlTag)) - return false; - std::string buffer; - if (!ExtractNamedValueFromXmlReader(reader, kUrlXmlTag, &buffer)) { - return false; - } - entry->url = GURL(buffer); - return true; -} - -bool Toolbar5Importer::ExtractTimeFromXmlReader( - XmlReader* reader, - ProfileWriter::BookmarkEntry* entry) { - DCHECK(reader); - DCHECK(entry); - if (!LocateNextTagWithStopByName(reader, kTimestampXmlTag, kLabelsXmlTag)) - return false; - std::string buffer; - if (!ExtractNamedValueFromXmlReader(reader, kTimestampXmlTag, &buffer)) { - return false; - } - int64 timestamp; - if (!StringToInt64(buffer, ×tamp)) { - return false; - } - entry->creation_time = base::Time::FromTimeT(timestamp); - return true; -} - -bool Toolbar5Importer::ExtractFoldersFromXmlReader( - XmlReader* reader, - std::vector<BookmarkFolderType>* bookmark_folders) { - DCHECK(reader); - DCHECK(bookmark_folders); - - // Read in the labels for this bookmark from the xml. There may be many - // labels for any one bookmark. - if (!LocateNextTagWithStopByName(reader, kLabelsXmlTag, kAttributesXmlTag)) - return false; - - // It is within scope to have an empty labels section, so we do not - // return false if the labels are empty. - if (!reader->Read() || !LocateNextOpenTag(reader)) - return false; - - std::vector<std::wstring> label_vector; - while (kLabelXmlTag == reader->NodeName()) { - std::string label_buffer; - if (!reader->ReadElementContent(&label_buffer)) { - label_buffer = ""; - } - label_vector.push_back(UTF8ToWide(label_buffer)); - LocateNextOpenTag(reader); - } - - if (0 == label_vector.size()) { - if (!FirstRun::IsChromeFirstRun()) { - bookmark_folders->resize(1); - (*bookmark_folders)[0].push_back( - l10n_util::GetString(IDS_BOOKMARK_GROUP_FROM_GOOGLE_TOOLBAR)); - } - return true; - } - - // We will be making one bookmark folder for each label. - bookmark_folders->resize(label_vector.size()); - - for (size_t index = 0; index < label_vector.size(); ++index) { - // If this is the first run then we place favorites with no labels - // in the title bar. Else they are placed in the "Google Toolbar" folder. - if (!FirstRun::IsChromeFirstRun() || !label_vector[index].empty()) { - (*bookmark_folders)[index].push_back( - l10n_util::GetString(IDS_BOOKMARK_GROUP_FROM_GOOGLE_TOOLBAR)); - } - - // If the label and is in the form "xxx:yyy:zzz" this was created from an - // IE or Firefox folder. We undo the label creation and recreate the - // correct folder. - std::vector<std::wstring> folder_names; - SplitString(label_vector[index], L':', &folder_names); - (*bookmark_folders)[index].insert((*bookmark_folders)[index].end(), - folder_names.begin(), folder_names.end()); - } - - return true; -} - -// Bookmark creation -void Toolbar5Importer::AddBookmarksToChrome( - const std::vector<ProfileWriter::BookmarkEntry>& bookmarks) { - if (!bookmarks.empty() && !cancelled()) { - int options = ProfileWriter::ADD_IF_UNIQUE | - (first_run() ? ProfileWriter::FIRST_RUN : 0); - main_loop_->PostTask(FROM_HERE, NewRunnableMethod(writer_, - &ProfileWriter::AddBookmarkEntry, bookmarks, - l10n_util::GetString(IDS_BOOKMARK_GROUP_FROM_GOOGLE_TOOLBAR), - options)); - } -} diff --git a/chrome/browser/importer/toolbar_importer.h b/chrome/browser/importer/toolbar_importer.h deleted file mode 100644 index cfb2825..0000000 --- a/chrome/browser/importer/toolbar_importer.h +++ /dev/null @@ -1,169 +0,0 @@ -// Copyright (c) 2006-2008 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. - -// The functionality provided here allows the user to import their bookmarks -// (favorites) from Google Toolbar. - -#ifndef CHROME_BROWSER_IMPORTER_TOOLBAR_IMPORTER_H__ -#define CHROME_BROWSER_IMPORTER_TOOLBAR_IMPORTER_H__ - -#include <string> -#include <vector> - -#include "chrome/browser/importer/importer.h" -#include "chrome/browser/net/url_fetcher.h" - -class XmlReader; - -// Currently the only configuration information we need is to check whether or -// not the user currently has their GAIA cookie. This is done by the function -// exposed through the ToolbarImportUtils namespace. -namespace ToolbarImporterUtils { -bool IsGoogleGAIACookieInstalled(); -} // namespace ToolbarImporterUtils - -// Toolbar5Importer is a class which exposes the functionality needed to -// communicate with the Google Toolbar v5 front-end, negotiate the download of -// Toolbar bookmarks, parse them, and install them on the client. -// Toolbar5Importer should not have StartImport called more than once. Futher -// if StartImport is called, then the class must not be destroyed until it -// has either completed or Toolbar5Importer->Cancel() has been called. -class Toolbar5Importer : public URLFetcher::Delegate, public Importer { - public: - Toolbar5Importer(); - virtual ~Toolbar5Importer(); - - // Importer view calls this method to begin the process. The items parameter - // should only either be NONE or FAVORITES, since as of right now these are - // the only items this importer supports. This method provides implementation - // of Importer::StartImport. - virtual void StartImport(ProfileInfo profile_info, - uint16 items, - ProfileWriter* writer, - MessageLoop* delegate_loop, - ImporterHost* host); - - // Importer view call this method when the user clicks the cancel button - // in the ImporterView UI. We need to post a message to our loop - // to cancel network retrieval. - virtual void Cancel(); - - // URLFetcher::Delegate method called back from the URLFetcher object. - virtual void OnURLFetchComplete(const URLFetcher* source, - const GURL& url, - const URLRequestStatus& status, - int response_code, - const ResponseCookies& cookies, - const std::string& data); - - private: - FRIEND_TEST(Toolbar5ImporterTest, BookmarkParse); - - // Internal states of the toolbar importer. - enum InternalStateEnum { - NOT_USED = -1, - INITIALIZED, - GET_AUTHORIZATION_TOKEN, - GET_BOOKMARKS, - PARSE_BOOKMARKS, - DONE - }; - - typedef std::vector<std::wstring> BookmarkFolderType; - - // URLs for connecting to the toolbar front end are defined below. - static const char kT5AuthorizationTokenUrl[]; - static const char kT5FrontEndUrlTemplate[]; - - // Token replacement tags are defined below. - static const char kRandomNumberToken[]; - static const char kAuthorizationToken[]; - static const char kAuthorizationTokenPrefix[]; - static const char kAuthorizationTokenSuffix[]; - static const char kMaxNumToken[]; - static const char kMaxTimestampToken[]; - - // XML tag names are defined below. - static const char kXmlApiReplyXmlTag[]; - static const char kBookmarksXmlTag[]; - static const char kBookmarkXmlTag[]; - static const char kTitleXmlTag[]; - static const char kUrlXmlTag[]; - static const char kTimestampXmlTag[]; - static const char kLabelsXmlTag[]; - static const char kLabelsXmlCloseTag[]; - static const char kLabelXmlTag[]; - static const char kAttributesXmlTag[]; - - // Flow control for asynchronous import is controlled by the methods below. - // ContinueImport is called back by each import action taken. BeginXXX - // and EndXXX are responsible for updating the state of the asynchronous - // import. EndImport is responsible for state cleanup and notifying the - // caller that import has completed. - void ContinueImport(); - void EndImport(); - void BeginImportBookmarks(); - void EndImportBookmarks(); - - // Network I/O is done by the methods below. These three methods are called - // in the order provided. The last two are called back with the HTML - // response provided by the Toolbar server. - void GetAuthenticationFromServer(); - void GetBookmarkDataFromServer(const std::string& response); - void GetBookmarksFromServerDataResponse(const std::string& response); - - // XML Parsing is implemented with the methods below. - bool ParseAuthenticationTokenResponse(const std::string& response, - std::string* token); - - static bool ParseBookmarksFromReader( - XmlReader* reader, - std::vector<ProfileWriter::BookmarkEntry>* bookmarks); - - static bool LocateNextOpenTag(XmlReader* reader); - static bool LocateNextTagByName(XmlReader* reader, const std::string& tag); - static bool LocateNextTagWithStopByName( - XmlReader* reader, - const std::string& tag, - const std::string& stop); - - static bool ExtractBookmarkInformation( - XmlReader* reader, - ProfileWriter::BookmarkEntry* bookmark_entry, - std::vector<BookmarkFolderType>* bookmark_folders); - static bool ExtractNamedValueFromXmlReader(XmlReader* reader, - const std::string& name, - std::string* buffer); - static bool ExtractTitleFromXmlReader(XmlReader* reader, - ProfileWriter::BookmarkEntry* entry); - static bool ExtractUrlFromXmlReader(XmlReader* reader, - ProfileWriter::BookmarkEntry* entry); - static bool ExtractTimeFromXmlReader(XmlReader* reader, - ProfileWriter::BookmarkEntry* entry); - static bool ExtractFoldersFromXmlReader( - XmlReader* reader, - std::vector<BookmarkFolderType>* bookmark_folders); - - // Bookmark creation is done by the method below. - void AddBookmarksToChrome( - const std::vector<ProfileWriter::BookmarkEntry>& bookmarks); - - // The writer used in this importer is stored in writer_. - ProfileWriter* writer_; - - // Internal state is stored in state_. - InternalStateEnum state_; - - // Bitmask of Importer::ImportItem is stored in items_to_import_. - uint16 items_to_import_; - - // The fetchers need to be available to cancel the network call on user cancel - // hence they are stored as member variables. - URLFetcher* token_fetcher_; - URLFetcher* data_fetcher_; - - DISALLOW_COPY_AND_ASSIGN(Toolbar5Importer); -}; - -#endif // CHROME_BROWSER_IMPORTER_TOOLBAR_IMPORTER_H__ diff --git a/chrome/browser/importer/toolbar_importer_unittest.cc b/chrome/browser/importer/toolbar_importer_unittest.cc deleted file mode 100644 index 4201fbf..0000000 --- a/chrome/browser/importer/toolbar_importer_unittest.cc +++ /dev/null @@ -1,440 +0,0 @@ -// Copyright (c) 2006-2008 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 <string> -#include <vector> - -#include "chrome/browser/importer/importer.h" -#include "chrome/browser/importer/toolbar_importer.h" -#include "chrome/common/libxml_utils.h" - - -namespace toolbar_importer_unittest { -static const wchar_t* kTitle = L"MyTitle"; -static const wchar_t* kUrl = L"http://www.google.com/"; -static const wchar_t* kTimestamp = L"1153328691085181"; -static const wchar_t* kFolder = L"Google"; -static const wchar_t* kFolder2 = L"Homepage"; -static const wchar_t* kFolderArray[3] = {L"Google", L"Search", L"Page"}; - -static const wchar_t* kOtherTitle = L"MyOtherTitle"; -static const wchar_t* kOtherUrl = L"http://www.google.com/mail"; -static const wchar_t* kOtherFolder = L"Mail"; - -// Since the following is very dense to read I enumerate the test cases here. -// 1. Correct bookmark structure with one label. -// 2. Correct bookmark structure with no labels. -// 3. Correct bookmark structure with two labels. -// 4. Correct bookmark structure with a folder->label translation by toolbar. -// 5. Correct bookmark structure with no favicon. -// 6. Two correct bookmarks. -// The following are error cases by removing sections from the xml: -// 7. Empty string passed as xml. -// 8. No <bookmarks> section in the xml. -// 9. No <bookmark> section below the <bookmarks> section. -// 10. No <title> in a <bookmark> section. -// 11. No <url> in a <bookmark> section. -// 12. No <timestamp> in a <bookmark> section. -// 13. No <labels> in a <bookmark> section. -static const char* kGoodBookmark = - " <bookmarks>" - " <bookmark> " - "<title>MyTitle</title> " - "<url>http://www.google.com/</url> " - "<timestamp>1153328691085181</timestamp> " - "<id>N123nasdf239</id> <notebook_id>Bxxxxxxx</notebook_id> " - "<section_id>Sxxxxxx</section_id> <has_highlight>0</has_highlight>" - "<labels> <label>Google</label> </labels> " - "<attributes> " - "<attribute> " - "<name>favicon_url</name> <value>http://www.google.com/favicon.ico</value> " - "</attribute> " - "<attribute> " - "<name>favicon_timestamp</name> <value>1153328653</value> " - "</attribute> " - "<attribute> <name>notebook_name</name> <value>My notebook 0</value> " - "</attribute> " - "<attribute> <name>section_name</name> <value>My section 0 " - "</value> </attribute> </attributes> " - "</bookmark> </bookmarks>"; -static const char* kGoodBookmarkNoLabel = - " <bookmarks>" - " <bookmark> " - "<title>MyTitle</title> " - "<url>http://www.google.com/</url> " - "<timestamp>1153328691085181</timestamp> " - "<id>N123nasdf239</id> <notebook_id>Bxxxxxxx</notebook_id> " - "<section_id>Sxxxxxx</section_id> <has_highlight>0</has_highlight>" - "<labels> </labels> " - "<attributes> " - "<attribute> " - "<name>favicon_url</name> <value>http://www.google.com/favicon.ico</value> " - "</attribute> " - "<attribute> " - "<name>favicon_timestamp</name> <value>1153328653</value> " - "</attribute> " - "<attribute> <name>notebook_name</name> <value>My notebook 0</value> " - "</attribute> " - "<attribute> <name>section_name</name> <value>My section 0 " - "</value> </attribute> </attributes> " - "</bookmark> </bookmarks>"; -static const char* kGoodBookmarkTwoLabels = - " <bookmarks>" - " <bookmark> " - "<title>MyTitle</title> " - "<url>http://www.google.com/</url> " - "<timestamp>1153328691085181</timestamp> " - "<id>N123nasdf239</id> <notebook_id>Bxxxxxxx</notebook_id> " - "<section_id>Sxxxxxx</section_id> <has_highlight>0</has_highlight>" - "<labels> <label>Google</label> <label>Homepage</label> </labels> " - "<attributes> " - "<attribute> " - "<name>favicon_url</name> <value>http://www.google.com/favicon.ico</value> " - "</attribute> " - "<attribute> " - "<name>favicon_timestamp</name> <value>1153328653</value> " - "</attribute> " - "<attribute> <name>notebook_name</name> <value>My notebook 0</value> " - "</attribute> " - "<attribute> <name>section_name</name> <value>My section 0 " - "</value> </attribute> </attributes> " - "</bookmark> </bookmarks>"; -static const char* kGoodBookmarkFolderLabel = - " <bookmarks>" - " <bookmark> " - "<title>MyTitle</title> " - "<url>http://www.google.com/</url> " - "<timestamp>1153328691085181</timestamp> " - "<id>N123nasdf239</id> <notebook_id>Bxxxxxxx</notebook_id> " - "<section_id>Sxxxxxx</section_id> <has_highlight>0</has_highlight>" - "<labels> <label>Google:Search:Page</label> </labels> " - "<attributes> " - "<attribute> " - "<name>favicon_url</name> <value>http://www.google.com/favicon.ico</value> " - "</attribute> " - "<attribute> " - "<name>favicon_timestamp</name> <value>1153328653</value> " - "</attribute> " - "<attribute> <name>notebook_name</name> <value>My notebook 0</value> " - "</attribute> " - "<attribute> <name>section_name</name> <value>My section 0 " - "</value> </attribute> </attributes> " - "</bookmark> </bookmarks>"; -static const char* kGoodBookmarkNoFavicon = - " <bookmarks>" - " <bookmark> " - "<title>MyTitle</title> " - "<url>http://www.google.com/</url> " - "<timestamp>1153328691085181</timestamp> " - "<id>N123nasdf239</id> <notebook_id>Bxxxxxxx</notebook_id> " - "<section_id>Sxxxxxx</section_id> <has_highlight>0</has_highlight>" - "<labels> <label>Google</label> </labels> " - "<attributes> " - "<attribute> " - "<name>favicon_timestamp</name> <value>1153328653</value> " - "</attribute> " - "<attribute> <name>notebook_name</name> <value>My notebook 0</value> " - "</attribute> " - "<attribute> <name>section_name</name> <value>My section 0 " - "</value> </attribute> </attributes> " - "</bookmark> </bookmarks>"; -static const char* kGoodBookmark2Items = - " <bookmarks>" - " <bookmark> " - "<title>MyTitle</title> " - "<url>http://www.google.com/</url> " - "<timestamp>1153328691085181</timestamp> " - "<id>N123nasdf239</id> <notebook_id>Bxxxxxxx</notebook_id> " - "<section_id>Sxxxxxx</section_id> <has_highlight>0</has_highlight>" - "<labels> <label>Google</label> </labels> " - "<attributes> " - "<attribute> " - "<name>favicon_url</name> <value>http://www.google.com/favicon.ico</value> " - "</attribute> " - "<attribute> " - "<name>favicon_timestamp</name> <value>1153328653</value> " - "</attribute> " - "<attribute> <name>notebook_name</name> <value>My notebook 0</value> " - "</attribute> " - "<attribute> <name>section_name</name> <value>My section 0 " - "</value> </attribute> </attributes> " - "</bookmark>" - " <bookmark> " - "<title>MyOtherTitle</title> " - "<url>http://www.google.com/mail</url> " - "<timestamp>1153328691085181</timestamp> " - "<id>N123nasdf239</id> <notebook_id>Bxxxxxxx</notebook_id> " - "<section_id>Sxxxxxx</section_id> <has_highlight>0</has_highlight>" - "<labels> <label>Mail</label> </labels> " - "<attributes> " - "<attribute> " - "<name>favicon_url</name>" - "<value>http://www.google.com/mail/favicon.ico</value> " - "</attribute> " - "<attribute> " - "<name>favicon_timestamp</name> <value>1253328653</value> " - "</attribute> " - "<attribute> <name>notebook_name</name> <value>My notebook 0</value> " - "</attribute> " - "<attribute> <name>section_name</name> <value>My section 0 " - "</value> </attribute> </attributes> " - "</bookmark>" - "</bookmarks>"; -static const char* kEmptyString = ""; -static const char* kBadBookmarkNoBookmarks = - " <bookmark> " - "<title>MyTitle</title> " - "<url>http://www.google.com/</url> " - "<timestamp>1153328691085181</timestamp> " - "<id>N123nasdf239</id> <notebook_id>Bxxxxxxx</notebook_id> " - "<section_id>Sxxxxxx</section_id> <has_highlight>0</has_highlight>" - "<labels> <label>Google</label> </labels> " - "<attributes> " - "<attribute> " - "<name>favicon_url</name> <value>http://www.google.com/favicon.ico</value> " - "</attribute> " - "<attribute> " - "<name>favicon_timestamp</name> <value>1153328653</value> " - "</attribute> " - "<attribute> <name>notebook_name</name> <value>My notebook 0</value> " - "</attribute> " - "<attribute> <name>section_name</name> <value>My section 0 " - "</value> </attribute> </attributes> " - "</bookmark> </bookmarks>"; -static const char* kBadBookmarkNoBookmark = - " <bookmarks>" - "<title>MyTitle</title> " - "<url>http://www.google.com/</url> " - "<timestamp>1153328691085181</timestamp> " - "<id>N123nasdf239</id> <notebook_id>Bxxxxxxx</notebook_id> " - "<section_id>Sxxxxxx</section_id> <has_highlight>0</has_highlight>" - "<labels> <label>Google</label> </labels> " - "<attributes> " - "<attribute> " - "<name>favicon_url</name> <value>http://www.google.com/favicon.ico</value> " - "</attribute> " - "<attribute> " - "<name>favicon_timestamp</name> <value>1153328653</value> " - "</attribute> " - "<attribute> <name>notebook_name</name> <value>My notebook 0</value> " - "</attribute> " - "<attribute> <name>section_name</name> <value>My section 0 " - "</value> </attribute> </attributes> " - "</bookmark> </bookmarks>"; -static const char* kBadBookmarkNoTitle = - " <bookmarks>" - " <bookmark> " - "<url>http://www.google.com/</url> " - "<timestamp>1153328691085181</timestamp> " - "<id>N123nasdf239</id> <notebook_id>Bxxxxxxx</notebook_id> " - "<section_id>Sxxxxxx</section_id> <has_highlight>0</has_highlight>" - "<labels> <label>Google</label> </labels> " - "<attributes> " - "<attribute> " - "<name>favicon_url</name> <value>http://www.google.com/favicon.ico</value> " - "</attribute> " - "<attribute> " - "<name>favicon_timestamp</name> <value>1153328653</value> " - "</attribute> " - "<attribute> <name>notebook_name</name> <value>My notebook 0</value> " - "</attribute> " - "<attribute> <name>section_name</name> <value>My section 0 " - "</value> </attribute> </attributes> " - "</bookmark> </bookmarks>"; -static const char* kBadBookmarkNoUrl = - " <bookmarks>" - " <bookmark> " - "<title>MyTitle</title> " - "<timestamp>1153328691085181</timestamp> " - "<id>N123nasdf239</id> <notebook_id>Bxxxxxxx</notebook_id> " - "<section_id>Sxxxxxx</section_id> <has_highlight>0</has_highlight>" - "<labels> <label>Google</label> </labels> " - "<attributes> " - "<attribute> " - "<name>favicon_url</name> <value>http://www.google.com/favicon.ico</value> " - "</attribute> " - "<attribute> " - "<name>favicon_timestamp</name> <value>1153328653</value> " - "</attribute> " - "<attribute> <name>notebook_name</name> <value>My notebook 0</value> " - "</attribute> " - "<attribute> <name>section_name</name> <value>My section 0 " - "</value> </attribute> </attributes> " - "</bookmark> </bookmarks>"; -static const char* kBadBookmarkNoTimestamp = - " <bookmarks>" - " <bookmark> " - "<title>MyTitle</title> " - "<url>http://www.google.com/</url> " - "<id>N123nasdf239</id> <notebook_id>Bxxxxxxx</notebook_id> " - "<section_id>Sxxxxxx</section_id> <has_highlight>0</has_highlight>" - "<labels> <label>Google</label> </labels> " - "<attributes> " - "<attribute> " - "<name>favicon_url</name> <value>http://www.google.com/favicon.ico</value> " - "</attribute> " - "<attribute> " - "<name>favicon_timestamp</name> <value>1153328653</value> " - "</attribute> " - "<attribute> <name>notebook_name</name> <value>My notebook 0</value> " - "</attribute> " - "<attribute> <name>section_name</name> <value>My section 0 " - "</value> </attribute> </attributes> " - "</bookmark> </bookmarks>"; -static const char* kBadBookmarkNoLabels = - " <bookmarks>" - " <bookmark> " - "<title>MyTitle</title> " - "<url>http://www.google.com/</url> " - "<timestamp>1153328691085181</timestamp> " - "<id>N123nasdf239</id> <notebook_id>Bxxxxxxx</notebook_id> " - "<section_id>Sxxxxxx</section_id> <has_highlight>0</has_highlight>" - "<attributes> " - "<attribute> " - "<name>favicon_url</name> <value>http://www.google.com/favicon.ico</value> " - "</attribute> " - "<attribute> " - "<name>favicon_timestamp</name> <value>1153328653</value> " - "</attribute> " - "<attribute> <name>notebook_name</name> <value>My notebook 0</value> " - "</attribute> " - "<attribute> <name>section_name</name> <value>My section 0 " - "</value> </attribute> </attributes> " - "</bookmark> </bookmarks>"; -} // namespace toolbar_importer_unittest - -// The parsing tests for Toolbar5Importer use the string above. For a -// description of all the tests run please see the comments immediately before -// the string constants above. -TEST(Toolbar5ImporterTest, BookmarkParse) { - XmlReader reader; - std::vector<ProfileWriter::BookmarkEntry> bookmarks; - - const GURL url(toolbar_importer_unittest::kUrl); - const GURL other_url(toolbar_importer_unittest::kOtherUrl); - - // Test case 1 is parsing a basic bookmark with a single label. - bookmarks.clear(); - EXPECT_TRUE(reader.Load(toolbar_importer_unittest::kGoodBookmark)); - EXPECT_TRUE(Toolbar5Importer::ParseBookmarksFromReader(&reader, &bookmarks)); - - EXPECT_EQ(bookmarks.size(), 1); - EXPECT_FALSE(bookmarks[0].in_toolbar); - EXPECT_EQ(toolbar_importer_unittest::kTitle, bookmarks[0].title); - EXPECT_EQ(url, bookmarks[0].url); - EXPECT_EQ(2, bookmarks[0].path.size()); - EXPECT_EQ(toolbar_importer_unittest::kFolder, bookmarks[0].path[1]); - - // Test case 2 is parsing a single bookmark with no label. - bookmarks.clear(); - EXPECT_TRUE(reader.Load(toolbar_importer_unittest::kGoodBookmarkNoLabel)); - EXPECT_TRUE(Toolbar5Importer::ParseBookmarksFromReader(&reader, &bookmarks)); - - EXPECT_EQ(bookmarks.size(), 1); - EXPECT_FALSE(bookmarks[0].in_toolbar); - EXPECT_EQ(toolbar_importer_unittest::kTitle, bookmarks[0].title); - EXPECT_EQ(bookmarks[0].url, url); - EXPECT_EQ(1, bookmarks[0].path.size()); - - // Test case 3 is parsing a single bookmark with two labels. - bookmarks.clear(); - EXPECT_TRUE(reader.Load(toolbar_importer_unittest::kGoodBookmarkTwoLabels)); - EXPECT_TRUE(Toolbar5Importer::ParseBookmarksFromReader(&reader, &bookmarks)); - - EXPECT_EQ(2, bookmarks.size()); - EXPECT_FALSE(bookmarks[0].in_toolbar); - EXPECT_FALSE(bookmarks[1].in_toolbar); - EXPECT_EQ(toolbar_importer_unittest::kTitle, bookmarks[0].title); - EXPECT_EQ(toolbar_importer_unittest::kTitle, bookmarks[1].title); - EXPECT_EQ(bookmarks[0].url, url); - EXPECT_EQ(bookmarks[1].url, url); - EXPECT_EQ(toolbar_importer_unittest::kFolder, bookmarks[0].path[1]); - EXPECT_EQ(toolbar_importer_unittest::kFolder2, bookmarks[1].path[1]); - - // Test case 4 is parsing a single bookmark which has a label with a colon, - // this test file name translation between Toolbar and Chrome. - bookmarks.clear(); - EXPECT_TRUE(reader.Load(toolbar_importer_unittest::kGoodBookmarkFolderLabel)); - EXPECT_TRUE(Toolbar5Importer::ParseBookmarksFromReader(&reader, &bookmarks)); - - EXPECT_EQ(bookmarks.size(), 1); - EXPECT_FALSE(bookmarks[0].in_toolbar); - EXPECT_EQ(toolbar_importer_unittest::kTitle, bookmarks[0].title); - EXPECT_EQ(bookmarks[0].url, url); - EXPECT_EQ(4, bookmarks[0].path.size()); - EXPECT_TRUE(toolbar_importer_unittest::kFolderArray[0] == - bookmarks[0].path[1]); - EXPECT_TRUE(toolbar_importer_unittest::kFolderArray[1] == - bookmarks[0].path[2]); - EXPECT_TRUE(toolbar_importer_unittest::kFolderArray[2] == - bookmarks[0].path[3]); - - // Test case 5 is parsing a single bookmark without a favicon URL. - bookmarks.clear(); - EXPECT_TRUE(reader.Load(toolbar_importer_unittest::kGoodBookmarkNoFavicon)); - EXPECT_TRUE(Toolbar5Importer::ParseBookmarksFromReader(&reader, &bookmarks)); - - EXPECT_EQ(1, bookmarks.size()); - EXPECT_FALSE(bookmarks[0].in_toolbar); - EXPECT_EQ(toolbar_importer_unittest::kTitle, bookmarks[0].title); - EXPECT_EQ(bookmarks[0].url, url); - EXPECT_EQ(2, bookmarks[0].path.size()); - EXPECT_EQ(toolbar_importer_unittest::kFolder, bookmarks[0].path[1]); - - // Test case 6 is parsing two bookmarks. - bookmarks.clear(); - EXPECT_TRUE(reader.Load(toolbar_importer_unittest::kGoodBookmark2Items)); - EXPECT_TRUE(Toolbar5Importer::ParseBookmarksFromReader(&reader, &bookmarks)); - - EXPECT_EQ(2, bookmarks.size()); - EXPECT_FALSE(bookmarks[0].in_toolbar); - EXPECT_FALSE(bookmarks[1].in_toolbar); - EXPECT_EQ(toolbar_importer_unittest::kTitle, bookmarks[0].title); - EXPECT_EQ(toolbar_importer_unittest::kOtherTitle, bookmarks[1].title); - EXPECT_EQ(bookmarks[0].url, url); - EXPECT_EQ(bookmarks[1].url, other_url); - EXPECT_EQ(2, bookmarks[0].path.size()); - EXPECT_EQ(toolbar_importer_unittest::kFolder, bookmarks[0].path[1]); - EXPECT_EQ(2, bookmarks[0].path.size()); - EXPECT_EQ(toolbar_importer_unittest::kOtherFolder, bookmarks[1].path[1]); - - // Test case 7 is parsing an empty string for bookmarks. - bookmarks.clear(); - - EXPECT_FALSE(reader.Load(toolbar_importer_unittest::kEmptyString)); - - // Test case 8 is testing the error when no <bookmarks> section is present. - bookmarks.clear(); - EXPECT_TRUE(reader.Load(toolbar_importer_unittest::kBadBookmarkNoBookmarks)); - EXPECT_FALSE(Toolbar5Importer::ParseBookmarksFromReader(&reader, &bookmarks)); - - // Test case 9 tests when no <bookmark> section is present. - bookmarks.clear(); - EXPECT_TRUE(reader.Load(toolbar_importer_unittest::kBadBookmarkNoBookmark)); - EXPECT_FALSE(Toolbar5Importer::ParseBookmarksFromReader(&reader, &bookmarks)); - - - // Test case 10 tests when a bookmark has no <title> section. - bookmarks.clear(); - EXPECT_TRUE(reader.Load(toolbar_importer_unittest::kBadBookmarkNoTitle)); - EXPECT_FALSE(Toolbar5Importer::ParseBookmarksFromReader(&reader, &bookmarks)); - - - // Test case 11 tests when a bookmark has no <url> section. - bookmarks.clear(); - EXPECT_TRUE(reader.Load(toolbar_importer_unittest::kBadBookmarkNoUrl)); - EXPECT_FALSE(Toolbar5Importer::ParseBookmarksFromReader(&reader, &bookmarks)); - - // Test case 12 tests when a bookmark has no <timestamp> section. - bookmarks.clear(); - EXPECT_TRUE(reader.Load(toolbar_importer_unittest::kBadBookmarkNoTimestamp)); - EXPECT_FALSE(Toolbar5Importer::ParseBookmarksFromReader(&reader, &bookmarks)); - - // Test case 13 tests when a bookmark has no <labels> section. - bookmarks.clear(); - EXPECT_TRUE(reader.Load(toolbar_importer_unittest::kBadBookmarkNoLabels)); - EXPECT_FALSE(Toolbar5Importer::ParseBookmarksFromReader(&reader, &bookmarks)); -} |