| OLD | NEW |
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 "chrome/browser/ui/ash/launcher/chrome_launcher_controller.h" | 5 #include "chrome/browser/ui/ash/launcher/chrome_launcher_controller.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 #include <string> | 8 #include <string> |
| 9 #include <vector> | 9 #include <vector> |
| 10 | 10 |
| 11 #include "ash/ash_switches.h" | 11 #include "ash/ash_switches.h" |
| 12 #include "ash/shelf/shelf_item_delegate_manager.h" | 12 #include "ash/shelf/shelf_item_delegate_manager.h" |
| 13 #include "ash/shelf/shelf_model.h" | 13 #include "ash/shelf/shelf_model.h" |
| 14 #include "ash/shelf/shelf_model_observer.h" | 14 #include "ash/shelf/shelf_model_observer.h" |
| 15 #include "ash/shell.h" | 15 #include "ash/shell.h" |
| 16 #include "ash/test/shelf_item_delegate_manager_test_api.h" | 16 #include "ash/test/shelf_item_delegate_manager_test_api.h" |
| 17 #include "base/command_line.h" | 17 #include "base/command_line.h" |
| 18 #include "base/compiler_specific.h" | 18 #include "base/compiler_specific.h" |
| 19 #include "base/files/file_path.h" | 19 #include "base/files/file_path.h" |
| 20 #include "base/memory/scoped_ptr.h" | 20 #include "base/memory/scoped_ptr.h" |
| 21 #include "base/message_loop/message_loop.h" | 21 #include "base/message_loop/message_loop.h" |
| 22 #include "base/strings/utf_string_conversions.h" | 22 #include "base/strings/utf_string_conversions.h" |
| 23 #include "base/values.h" | 23 #include "base/values.h" |
| 24 #include "chrome/browser/extensions/extension_service.h" | 24 #include "chrome/browser/extensions/extension_service.h" |
| 25 #include "chrome/browser/extensions/test_extension_system.h" | 25 #include "chrome/browser/extensions/test_extension_system.h" |
| 26 #include "chrome/browser/favicon/chrome_favicon_client_factory.h" |
| 26 #include "chrome/browser/ui/ash/chrome_launcher_prefs.h" | 27 #include "chrome/browser/ui/ash/chrome_launcher_prefs.h" |
| 27 #include "chrome/browser/ui/ash/launcher/app_window_launcher_item_controller.h" | 28 #include "chrome/browser/ui/ash/launcher/app_window_launcher_item_controller.h" |
| 28 #include "chrome/browser/ui/ash/launcher/launcher_application_menu_item_model.h" | 29 #include "chrome/browser/ui/ash/launcher/launcher_application_menu_item_model.h" |
| 29 #include "chrome/browser/ui/ash/launcher/launcher_item_controller.h" | 30 #include "chrome/browser/ui/ash/launcher/launcher_item_controller.h" |
| 30 #include "chrome/browser/ui/browser.h" | 31 #include "chrome/browser/ui/browser.h" |
| 31 #include "chrome/browser/ui/browser_commands.h" | 32 #include "chrome/browser/ui/browser_commands.h" |
| 32 #include "chrome/browser/ui/browser_finder.h" | 33 #include "chrome/browser/ui/browser_finder.h" |
| 33 #include "chrome/browser/ui/browser_list.h" | 34 #include "chrome/browser/ui/browser_list.h" |
| 34 #include "chrome/browser/ui/browser_tabstrip.h" | 35 #include "chrome/browser/ui/browser_tabstrip.h" |
| 35 #include "chrome/browser/ui/host_desktop.h" | 36 #include "chrome/browser/ui/host_desktop.h" |
| (...skipping 1948 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1984 // the active item is the first entry. | 1985 // the active item is the first entry. |
| 1985 base::string16 two_menu_items[] = {title1, title2}; | 1986 base::string16 two_menu_items[] = {title1, title2}; |
| 1986 EXPECT_TRUE(CheckMenuCreation( | 1987 EXPECT_TRUE(CheckMenuCreation( |
| 1987 launcher_controller_.get(), item_browser, 2, two_menu_items, true)); | 1988 launcher_controller_.get(), item_browser, 2, two_menu_items, true)); |
| 1988 | 1989 |
| 1989 // Apparently we have to close all tabs we have. | 1990 // Apparently we have to close all tabs we have. |
| 1990 chrome::CloseTab(browser2.get()); | 1991 chrome::CloseTab(browser2.get()); |
| 1991 } | 1992 } |
| 1992 | 1993 |
| 1993 #if defined(OS_CHROMEOS) | 1994 #if defined(OS_CHROMEOS) |
| 1995 static KeyedService* BuildChromeFaviconClient( |
| 1996 content::BrowserContext* profile) { |
| 1997 return new ChromeFaviconClient(static_cast<Profile*>(profile)); |
| 1998 } |
| 1999 |
| 1994 // Check the multi profile case where only user related browsers should show | 2000 // Check the multi profile case where only user related browsers should show |
| 1995 // up. | 2001 // up. |
| 1996 TEST_F(MultiProfileMultiBrowserShelfLayoutChromeLauncherControllerTest, | 2002 TEST_F(MultiProfileMultiBrowserShelfLayoutChromeLauncherControllerTest, |
| 1997 BrowserMenuGenerationTwoUsers) { | 2003 BrowserMenuGenerationTwoUsers) { |
| 1998 // Create a browser item in the LauncherController. | 2004 // Create a browser item in the LauncherController. |
| 1999 InitLauncherController(); | 2005 InitLauncherController(); |
| 2000 | 2006 |
| 2001 ash::ShelfItem item_browser; | 2007 ash::ShelfItem item_browser; |
| 2002 item_browser.type = ash::TYPE_BROWSER_SHORTCUT; | 2008 item_browser.type = ash::TYPE_BROWSER_SHORTCUT; |
| 2003 item_browser.id = | 2009 item_browser.id = |
| 2004 launcher_controller_->GetShelfIDForAppID(extension_misc::kChromeAppId); | 2010 launcher_controller_->GetShelfIDForAppID(extension_misc::kChromeAppId); |
| 2005 | 2011 |
| 2006 // Check that the menu is empty. | 2012 // Check that the menu is empty. |
| 2007 chrome::NewTab(browser()); | 2013 chrome::NewTab(browser()); |
| 2008 EXPECT_TRUE(CheckMenuCreation( | 2014 EXPECT_TRUE(CheckMenuCreation( |
| 2009 launcher_controller_.get(), item_browser, 0, NULL, true)); | 2015 launcher_controller_.get(), item_browser, 0, NULL, true)); |
| 2010 | 2016 |
| 2011 // Show the created |browser()| by adding it to the active browser list. | 2017 // Show the created |browser()| by adding it to the active browser list. |
| 2012 BrowserList::SetLastActive(browser()); | 2018 BrowserList::SetLastActive(browser()); |
| 2013 base::string16 title1 = ASCIIToUTF16("Test1"); | 2019 base::string16 title1 = ASCIIToUTF16("Test1"); |
| 2014 NavigateAndCommitActiveTabWithTitle(browser(), GURL("http://test1"), title1); | 2020 NavigateAndCommitActiveTabWithTitle(browser(), GURL("http://test1"), title1); |
| 2015 base::string16 one_menu_item1[] = { title1 }; | 2021 base::string16 one_menu_item1[] = { title1 }; |
| 2016 EXPECT_TRUE(CheckMenuCreation( | 2022 EXPECT_TRUE(CheckMenuCreation( |
| 2017 launcher_controller_.get(), item_browser, 1, one_menu_item1, true)); | 2023 launcher_controller_.get(), item_browser, 1, one_menu_item1, true)); |
| 2018 | 2024 |
| 2019 // Create a browser for another user and check that it is not included in the | 2025 // Create a browser for another user and check that it is not included in the |
| 2020 // users running browser list. | 2026 // users running browser list. |
| 2021 std::string user2 = "user2"; | 2027 std::string user2 = "user2"; |
| 2022 TestingProfile* profile2 = CreateMultiUserProfile(user2); | 2028 TestingProfile* profile2 = CreateMultiUserProfile(user2); |
| 2029 ChromeFaviconClientFactory::GetInstance()->SetTestingFactory( |
| 2030 profile2, BuildChromeFaviconClient); |
| 2023 scoped_ptr<Browser> browser2( | 2031 scoped_ptr<Browser> browser2( |
| 2024 CreateBrowserAndTabWithProfile(profile2, user2, "http://test2")); | 2032 CreateBrowserAndTabWithProfile(profile2, user2, "http://test2")); |
| 2025 base::string16 one_menu_item2[] = { ASCIIToUTF16(user2) }; | 2033 base::string16 one_menu_item2[] = { ASCIIToUTF16(user2) }; |
| 2026 EXPECT_TRUE(CheckMenuCreation( | 2034 EXPECT_TRUE(CheckMenuCreation( |
| 2027 launcher_controller_.get(), item_browser, 1, one_menu_item1, true)); | 2035 launcher_controller_.get(), item_browser, 1, one_menu_item1, true)); |
| 2028 | 2036 |
| 2029 // Switch to the other user and make sure that only that browser window gets | 2037 // Switch to the other user and make sure that only that browser window gets |
| 2030 // shown. | 2038 // shown. |
| 2031 SwitchActiveUser(profile2->GetProfileName()); | 2039 SwitchActiveUser(profile2->GetProfileName()); |
| 2032 EXPECT_TRUE(CheckMenuCreation( | 2040 EXPECT_TRUE(CheckMenuCreation( |
| (...skipping 659 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2692 | 2700 |
| 2693 EXPECT_EQ(1, app_icon_loader->fetch_count()); | 2701 EXPECT_EQ(1, app_icon_loader->fetch_count()); |
| 2694 ASSERT_EQ(initial_size + 1, model_->items().size()); | 2702 ASSERT_EQ(initial_size + 1, model_->items().size()); |
| 2695 EXPECT_TRUE(launcher_controller_->IsAppPinned("1")); | 2703 EXPECT_TRUE(launcher_controller_->IsAppPinned("1")); |
| 2696 EXPECT_FALSE(launcher_controller_->IsAppPinned("0")); | 2704 EXPECT_FALSE(launcher_controller_->IsAppPinned("0")); |
| 2697 EXPECT_EQ(ash::TYPE_APP_SHORTCUT, model_->items()[app_index].type); | 2705 EXPECT_EQ(ash::TYPE_APP_SHORTCUT, model_->items()[app_index].type); |
| 2698 | 2706 |
| 2699 launcher_controller_->UnpinAppWithID("1"); | 2707 launcher_controller_->UnpinAppWithID("1"); |
| 2700 ASSERT_EQ(initial_size, model_->items().size()); | 2708 ASSERT_EQ(initial_size, model_->items().size()); |
| 2701 } | 2709 } |
| OLD | NEW |