| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/run_loop.h" | 5 #include "base/run_loop.h" |
| 6 #include "chrome/browser/extensions/extension_browsertest.h" | 6 #include "chrome/browser/extensions/extension_browsertest.h" |
| 7 #include "chrome/browser/ui/views/frame/browser_view.h" | 7 #include "chrome/browser/ui/views/frame/browser_view.h" |
| 8 #include "chrome/browser/ui/views/frame/test_with_browser_view.h" | 8 #include "chrome/browser/ui/views/frame/test_with_browser_view.h" |
| 9 #include "chrome/browser/ui/views/tabs/tab_drag_controller_interactive_uitest.h" | 9 #include "chrome/browser/ui/views/tabs/tab_drag_controller_interactive_uitest.h" |
| 10 #include "chrome/browser/ui/views/toolbar/browser_actions_container.h" | 10 #include "chrome/browser/ui/views/toolbar/browser_actions_container.h" |
| (...skipping 30 matching lines...) Expand all Loading... |
| 41 // DoDragAndDrop. | 41 // DoDragAndDrop. |
| 42 void TestWhileInDragOperation(); | 42 void TestWhileInDragOperation(); |
| 43 | 43 |
| 44 private: | 44 private: |
| 45 // Finishes the drag-and-drop operation started in DoDragAndDrop(). | 45 // Finishes the drag-and-drop operation started in DoDragAndDrop(). |
| 46 void FinishDragAndDrop(const base::Closure& quit_closure); | 46 void FinishDragAndDrop(const base::Closure& quit_closure); |
| 47 | 47 |
| 48 // InProcessBrowserTest: | 48 // InProcessBrowserTest: |
| 49 virtual void SetUpCommandLine(base::CommandLine* command_line) OVERRIDE; | 49 virtual void SetUpCommandLine(base::CommandLine* command_line) OVERRIDE; |
| 50 virtual void SetUpOnMainThread() OVERRIDE; | 50 virtual void SetUpOnMainThread() OVERRIDE; |
| 51 virtual void TearDownOnMainThread() OVERRIDE; |
| 51 | 52 |
| 52 ToolbarView* toolbar_view_; | 53 ToolbarView* toolbar_view_; |
| 53 | 54 |
| 54 BrowserActionsContainer* browser_actions_; | 55 BrowserActionsContainer* browser_actions_; |
| 55 | 56 |
| 56 // The drag-and-drop background thread. | 57 // The drag-and-drop background thread. |
| 57 scoped_ptr<base::Thread> dnd_thread_; | 58 scoped_ptr<base::Thread> dnd_thread_; |
| 58 | 59 |
| 59 // Override the extensions-action-redesign switch. | 60 // Override the extensions-action-redesign switch. |
| 60 scoped_ptr<extensions::FeatureSwitch::ScopedOverride> feature_override_; | 61 scoped_ptr<extensions::FeatureSwitch::ScopedOverride> feature_override_; |
| (...skipping 57 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 118 quit_closure); | 119 quit_closure); |
| 119 } | 120 } |
| 120 | 121 |
| 121 void ToolbarViewInteractiveUITest::SetUpCommandLine( | 122 void ToolbarViewInteractiveUITest::SetUpCommandLine( |
| 122 base::CommandLine* command_line) { | 123 base::CommandLine* command_line) { |
| 123 ExtensionBrowserTest::SetUpCommandLine(command_line); | 124 ExtensionBrowserTest::SetUpCommandLine(command_line); |
| 124 // We do this before the rest of the setup because it can affect how the views | 125 // We do this before the rest of the setup because it can affect how the views |
| 125 // are constructed. | 126 // are constructed. |
| 126 feature_override_.reset(new extensions::FeatureSwitch::ScopedOverride( | 127 feature_override_.reset(new extensions::FeatureSwitch::ScopedOverride( |
| 127 extensions::FeatureSwitch::extension_action_redesign(), true)); | 128 extensions::FeatureSwitch::extension_action_redesign(), true)); |
| 129 BrowserActionsContainer::disable_animations_during_testing_ = true; |
| 130 WrenchToolbarButton::g_open_wrench_immediately_for_testing = true; |
| 128 } | 131 } |
| 129 | 132 |
| 130 void ToolbarViewInteractiveUITest::SetUpOnMainThread() { | 133 void ToolbarViewInteractiveUITest::SetUpOnMainThread() { |
| 131 ExtensionBrowserTest::SetUpOnMainThread(); | 134 ExtensionBrowserTest::SetUpOnMainThread(); |
| 132 | 135 |
| 133 toolbar_view_ = BrowserView::GetBrowserViewForBrowser(browser())->toolbar(); | 136 toolbar_view_ = BrowserView::GetBrowserViewForBrowser(browser())->toolbar(); |
| 134 browser_actions_ = toolbar_view_->browser_actions(); | 137 browser_actions_ = toolbar_view_->browser_actions(); |
| 135 } | 138 } |
| 136 | 139 |
| 140 void ToolbarViewInteractiveUITest::TearDownOnMainThread() { |
| 141 BrowserActionsContainer::disable_animations_during_testing_ = false; |
| 142 WrenchToolbarButton::g_open_wrench_immediately_for_testing = false; |
| 143 } |
| 144 |
| 137 IN_PROC_BROWSER_TEST_F(ToolbarViewInteractiveUITest, | 145 IN_PROC_BROWSER_TEST_F(ToolbarViewInteractiveUITest, |
| 138 MAYBE(TestWrenchMenuOpensOnDrag)) { | 146 MAYBE(TestWrenchMenuOpensOnDrag)) { |
| 139 BrowserActionsContainer::disable_animations_during_testing_ = true; | |
| 140 WrenchToolbarButton::g_open_wrench_immediately_for_testing = true; | |
| 141 | |
| 142 // Load an extension that has a browser action. | 147 // Load an extension that has a browser action. |
| 143 ASSERT_TRUE(LoadExtension(test_data_dir_.AppendASCII("api_test") | 148 ASSERT_TRUE(LoadExtension(test_data_dir_.AppendASCII("api_test") |
| 144 .AppendASCII("browser_action") | 149 .AppendASCII("browser_action") |
| 145 .AppendASCII("basics"))); | 150 .AppendASCII("basics"))); |
| 146 base::RunLoop().RunUntilIdle(); // Ensure the extension is fully loaded. | 151 base::RunLoop().RunUntilIdle(); // Ensure the extension is fully loaded. |
| 147 | 152 |
| 148 ASSERT_EQ(1u, browser_actions()->VisibleBrowserActions()); | 153 ASSERT_EQ(1u, browser_actions()->VisibleBrowserActions()); |
| 149 | 154 |
| 150 BrowserActionView* view = browser_actions()->GetBrowserActionViewAt(0); | 155 BrowserActionView* view = browser_actions()->GetBrowserActionViewAt(0); |
| 151 ASSERT_TRUE(view); | 156 ASSERT_TRUE(view); |
| 152 | 157 |
| 153 gfx::Point browser_action_view_loc = test::GetCenterInScreenCoordinates(view); | 158 gfx::Point browser_action_view_loc = test::GetCenterInScreenCoordinates(view); |
| 154 gfx::Point wrench_button_loc = | 159 gfx::Point wrench_button_loc = |
| 155 test::GetCenterInScreenCoordinates(toolbar_view()->app_menu()); | 160 test::GetCenterInScreenCoordinates(toolbar_view()->app_menu()); |
| 156 | 161 |
| 157 // Perform a drag and drop from the browser action view to the wrench button, | 162 // Perform a drag and drop from the browser action view to the wrench button, |
| 158 // which should open the wrench menu. | 163 // which should open the wrench menu. |
| 159 DoDragAndDrop(browser_action_view_loc, wrench_button_loc); | 164 DoDragAndDrop(browser_action_view_loc, wrench_button_loc); |
| 160 } | 165 } |
| OLD | NEW |