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

Side by Side Diff: chrome/browser/sessions/session_service_unittest.cc

Issue 225303016: Elim kRestorePopups (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 years, 8 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 unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « chrome/browser/sessions/session_service.cc ('k') | chrome/browser/ui/browser_window_state.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "base/bind.h" 5 #include "base/bind.h"
6 #include "base/bind_helpers.h" 6 #include "base/bind_helpers.h"
7 #include "base/file_util.h" 7 #include "base/file_util.h"
8 #include "base/files/scoped_temp_dir.h" 8 #include "base/files/scoped_temp_dir.h"
9 #include "base/memory/scoped_ptr.h" 9 #include "base/memory/scoped_ptr.h"
10 #include "base/memory/scoped_vector.h" 10 #include "base/memory/scoped_vector.h"
(...skipping 469 matching lines...) Expand 10 before | Expand all | Expand 10 after
480 ASSERT_EQ(window_id.id(), windows[0]->window_id.id()); 480 ASSERT_EQ(window_id.id(), windows[0]->window_id.id());
481 ASSERT_EQ(1U, windows[0]->tabs.size()); 481 ASSERT_EQ(1U, windows[0]->tabs.size());
482 482
483 SessionTab* tab = windows[0]->tabs[0]; 483 SessionTab* tab = windows[0]->tabs[0];
484 helper_.AssertTabEquals(window_id, tab_id, 0, 0, 1, *tab); 484 helper_.AssertTabEquals(window_id, tab_id, 0, 0, 1, *tab);
485 helper_.AssertNavigationEquals(nav1, tab->navigations[0]); 485 helper_.AssertNavigationEquals(nav1, tab->navigations[0]);
486 } 486 }
487 487
488 // Makes sure we don't track popups. 488 // Makes sure we don't track popups.
489 TEST_F(SessionServiceTest, IgnorePopups) { 489 TEST_F(SessionServiceTest, IgnorePopups) {
490 if (browser_defaults::kRestorePopups)
491 return; // This test is only applicable if popups aren't restored.
492
493 SessionID window2_id; 490 SessionID window2_id;
494 SessionID tab_id; 491 SessionID tab_id;
495 SessionID tab2_id; 492 SessionID tab2_id;
496 ASSERT_NE(window2_id.id(), window_id.id()); 493 ASSERT_NE(window2_id.id(), window_id.id());
497 494
498 service()->SetWindowType( 495 service()->SetWindowType(
499 window2_id, Browser::TYPE_POPUP, SessionService::TYPE_NORMAL); 496 window2_id, Browser::TYPE_POPUP, SessionService::TYPE_NORMAL);
500 service()->SetWindowBounds(window2_id, 497 service()->SetWindowBounds(window2_id,
501 window_bounds, 498 window_bounds,
502 ui::SHOW_STATE_NORMAL); 499 ui::SHOW_STATE_NORMAL);
(...skipping 17 matching lines...) Expand all
520 ASSERT_EQ(1U, windows.size()); 517 ASSERT_EQ(1U, windows.size());
521 ASSERT_EQ(0, windows[0]->selected_tab_index); 518 ASSERT_EQ(0, windows[0]->selected_tab_index);
522 ASSERT_EQ(window_id.id(), windows[0]->window_id.id()); 519 ASSERT_EQ(window_id.id(), windows[0]->window_id.id());
523 ASSERT_EQ(1U, windows[0]->tabs.size()); 520 ASSERT_EQ(1U, windows[0]->tabs.size());
524 521
525 SessionTab* tab = windows[0]->tabs[0]; 522 SessionTab* tab = windows[0]->tabs[0];
526 helper_.AssertTabEquals(window_id, tab_id, 0, 0, 1, *tab); 523 helper_.AssertTabEquals(window_id, tab_id, 0, 0, 1, *tab);
527 helper_.AssertNavigationEquals(nav1, tab->navigations[0]); 524 helper_.AssertNavigationEquals(nav1, tab->navigations[0]);
528 } 525 }
529 526
530 // Makes sure we track popups.
531 TEST_F(SessionServiceTest, RestorePopup) {
532 if (!browser_defaults::kRestorePopups)
533 return; // This test is only applicable if popups are restored.
534
535 SessionID window2_id;
536 SessionID tab_id;
537 SessionID tab2_id;
538 ASSERT_NE(window2_id.id(), window_id.id());
539
540 service()->SetWindowType(
541 window2_id, Browser::TYPE_POPUP, SessionService::TYPE_NORMAL);
542 service()->SetWindowBounds(window2_id,
543 window_bounds,
544 ui::SHOW_STATE_NORMAL);
545
546 SerializedNavigationEntry nav1 =
547 SerializedNavigationEntryTestHelper::CreateNavigation(
548 "http://google.com", "abc");
549 SerializedNavigationEntry nav2 =
550 SerializedNavigationEntryTestHelper::CreateNavigation(
551 "http://google2.com", "abcd");
552
553 helper_.PrepareTabInWindow(window_id, tab_id, 0, true);
554 UpdateNavigation(window_id, tab_id, nav1, true);
555
556 helper_.PrepareTabInWindow(window2_id, tab2_id, 0, false);
557 UpdateNavigation(window2_id, tab2_id, nav2, true);
558
559 ScopedVector<SessionWindow> windows;
560 ReadWindows(&(windows.get()), NULL);
561
562 ASSERT_EQ(2U, windows.size());
563 int tabbed_index = windows[0]->type == Browser::TYPE_TABBED ?
564 0 : 1;
565 int popup_index = tabbed_index == 0 ? 1 : 0;
566 ASSERT_EQ(0, windows[tabbed_index]->selected_tab_index);
567 ASSERT_EQ(window_id.id(), windows[tabbed_index]->window_id.id());
568 ASSERT_EQ(1U, windows[tabbed_index]->tabs.size());
569
570 SessionTab* tab = windows[tabbed_index]->tabs[0];
571 helper_.AssertTabEquals(window_id, tab_id, 0, 0, 1, *tab);
572 helper_.AssertNavigationEquals(nav1, tab->navigations[0]);
573
574 ASSERT_EQ(0, windows[popup_index]->selected_tab_index);
575 ASSERT_EQ(window2_id.id(), windows[popup_index]->window_id.id());
576 ASSERT_EQ(1U, windows[popup_index]->tabs.size());
577
578 tab = windows[popup_index]->tabs[0];
579 helper_.AssertTabEquals(window2_id, tab2_id, 0, 0, 1, *tab);
580 helper_.AssertNavigationEquals(nav2, tab->navigations[0]);
581 }
582
583 #if defined (OS_CHROMEOS) 527 #if defined (OS_CHROMEOS)
584 // Makes sure we track apps. Only applicable on chromeos. 528 // Makes sure we track apps. Only applicable on chromeos.
585 TEST_F(SessionServiceTest, RestoreApp) { 529 TEST_F(SessionServiceTest, RestoreApp) {
586 SessionID window2_id; 530 SessionID window2_id;
587 SessionID tab_id; 531 SessionID tab_id;
588 SessionID tab2_id; 532 SessionID tab2_id;
589 ASSERT_NE(window2_id.id(), window_id.id()); 533 ASSERT_NE(window2_id.id(), window_id.id());
590 534
591 service()->SetWindowType( 535 service()->SetWindowType(
592 window2_id, Browser::TYPE_POPUP, SessionService::TYPE_APP); 536 window2_id, Browser::TYPE_POPUP, SessionService::TYPE_APP);
(...skipping 455 matching lines...) Expand 10 before | Expand all | Expand 10 after
1048 992
1049 ASSERT_EQ(1U, windows.size()); 993 ASSERT_EQ(1U, windows.size());
1050 ASSERT_EQ(0, windows[0]->selected_tab_index); 994 ASSERT_EQ(0, windows[0]->selected_tab_index);
1051 ASSERT_EQ(window_id.id(), windows[0]->window_id.id()); 995 ASSERT_EQ(window_id.id(), windows[0]->window_id.id());
1052 ASSERT_EQ(1U, windows[0]->tabs.size()); 996 ASSERT_EQ(1U, windows[0]->tabs.size());
1053 997
1054 SessionTab* tab = windows[0]->tabs[0]; 998 SessionTab* tab = windows[0]->tabs[0];
1055 helper_.AssertTabEquals(window_id, tab_id, 0, 0, 1, *tab); 999 helper_.AssertTabEquals(window_id, tab_id, 0, 0, 1, *tab);
1056 helper_.AssertNavigationEquals(nav1, tab->navigations[0]); 1000 helper_.AssertNavigationEquals(nav1, tab->navigations[0]);
1057 } 1001 }
OLDNEW
« no previous file with comments | « chrome/browser/sessions/session_service.cc ('k') | chrome/browser/ui/browser_window_state.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698