| Index: trunk/src/chrome/browser/ui/views/toolbar/toolbar_view_interactive_uitest.cc
|
| ===================================================================
|
| --- trunk/src/chrome/browser/ui/views/toolbar/toolbar_view_interactive_uitest.cc (revision 285300)
|
| +++ trunk/src/chrome/browser/ui/views/toolbar/toolbar_view_interactive_uitest.cc (working copy)
|
| @@ -1,157 +0,0 @@
|
| -// Copyright 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/run_loop.h"
|
| -#include "chrome/browser/extensions/extension_browsertest.h"
|
| -#include "chrome/browser/ui/views/frame/browser_view.h"
|
| -#include "chrome/browser/ui/views/frame/test_with_browser_view.h"
|
| -#include "chrome/browser/ui/views/tabs/tab_drag_controller_interactive_uitest.h"
|
| -#include "chrome/browser/ui/views/toolbar/browser_actions_container.h"
|
| -#include "chrome/browser/ui/views/toolbar/toolbar_view.h"
|
| -#include "chrome/browser/ui/views/toolbar/wrench_toolbar_button.h"
|
| -#include "chrome/test/base/interactive_test_utils.h"
|
| -#include "extensions/common/feature_switch.h"
|
| -
|
| -// Borrowed from chrome/browser/ui/views/bookmarks/bookmark_bar_view_test.cc,
|
| -// since these are also disabled on Linux for drag and drop.
|
| -// TODO(erg): Fix DND tests on linux_aura. crbug.com/163931
|
| -#if defined(OS_LINUX) && defined(USE_AURA)
|
| -#define MAYBE(x) DISABLED_##x
|
| -#else
|
| -#define MAYBE(x) x
|
| -#endif
|
| -
|
| -class ToolbarViewInteractiveUITest : public ExtensionBrowserTest {
|
| - public:
|
| - ToolbarViewInteractiveUITest();
|
| - virtual ~ToolbarViewInteractiveUITest();
|
| -
|
| - protected:
|
| - ToolbarView* toolbar_view() { return toolbar_view_; }
|
| - BrowserActionsContainer* browser_actions() { return browser_actions_; }
|
| -
|
| - // Performs a drag-and-drop operation by moving the mouse to |start|, clicking
|
| - // the left button, moving the mouse to |end|, and releasing the left button.
|
| - // TestWhileInDragOperation() is called after the mouse has moved to |end|,
|
| - // but before the click is released.
|
| - void DoDragAndDrop(const gfx::Point& start, const gfx::Point& end);
|
| -
|
| - // A function to perform testing actions while in the drag operation from
|
| - // DoDragAndDrop.
|
| - void TestWhileInDragOperation();
|
| -
|
| - private:
|
| - // Finishes the drag-and-drop operation started in DoDragAndDrop().
|
| - void FinishDragAndDrop(const base::Closure& quit_closure);
|
| -
|
| - // InProcessBrowserTest:
|
| - virtual void SetUpCommandLine(base::CommandLine* command_line) OVERRIDE;
|
| - virtual void SetUpOnMainThread() OVERRIDE;
|
| -
|
| - ToolbarView* toolbar_view_;
|
| -
|
| - BrowserActionsContainer* browser_actions_;
|
| -
|
| - // The drag-and-drop background thread.
|
| - scoped_ptr<base::Thread> dnd_thread_;
|
| -
|
| - // Override the extensions-action-redesign switch.
|
| - scoped_ptr<extensions::FeatureSwitch::ScopedOverride> feature_override_;
|
| -};
|
| -
|
| -ToolbarViewInteractiveUITest::ToolbarViewInteractiveUITest()
|
| - : toolbar_view_(NULL),
|
| - browser_actions_(NULL) {
|
| -}
|
| -
|
| -ToolbarViewInteractiveUITest::~ToolbarViewInteractiveUITest() {
|
| -}
|
| -
|
| -void ToolbarViewInteractiveUITest::DoDragAndDrop(const gfx::Point& start,
|
| - const gfx::Point& end) {
|
| - // Much of this function is modeled after methods in ViewEventTestBase (in
|
| - // particular, the |dnd_thread_|, but it's easier to move that here than try
|
| - // to make ViewEventTestBase play nice with a BrowserView (for the toolbar).
|
| - // TODO(devlin): In a perfect world, this would be factored better.
|
| -
|
| - // Send the mouse to |start|, and click.
|
| - ASSERT_TRUE(ui_test_utils::SendMouseMoveSync(start));
|
| - ASSERT_TRUE(ui_test_utils::SendMouseEventsSync(
|
| - ui_controls::LEFT, ui_controls::DOWN));
|
| -
|
| - scoped_refptr<content::MessageLoopRunner> runner =
|
| - new content::MessageLoopRunner();
|
| -
|
| - ui_controls::SendMouseMoveNotifyWhenDone(
|
| - end.x() + 10,
|
| - end.y(),
|
| - base::Bind(&ToolbarViewInteractiveUITest::FinishDragAndDrop,
|
| - base::Unretained(this),
|
| - runner->QuitClosure()));
|
| -
|
| - // Also post a move task to the drag and drop thread.
|
| - if (!dnd_thread_.get()) {
|
| - dnd_thread_.reset(new base::Thread("mouse_move_thread"));
|
| - dnd_thread_->Start();
|
| - }
|
| -
|
| - dnd_thread_->message_loop()->PostDelayedTask(
|
| - FROM_HERE,
|
| - base::Bind(base::IgnoreResult(&ui_controls::SendMouseMove),
|
| - end.x(),
|
| - end.y()),
|
| - base::TimeDelta::FromMilliseconds(200));
|
| - runner->Run();
|
| -}
|
| -
|
| -void ToolbarViewInteractiveUITest::TestWhileInDragOperation() {
|
| - EXPECT_TRUE(toolbar_view()->IsWrenchMenuShowing());
|
| -}
|
| -
|
| -void ToolbarViewInteractiveUITest::FinishDragAndDrop(
|
| - const base::Closure& quit_closure) {
|
| - dnd_thread_.reset();
|
| - TestWhileInDragOperation();
|
| - ui_controls::SendMouseEvents(ui_controls::LEFT, ui_controls::UP);
|
| - ui_controls::RunClosureAfterAllPendingUIEvents(
|
| - quit_closure);
|
| -}
|
| -
|
| -void ToolbarViewInteractiveUITest::SetUpCommandLine(
|
| - base::CommandLine* command_line) {
|
| - ExtensionBrowserTest::SetUpCommandLine(command_line);
|
| - // We do this before the rest of the setup because it can affect how the views
|
| - // are constructed.
|
| - feature_override_.reset(new extensions::FeatureSwitch::ScopedOverride(
|
| - extensions::FeatureSwitch::extension_action_redesign(), true));
|
| -}
|
| -
|
| -void ToolbarViewInteractiveUITest::SetUpOnMainThread() {
|
| - ExtensionBrowserTest::SetUpOnMainThread();
|
| -
|
| - toolbar_view_ = BrowserView::GetBrowserViewForBrowser(browser())->toolbar();
|
| - browser_actions_ = toolbar_view_->browser_actions();
|
| -}
|
| -
|
| -IN_PROC_BROWSER_TEST_F(ToolbarViewInteractiveUITest,
|
| - MAYBE(TestWrenchMenuOpensOnDrag)) {
|
| - WrenchToolbarButton::g_open_wrench_immediately_for_testing = true;
|
| -
|
| - // Load an extension that has a browser action.
|
| - ASSERT_TRUE(LoadExtension(test_data_dir_.AppendASCII("api_test")
|
| - .AppendASCII("browser_action")
|
| - .AppendASCII("basics")));
|
| - ASSERT_EQ(1u, browser_actions()->VisibleBrowserActions());
|
| -
|
| - BrowserActionView* view = browser_actions()->GetBrowserActionViewAt(0);
|
| - ASSERT_TRUE(view);
|
| -
|
| - gfx::Point browser_action_view_loc = test::GetCenterInScreenCoordinates(view);
|
| - gfx::Point wrench_button_loc =
|
| - test::GetCenterInScreenCoordinates(toolbar_view()->app_menu());
|
| -
|
| - // Perform a drag and drop from the browser action view to the wrench button,
|
| - // which should open the wrench menu.
|
| - DoDragAndDrop(browser_action_view_loc, wrench_button_loc);
|
| -}
|
|
|