diff options
Diffstat (limited to 'chromium/components/sessions/serialized_navigation_entry_unittest.cc')
| -rw-r--r-- | chromium/components/sessions/serialized_navigation_entry_unittest.cc | 290 |
1 files changed, 290 insertions, 0 deletions
diff --git a/chromium/components/sessions/serialized_navigation_entry_unittest.cc b/chromium/components/sessions/serialized_navigation_entry_unittest.cc new file mode 100644 index 00000000000..5f052fe23e7 --- /dev/null +++ b/chromium/components/sessions/serialized_navigation_entry_unittest.cc @@ -0,0 +1,290 @@ +// 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 "components/sessions/serialized_navigation_entry.h" + +#include <cstddef> +#include <string> + +#include "base/basictypes.h" +#include "base/memory/scoped_ptr.h" +#include "base/pickle.h" +#include "base/strings/string16.h" +#include "base/strings/string_number_conversions.h" +#include "base/strings/utf_string_conversions.h" +#include "base/time/time.h" +#include "content/public/browser/favicon_status.h" +#include "content/public/browser/navigation_entry.h" +#include "content/public/common/page_transition_types.h" +#include "content/public/common/referrer.h" +#include "sync/protocol/session_specifics.pb.h" +#include "sync/util/time.h" +#include "testing/gtest/include/gtest/gtest.h" +#include "third_party/WebKit/public/platform/WebReferrerPolicy.h" +#include "url/gurl.h" + +namespace sessions { +namespace { + +const int kIndex = 3; +const int kUniqueID = 50; +const content::Referrer kReferrer = + content::Referrer(GURL("http://www.referrer.com"), + WebKit::WebReferrerPolicyAlways); +const GURL kVirtualURL("http://www.virtual-url.com"); +const string16 kTitle = ASCIIToUTF16("title"); +const content::PageState kPageState = + content::PageState::CreateFromEncodedData("page state"); +const content::PageTransition kTransitionType = + static_cast<content::PageTransition>( + content::PAGE_TRANSITION_AUTO_SUBFRAME | + content::PAGE_TRANSITION_HOME_PAGE | + content::PAGE_TRANSITION_CLIENT_REDIRECT); +const bool kHasPostData = true; +const int64 kPostID = 100; +const GURL kOriginalRequestURL("http://www.original-request.com"); +const bool kIsOverridingUserAgent = true; +const base::Time kTimestamp = syncer::ProtoTimeToTime(100); +const string16 kSearchTerms = ASCIIToUTF16("my search terms"); +const GURL kFaviconURL("http://virtual-url.com/favicon.ico"); + +const int kPageID = 10; + +// Create a NavigationEntry from the constants above. +scoped_ptr<content::NavigationEntry> MakeNavigationEntryForTest() { + scoped_ptr<content::NavigationEntry> navigation_entry( + content::NavigationEntry::Create()); + navigation_entry->SetReferrer(kReferrer); + navigation_entry->SetVirtualURL(kVirtualURL); + navigation_entry->SetTitle(kTitle); + navigation_entry->SetPageState(kPageState); + navigation_entry->SetTransitionType(kTransitionType); + navigation_entry->SetHasPostData(kHasPostData); + navigation_entry->SetPostID(kPostID); + navigation_entry->SetOriginalRequestURL(kOriginalRequestURL); + navigation_entry->SetIsOverridingUserAgent(kIsOverridingUserAgent); + navigation_entry->SetTimestamp(kTimestamp); + navigation_entry->SetExtraData(kSearchTermsKey, kSearchTerms); + navigation_entry->GetFavicon().valid = true; + navigation_entry->GetFavicon().url = kFaviconURL; + return navigation_entry.Pass(); +} + +// Create a sync_pb::TabNavigation from the constants above. +sync_pb::TabNavigation MakeSyncDataForTest() { + sync_pb::TabNavigation sync_data; + sync_data.set_virtual_url(kVirtualURL.spec()); + sync_data.set_referrer(kReferrer.url.spec()); + sync_data.set_title(UTF16ToUTF8(kTitle)); + sync_data.set_state(kPageState.ToEncodedData()); + sync_data.set_page_transition( + sync_pb::SyncEnums_PageTransition_AUTO_SUBFRAME); + sync_data.set_unique_id(kUniqueID); + sync_data.set_timestamp_msec(syncer::TimeToProtoTime(kTimestamp)); + sync_data.set_redirect_type(sync_pb::SyncEnums::CLIENT_REDIRECT); + sync_data.set_navigation_home_page(true); + sync_data.set_search_terms(UTF16ToUTF8(kSearchTerms)); + sync_data.set_favicon_url(kFaviconURL.spec()); + return sync_data; +} + +// Create a default SerializedNavigationEntry. All its fields should be +// initialized to their respective default values. +TEST(SerializedNavigationEntryTest, DefaultInitializer) { + const SerializedNavigationEntry navigation; + EXPECT_EQ(-1, navigation.index()); + EXPECT_EQ(0, navigation.unique_id()); + EXPECT_EQ(GURL(), navigation.referrer().url); + EXPECT_EQ(WebKit::WebReferrerPolicyDefault, navigation.referrer().policy); + EXPECT_EQ(GURL(), navigation.virtual_url()); + EXPECT_TRUE(navigation.title().empty()); + EXPECT_FALSE(navigation.page_state().IsValid()); + EXPECT_EQ(content::PAGE_TRANSITION_TYPED, navigation.transition_type()); + EXPECT_FALSE(navigation.has_post_data()); + EXPECT_EQ(-1, navigation.post_id()); + EXPECT_EQ(GURL(), navigation.original_request_url()); + EXPECT_FALSE(navigation.is_overriding_user_agent()); + EXPECT_TRUE(navigation.timestamp().is_null()); + EXPECT_TRUE(navigation.search_terms().empty()); + EXPECT_FALSE(navigation.favicon_url().is_valid()); +} + +// Create a SerializedNavigationEntry from a NavigationEntry. All its fields +// should match the NavigationEntry's. +TEST(SerializedNavigationEntryTest, FromNavigationEntry) { + const scoped_ptr<content::NavigationEntry> navigation_entry( + MakeNavigationEntryForTest()); + + const SerializedNavigationEntry& navigation = + SerializedNavigationEntry::FromNavigationEntry(kIndex, *navigation_entry); + + EXPECT_EQ(kIndex, navigation.index()); + + EXPECT_EQ(navigation_entry->GetUniqueID(), navigation.unique_id()); + EXPECT_EQ(kReferrer.url, navigation.referrer().url); + EXPECT_EQ(kReferrer.policy, navigation.referrer().policy); + EXPECT_EQ(kVirtualURL, navigation.virtual_url()); + EXPECT_EQ(kTitle, navigation.title()); + EXPECT_EQ(kPageState, navigation.page_state()); + EXPECT_EQ(kTransitionType, navigation.transition_type()); + EXPECT_EQ(kHasPostData, navigation.has_post_data()); + EXPECT_EQ(kPostID, navigation.post_id()); + EXPECT_EQ(kOriginalRequestURL, navigation.original_request_url()); + EXPECT_EQ(kIsOverridingUserAgent, navigation.is_overriding_user_agent()); + EXPECT_EQ(kTimestamp, navigation.timestamp()); + EXPECT_EQ(kFaviconURL, navigation.favicon_url()); +} + +// Create a SerializedNavigationEntry from a sync_pb::TabNavigation. All its +// fields should match the protocol buffer's if it exists there, and +// sbould be set to the default value otherwise. +TEST(SerializedNavigationEntryTest, FromSyncData) { + const sync_pb::TabNavigation sync_data = MakeSyncDataForTest(); + + const SerializedNavigationEntry& navigation = + SerializedNavigationEntry::FromSyncData(kIndex, sync_data); + + EXPECT_EQ(kIndex, navigation.index()); + EXPECT_EQ(kUniqueID, navigation.unique_id()); + EXPECT_EQ(kReferrer.url, navigation.referrer().url); + EXPECT_EQ(WebKit::WebReferrerPolicyDefault, navigation.referrer().policy); + EXPECT_EQ(kVirtualURL, navigation.virtual_url()); + EXPECT_EQ(kTitle, navigation.title()); + EXPECT_EQ(kPageState, navigation.page_state()); + EXPECT_EQ(kTransitionType, navigation.transition_type()); + EXPECT_FALSE(navigation.has_post_data()); + EXPECT_EQ(-1, navigation.post_id()); + EXPECT_EQ(GURL(), navigation.original_request_url()); + EXPECT_FALSE(navigation.is_overriding_user_agent()); + EXPECT_TRUE(navigation.timestamp().is_null()); + EXPECT_EQ(kSearchTerms, navigation.search_terms()); + EXPECT_EQ(kFaviconURL, navigation.favicon_url()); +} + +// Create a SerializedNavigationEntry, pickle it, then create another one by +// unpickling. The new one should match the old one except for fields +// that aren't pickled, which should be set to default values. +TEST(SerializedNavigationEntryTest, Pickle) { + const SerializedNavigationEntry& old_navigation = + SerializedNavigationEntry::FromNavigationEntry( + kIndex, *MakeNavigationEntryForTest()); + + Pickle pickle; + old_navigation.WriteToPickle(30000, &pickle); + + SerializedNavigationEntry new_navigation; + PickleIterator pickle_iterator(pickle); + EXPECT_TRUE(new_navigation.ReadFromPickle(&pickle_iterator)); + + EXPECT_EQ(kIndex, new_navigation.index()); + + EXPECT_EQ(0, new_navigation.unique_id()); + EXPECT_EQ(kReferrer.url, new_navigation.referrer().url); + EXPECT_EQ(kReferrer.policy, new_navigation.referrer().policy); + EXPECT_EQ(kVirtualURL, new_navigation.virtual_url()); + EXPECT_EQ(kTitle, new_navigation.title()); + EXPECT_FALSE(new_navigation.page_state().IsValid()); + EXPECT_EQ(kTransitionType, new_navigation.transition_type()); + EXPECT_EQ(kHasPostData, new_navigation.has_post_data()); + EXPECT_EQ(-1, new_navigation.post_id()); + EXPECT_EQ(kOriginalRequestURL, new_navigation.original_request_url()); + EXPECT_EQ(kIsOverridingUserAgent, new_navigation.is_overriding_user_agent()); + EXPECT_EQ(kTimestamp, new_navigation.timestamp()); + EXPECT_EQ(kSearchTerms, new_navigation.search_terms()); +} + +// Create a NavigationEntry, then create another one by converting to +// a SerializedNavigationEntry and back. The new one should match the old one +// except for fields that aren't preserved, which should be set to +// expected values. +TEST(SerializedNavigationEntryTest, ToNavigationEntry) { + const scoped_ptr<content::NavigationEntry> old_navigation_entry( + MakeNavigationEntryForTest()); + + const SerializedNavigationEntry& navigation = + SerializedNavigationEntry::FromNavigationEntry(kIndex, + *old_navigation_entry); + + const scoped_ptr<content::NavigationEntry> new_navigation_entry( + navigation.ToNavigationEntry(kPageID, NULL)); + + EXPECT_EQ(kReferrer.url, new_navigation_entry->GetReferrer().url); + EXPECT_EQ(kReferrer.policy, new_navigation_entry->GetReferrer().policy); + EXPECT_EQ(kVirtualURL, new_navigation_entry->GetVirtualURL()); + EXPECT_EQ(kTitle, new_navigation_entry->GetTitle()); + EXPECT_EQ(kPageState, new_navigation_entry->GetPageState()); + EXPECT_EQ(kPageID, new_navigation_entry->GetPageID()); + EXPECT_EQ(content::PAGE_TRANSITION_RELOAD, + new_navigation_entry->GetTransitionType()); + EXPECT_EQ(kHasPostData, new_navigation_entry->GetHasPostData()); + EXPECT_EQ(kPostID, new_navigation_entry->GetPostID()); + EXPECT_EQ(kOriginalRequestURL, + new_navigation_entry->GetOriginalRequestURL()); + EXPECT_EQ(kIsOverridingUserAgent, + new_navigation_entry->GetIsOverridingUserAgent()); + string16 search_terms; + new_navigation_entry->GetExtraData(kSearchTermsKey, &search_terms); + EXPECT_EQ(kSearchTerms, search_terms); +} + +// Create a NavigationEntry, convert it to a SerializedNavigationEntry, then +// create a sync protocol buffer from it. The protocol buffer should +// have matching fields to the NavigationEntry (when applicable). +TEST(SerializedNavigationEntryTest, ToSyncData) { + const scoped_ptr<content::NavigationEntry> navigation_entry( + MakeNavigationEntryForTest()); + + const SerializedNavigationEntry& navigation = + SerializedNavigationEntry::FromNavigationEntry(kIndex, *navigation_entry); + + const sync_pb::TabNavigation sync_data = navigation.ToSyncData(); + + EXPECT_EQ(kVirtualURL.spec(), sync_data.virtual_url()); + EXPECT_EQ(kReferrer.url.spec(), sync_data.referrer()); + EXPECT_EQ(kTitle, ASCIIToUTF16(sync_data.title())); + EXPECT_TRUE(sync_data.state().empty()); + EXPECT_EQ(sync_pb::SyncEnums_PageTransition_AUTO_SUBFRAME, + sync_data.page_transition()); + EXPECT_TRUE(sync_data.has_redirect_type()); + EXPECT_EQ(navigation_entry->GetUniqueID(), sync_data.unique_id()); + EXPECT_EQ(syncer::TimeToProtoTime(kTimestamp), sync_data.timestamp_msec()); + EXPECT_EQ(kTimestamp.ToInternalValue(), sync_data.global_id()); + EXPECT_EQ(kFaviconURL.spec(), sync_data.favicon_url()); +} + +// Ensure all transition types and qualifiers are converted to/from the sync +// SerializedNavigationEntry representation properly. +TEST(SerializedNavigationEntryTest, TransitionTypes) { + scoped_ptr<content::NavigationEntry> navigation_entry( + MakeNavigationEntryForTest()); + for (uint32 core_type = content::PAGE_TRANSITION_LINK; + core_type != content::PAGE_TRANSITION_LAST_CORE; ++core_type) { + // Because qualifier is a uint32, left shifting will eventually overflow + // and hit zero again. SERVER_REDIRECT, as the last qualifier and also + // in place of the sign bit, is therefore the last transition before + // breaking. + for (uint32 qualifier = content::PAGE_TRANSITION_FORWARD_BACK; + qualifier != 0; qualifier <<= 1) { + if (qualifier == 0x08000000) + continue; // 0x08000000 is not a valid qualifier. + content::PageTransition transition = + static_cast<content::PageTransition>(core_type | qualifier); + + navigation_entry->SetTransitionType(transition); + const SerializedNavigationEntry& navigation = + SerializedNavigationEntry::FromNavigationEntry(kIndex, + *navigation_entry); + const sync_pb::TabNavigation& sync_data = navigation.ToSyncData(); + const SerializedNavigationEntry& constructed_nav = + SerializedNavigationEntry::FromSyncData(kIndex, sync_data); + const content::PageTransition constructed_transition = + constructed_nav.transition_type(); + + EXPECT_EQ(transition, constructed_transition); + } + } +} + +} // namespace +} // namespace sessions |
