| Index: chrome/test/ui/mouseleave_uitest.cc
|
| ===================================================================
|
| --- chrome/test/ui/mouseleave_uitest.cc (revision 0)
|
| +++ chrome/test/ui/mouseleave_uitest.cc (revision 0)
|
| @@ -0,0 +1,99 @@
|
| +// Copyright (c) 2009 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/command_line.h"
|
| +#include "base/file_util.h"
|
| +#include "base/gfx/point.h"
|
| +#include "base/gfx/rect.h"
|
| +#include "base/path_service.h"
|
| +#include "base/string_util.h"
|
| +#include "base/values.h"
|
| +#include "chrome/browser/view_ids.h"
|
| +#include "chrome/common/chrome_paths.h"
|
| +#include "chrome/common/chrome_switches.h"
|
| +#include "chrome/test/automation/browser_proxy.h"
|
| +#include "chrome/test/automation/tab_proxy.h"
|
| +#include "chrome/test/automation/window_proxy.h"
|
| +#include "chrome/test/ui/javascript_test_util.h"
|
| +#include "chrome/test/ui/ui_test.h"
|
| +#include "googleurl/src/gurl.h"
|
| +#include "net/base/net_util.h"
|
| +#include "views/event.h"
|
| +
|
| +#if defined(OS_MACOSX)
|
| +// window->GetViewBounds is not implemented
|
| +// window->SimulateOSMouseMove is not implemented
|
| +// http://code.google.com/p/chromium/issues/detail?id=26102
|
| +#define MAYBE_TestOnMouseOut DISABLED_TestOnMouseOut
|
| +#elif defined(OS_WIN)
|
| +// Test succeeds locally, flaky on trybot
|
| +// http://code.google.com/p/chromium/issues/detail?id=26349
|
| +#define MAYBE_TestOnMouseOut DISABLED_TestOnMouseOut
|
| +#endif
|
| +
|
| +namespace {
|
| +
|
| +class MouseLeaveTest : public UITest {
|
| + public:
|
| + MouseLeaveTest() {
|
| + dom_automation_enabled_ = true;
|
| + show_window_ = true;
|
| + }
|
| +
|
| + DISALLOW_COPY_AND_ASSIGN(MouseLeaveTest);
|
| +};
|
| +
|
| +TEST_F(MouseLeaveTest, MAYBE_TestOnMouseOut) {
|
| + GURL test_url = GetTestUrl(L"", L"mouseleave.html");
|
| +
|
| + scoped_refptr<TabProxy> tab(GetActiveTab());
|
| + ASSERT_TRUE(tab.get());
|
| + scoped_refptr<BrowserProxy> browser = automation()->GetBrowserWindow(0);
|
| + scoped_refptr<WindowProxy> window = browser->GetWindow();
|
| +
|
| + gfx::Rect tab_view_bounds;
|
| + ASSERT_TRUE(window->GetViewBounds(VIEW_ID_TAB_CONTAINER, &tab_view_bounds,
|
| + true));
|
| + gfx::Point in_content_point(
|
| + tab_view_bounds.x() + tab_view_bounds.width() / 2,
|
| + tab_view_bounds.y() + 10);
|
| + gfx::Point above_content_point(
|
| + tab_view_bounds.x() + tab_view_bounds.width() / 2,
|
| + tab_view_bounds.y() - 2);
|
| +
|
| + // Start by moving the point just above the content.
|
| + ASSERT_TRUE(window->SimulateOSMouseMove(above_content_point));
|
| +
|
| + // Navigate to the test html page.
|
| + tab->NavigateToURL(test_url);
|
| +
|
| + const int timeout_ms = 5 * action_max_timeout_ms();
|
| + const int check_interval_ms = action_max_timeout_ms() / 10;
|
| +
|
| + // Wait for the onload() handler to complete so we can do the
|
| + // next part of the test.
|
| + ASSERT_TRUE(WaitUntilCookieValue(
|
| + tab.get(), test_url, "__state", check_interval_ms, timeout_ms,
|
| + "initial"));
|
| +
|
| + // Move the cursor to the top-center of the content, which will trigger
|
| + // a javascript onMouseOver event.
|
| + ASSERT_TRUE(window->SimulateOSMouseMove(in_content_point));
|
| +
|
| + // Wait on the correct intermediate value of the cookie.
|
| + ASSERT_TRUE(WaitUntilCookieValue(
|
| + tab.get(), test_url, "__state", check_interval_ms, timeout_ms,
|
| + "initial,entered"));
|
| +
|
| + // Move the cursor above the content again, which should trigger
|
| + // a javascript onMouseOut event.
|
| + ASSERT_TRUE(window->SimulateOSMouseMove(above_content_point));
|
| +
|
| + // Wait on the correct final value of the cookie.
|
| + ASSERT_TRUE(WaitUntilCookieValue(
|
| + tab.get(), test_url, "__state", check_interval_ms, timeout_ms,
|
| + "initial,entered,left"));
|
| +}
|
| +
|
| +} // namespace
|
|
|
| Property changes on: chrome/test/ui/mouseleave_uitest.cc
|
| ___________________________________________________________________
|
| Added: svn:eol-style
|
| + LF
|
|
|
|
|