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

Unified Diff: chrome/browser/sessions/session_types_unittest.cc

Issue 10990012: [Sync] Refactor handling of session tabs (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Few more fixes Created 8 years, 3 months 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
Index: chrome/browser/sessions/session_types_unittest.cc
diff --git a/chrome/browser/sessions/session_types_unittest.cc b/chrome/browser/sessions/session_types_unittest.cc
index 0e8030ba57a7b21d16b80e4a71be7c86ca77807f..455ec4532002dc54e0d796a72174d308db1f71bf 100644
--- a/chrome/browser/sessions/session_types_unittest.cc
+++ b/chrome/browser/sessions/session_types_unittest.cc
@@ -9,6 +9,7 @@
#include "base/memory/scoped_ptr.h"
#include "base/pickle.h"
#include "base/string16.h"
+#include "base/string_number_conversions.h"
#include "base/time.h"
#include "base/utf_string_conversions.h"
#include "chrome/browser/sessions/session_types.h"
@@ -243,4 +244,94 @@ TEST(TabNavigationTest, ToSyncData) {
EXPECT_EQ(syncer::TimeToProtoTime(kTimestamp), sync_data.timestamp());
}
+// Create a typical SessionTab protocol buffer and set an existing
+// SessionTab from it. The data from the protocol buffer should
+// clobber the existing data.
+TEST(SessionTab, FromSyncData) {
+ sync_pb::SessionTab sync_data;
+ sync_data.set_tab_id(5);
+ sync_data.set_window_id(10);
+ sync_data.set_tab_visual_index(13);
+ sync_data.set_current_navigation_index(3);
+ sync_data.set_pinned(true);
+ sync_data.set_extension_app_id("app_id");
+ for (int i = 0; i < 5; ++i) {
+ sync_pb::TabNavigation* navigation = sync_data.add_navigation();
+ navigation->set_virtual_url("http://foo/" + base::IntToString(i));
+ navigation->set_referrer("referrer");
+ navigation->set_title("title");
+ navigation->set_page_transition(sync_pb::SyncEnums_PageTransition_TYPED);
+ }
+
+ SessionTab tab;
+ tab.window_id.set_id(100);
+ tab.tab_id.set_id(100);
+ tab.tab_visual_index = 100;
+ tab.current_navigation_index = 1000;
+ tab.pinned = false;
+ tab.extension_app_id = "fake";
+ tab.user_agent_override = "fake";
+ tab.timestamp = base::Time::FromInternalValue(100);
+ tab.navigations.resize(100);
+ tab.session_storage_persistent_id = "fake";
+
+ tab.SetFromSyncData(sync_data, base::Time::FromInternalValue(5u));
+ EXPECT_EQ(10, tab.window_id.id());
+ EXPECT_EQ(5, tab.tab_id.id());
+ EXPECT_EQ(13, tab.tab_visual_index);
+ EXPECT_EQ(3, tab.current_navigation_index);
+ EXPECT_TRUE(tab.pinned);
+ EXPECT_EQ("app_id", tab.extension_app_id);
+ EXPECT_TRUE(tab.user_agent_override.empty());
+ EXPECT_EQ(5u, tab.timestamp.ToInternalValue());
+ ASSERT_EQ(5u, tab.navigations.size());
+ for (int i = 0; i < 5; ++i) {
+ EXPECT_EQ(i, tab.navigations[i].index());
+ EXPECT_EQ(GURL("referrer"),
+ SessionTypesTestHelper::GetReferrer(tab.navigations[i]).url);
+ EXPECT_EQ(string16(ASCIIToUTF16("title")), tab.navigations[i].title());
+ EXPECT_EQ(content::PAGE_TRANSITION_TYPED,
+ SessionTypesTestHelper::GetTransitionType(tab.navigations[i]));
+ EXPECT_EQ(GURL("http://foo/" + base::IntToString(i)),
+ tab.navigations[i].virtual_url());
+ }
+ EXPECT_TRUE(tab.session_storage_persistent_id.empty());
+}
+
+TEST(SessionTab, ToSyncData) {
+ SessionTab tab;
+ tab.window_id.set_id(10);
+ tab.tab_id.set_id(5);
+ tab.tab_visual_index = 13;
+ tab.current_navigation_index = 3;
+ tab.pinned = true;
+ tab.extension_app_id = "app_id";
+ tab.user_agent_override = "fake";
+ tab.timestamp = base::Time::FromInternalValue(100);
+ for (int i = 0; i < 5; ++i) {
+ tab.navigations.push_back(
+ SessionTypesTestHelper::CreateNavigation(
+ "http://foo/" + base::IntToString(i), "title"));
+ }
+ tab.session_storage_persistent_id = "fake";
+
+ const sync_pb::SessionTab& sync_data = tab.ToSyncData();
+ EXPECT_EQ(5, sync_data.tab_id());
+ EXPECT_EQ(10, sync_data.window_id());
+ EXPECT_EQ(13, sync_data.tab_visual_index());
+ EXPECT_EQ(3, sync_data.current_navigation_index());
+ EXPECT_TRUE(sync_data.pinned());
+ EXPECT_EQ("app_id", sync_data.extension_app_id());
+ ASSERT_EQ(5, sync_data.navigation_size());
+ for (int i = 0; i < 5; ++i) {
+ EXPECT_EQ(tab.navigations[i].virtual_url().spec(),
+ sync_data.navigation(i).virtual_url());
+ EXPECT_EQ(UTF16ToUTF8(tab.navigations[i].title()),
+ sync_data.navigation(i).title());
+ }
+ EXPECT_FALSE(sync_data.has_favicon());
+ EXPECT_FALSE(sync_data.has_favicon_type());
+ EXPECT_FALSE(sync_data.has_favicon_source());
+}
+
} // namespace

Powered by Google App Engine
This is Rietveld 408576698