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

Unified Diff: chrome/browser/ui/browser_tab_restore_uitest.cc

Issue 227043004: Restored tabs should set their initial visibility (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Add tests. 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | chrome/browser/ui/browser_tabrestore.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/ui/browser_tab_restore_uitest.cc
diff --git a/chrome/browser/ui/browser_tab_restore_uitest.cc b/chrome/browser/ui/browser_tab_restore_uitest.cc
new file mode 100644
index 0000000000000000000000000000000000000000..e5873ba7a651dab093d3c4c3f6ff4c57c7d05ddd
--- /dev/null
+++ b/chrome/browser/ui/browser_tab_restore_uitest.cc
@@ -0,0 +1,194 @@
+// Copyright (c) 2014 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 "base/strings/utf_string_conversions.h"
+#include "chrome/browser/chrome_notification_types.h"
+#include "chrome/browser/sessions/tab_restore_service.h"
+#include "chrome/browser/sessions/tab_restore_service_delegate.h"
+#include "chrome/browser/sessions/tab_restore_service_factory.h"
+#include "chrome/browser/ui/browser.h"
+#include "chrome/browser/ui/browser_commands.h"
+#include "chrome/browser/ui/browser_list.h"
+#include "chrome/browser/ui/tabs/tab_strip_model.h"
+#include "chrome/browser/ui/toolbar/recent_tabs_sub_menu_model.h"
+#include "chrome/test/base/in_process_browser_test.h"
+#include "chrome/test/base/interactive_test_utils.h"
+#include "content/public/browser/notification_service.h"
+#include "content/public/browser/web_contents.h"
+#include "content/public/test/browser_test_utils.h"
+
+typedef InProcessBrowserTest TabRestoreTest;
sky 2014/04/16 16:42:05 Make this match your file name, eg BrowserTabResto
+
+void AwaitTabsReady(TabStripModel* tab_strip_model) {
+ for (int i = 0; i < tab_strip_model->count(); ++i) {
+ content::WebContents* contents = tab_strip_model->GetWebContentsAt(i);
+ std::string title = base::UTF16ToUTF8(contents->GetTitle());
+ if (title == "about:blank")
+ continue;
+ bool window_ready = false;
+ const char kGetReadyJS[] = "window.domAutomationController.send("
+ "window.ready == undefined ? false : window.ready);";
+ EXPECT_TRUE(content::ExecuteScriptAndExtractBool(
+ contents, kGetReadyJS, &window_ready));
+ if (title.empty() || !window_ready) {
+ base::PlatformThread::YieldCurrentThread();
sky 2014/04/16 16:42:05 Don't do this. Add observers to wait for the condi
+ i = -1; // Start over.
+ }
+ }
+}
+
+void CheckVisbility(TabStripModel* tab_strip_model, int visible_index) {
+ for (int i = 0; i < tab_strip_model->count(); ++i) {
+ content::WebContents* contents = tab_strip_model->GetWebContentsAt(i);
+ std::string document_visibility_state;
+ const char kGetStateJS[] = "window.domAutomationController.send("
+ "window.document.visibilityState);";
+ EXPECT_TRUE(content::ExecuteScriptAndExtractString(
+ contents, kGetStateJS, &document_visibility_state));
+ if (i == visible_index) {
+ EXPECT_EQ("visible", document_visibility_state);
+ } else {
+ EXPECT_EQ("hidden", document_visibility_state);
+ }
+ }
+}
+
+void CreateTabs(Browser* browser) {
+ static GURL test_page(ui_test_utils::GetTestUrl(base::FilePath(),
+ base::FilePath(FILE_PATH_LITERAL("tab-restore-visibilty.html"))));
+ ui_test_utils::NavigateToURLWithDisposition(
+ browser, test_page, NEW_FOREGROUND_TAB,
+ ui_test_utils::BROWSER_TEST_WAIT_FOR_NAVIGATION);
+ ui_test_utils::NavigateToURLWithDisposition(
+ browser, test_page, NEW_BACKGROUND_TAB,
+ ui_test_utils::BROWSER_TEST_WAIT_FOR_NAVIGATION);
+}
+
+void CloseBrowser(Browser* browser) {
+ content::WindowedNotificationObserver observer(
+ chrome::NOTIFICATION_BROWSER_CLOSED,
+ content::Source<Browser>(browser));
+ chrome::CloseWindow(browser);
+ observer.Wait();
+}
+
+IN_PROC_BROWSER_TEST_F(TabRestoreTest, RecentTabsMenuTabDisposition) {
+ // Create tabs.
+ CreateTabs(browser());
+ TabStripModel* tab_strip_model= browser()->tab_strip_model();
+ ASSERT_EQ(3, tab_strip_model->count());
+ AwaitTabsReady(tab_strip_model);
+
+ // Create a new browser.
+ ui_test_utils::NavigateToURLWithDisposition(
+ browser(), GURL(), NEW_WINDOW,
+ ui_test_utils::BROWSER_TEST_WAIT_FOR_BROWSER);
+ BrowserList* active_browser_list =
+ BrowserList::GetInstance(chrome::GetActiveDesktop());
+ ASSERT_EQ(2u, active_browser_list->size());
+
+ // Close the first browser.
+ CloseBrowser(browser());
+ ASSERT_EQ(1u, active_browser_list->size());
+
+ // Restore tabs using current browser's recent tabs menu.
+ content::WindowedNotificationObserver browser_observer(
+ chrome::NOTIFICATION_BROWSER_WINDOW_READY,
+ content::NotificationService::AllSources());
+ content::WindowedNotificationObserver tab_added_observer(
+ chrome::NOTIFICATION_TAB_PARENTED,
+ content::NotificationService::AllSources());
+ content::WindowedNotificationObserver tab_loaded_observer(
+ content::NOTIFICATION_LOAD_STOP,
+ content::NotificationService::AllSources());
+
+ Browser* browser = active_browser_list->get(0);
+ RecentTabsSubMenuModel menu(NULL, browser, NULL);
+ menu.ExecuteCommand(
+ RecentTabsSubMenuModel::GetFirstRecentTabsCommandId(), 0);
+
+ // Await a new browser containing the restored tabs.
+ browser_observer.Wait();
+ tab_added_observer.Wait();
+ tab_loaded_observer.Wait();
+ ASSERT_EQ(2u, active_browser_list->size());
+
+ // The current browser should still have only 1 tab.
+ tab_strip_model = browser->tab_strip_model();
+ ASSERT_EQ(1, tab_strip_model->count());
+
+ // There should be 3 restored tabs in the new browser.
+ browser = active_browser_list->get(1);
+ tab_strip_model = browser->tab_strip_model();
+ ASSERT_EQ(3, tab_strip_model->count());
+
+ // Its middle tab only should have visibile disposition.
+ AwaitTabsReady(tab_strip_model);
+ CheckVisbility(tab_strip_model, 1);
+}
+
+IN_PROC_BROWSER_TEST_F(TabRestoreTest, RestoreDelegateTabDisposition) {
+ // Create tabs.
+ CreateTabs(browser());
+ TabStripModel* tab_strip_model= browser()->tab_strip_model();
+ ASSERT_EQ(3, tab_strip_model->count());
+ AwaitTabsReady(tab_strip_model);
+
+ // Create a new browser.
+ ui_test_utils::NavigateToURLWithDisposition(
+ browser(), GURL(), NEW_WINDOW,
+ ui_test_utils::BROWSER_TEST_WAIT_FOR_BROWSER);
+ BrowserList* active_browser_list =
+ BrowserList::GetInstance(chrome::GetActiveDesktop());
+ ASSERT_EQ(2u, active_browser_list->size());
+
+ // Close the first browser.
+ CloseBrowser(browser());
+ ASSERT_EQ(1u, active_browser_list->size());
+
+ // Check the current browser has a delegated restore service.
+ Browser* browser = active_browser_list->get(0);
+ TabRestoreService* service =
+ TabRestoreServiceFactory::GetForProfile(browser->profile());
+ bool has_tab_restore_service = !!service;
+ ASSERT_TRUE(has_tab_restore_service);
+ TabRestoreServiceDelegate* delegate =
+ TabRestoreServiceDelegate::FindDelegateForWebContents(
+ browser->tab_strip_model()->GetActiveWebContents());
+ bool has_tab_restore_delegate = !!delegate;
+ ASSERT_TRUE(has_tab_restore_delegate);
+
+ // Tab restore using the delegated restore service.
+ content::WindowedNotificationObserver browser_observer(
+ chrome::NOTIFICATION_BROWSER_WINDOW_READY,
+ content::NotificationService::AllSources());
+ content::WindowedNotificationObserver tab_added_observer(
+ chrome::NOTIFICATION_TAB_PARENTED,
+ content::NotificationService::AllSources());
+ content::WindowedNotificationObserver tab_loaded_observer(
+ content::NOTIFICATION_LOAD_STOP,
+ content::NotificationService::AllSources());
+
+ service->RestoreMostRecentEntry(
+ delegate, browser->host_desktop_type());
+
+ // Await a new browser containing the restored tabs.
+ browser_observer.Wait();
+ tab_added_observer.Wait();
+ tab_loaded_observer.Wait();
+ ASSERT_EQ(2u, active_browser_list->size());
+
+ // The current browser should still have only 1 tab.
+ tab_strip_model = browser->tab_strip_model();
+ ASSERT_EQ(1, tab_strip_model->count());
+
+ // There should be 3 restored tabs in the new browser.
+ browser = active_browser_list->get(1);
+ tab_strip_model = browser->tab_strip_model();
+ ASSERT_EQ(3, tab_strip_model->count());
+
+ // Its middle tab only should have visibile disposition.
+ AwaitTabsReady(tab_strip_model);
+ CheckVisbility(tab_strip_model, 1);
+}
« no previous file with comments | « no previous file | chrome/browser/ui/browser_tabrestore.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698