| OLD | NEW |
| 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 Loading... |
| 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 Loading... |
| 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 Loading... |
| 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 } |
| OLD | NEW |