| OLD | NEW |
| 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 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 "ui/views/corewm/tooltip_controller.h" | 5 #include "ui/views/corewm/tooltip_controller.h" |
| 6 | 6 |
| 7 #include "base/strings/utf_string_conversions.h" | 7 #include "base/strings/utf_string_conversions.h" |
| 8 #include "ui/aura/client/cursor_client.h" | 8 #include "ui/aura/client/cursor_client.h" |
| 9 #include "ui/aura/client/screen_position_client.h" | 9 #include "ui/aura/client/screen_position_client.h" |
| 10 #include "ui/aura/env.h" | 10 #include "ui/aura/env.h" |
| 11 #include "ui/aura/test/aura_test_base.h" | 11 #include "ui/aura/test/aura_test_base.h" |
| 12 #include "ui/aura/test/test_screen.h" | 12 #include "ui/aura/test/test_screen.h" |
| 13 #include "ui/aura/test/test_window_delegate.h" | 13 #include "ui/aura/test/test_window_delegate.h" |
| 14 #include "ui/aura/window.h" | 14 #include "ui/aura/window.h" |
| 15 #include "ui/aura/window_event_dispatcher.h" | 15 #include "ui/aura/window_event_dispatcher.h" |
| 16 #include "ui/events/test/event_generator.h" | 16 #include "ui/events/test/event_generator.h" |
| 17 #include "ui/gfx/font.h" | 17 #include "ui/gfx/font.h" |
| 18 #include "ui/gfx/point.h" | 18 #include "ui/gfx/point.h" |
| 19 #include "ui/gfx/screen.h" | 19 #include "ui/gfx/screen.h" |
| 20 #include "ui/gfx/screen_type_delegate.h" | 20 #include "ui/gfx/screen_type_delegate.h" |
| 21 #include "ui/gfx/text_elider.h" | 21 #include "ui/gfx/text_elider.h" |
| 22 #include "ui/views/corewm/tooltip_aura.h" | 22 #include "ui/views/corewm/tooltip_aura.h" |
| 23 #include "ui/views/corewm/tooltip_controller_test_helper.h" | 23 #include "ui/views/corewm/tooltip_controller_test_helper.h" |
| 24 #include "ui/views/test/desktop_test_views_delegate.h" | 24 #include "ui/views/test/desktop_test_views_delegate.h" |
| 25 #include "ui/views/test/test_views_delegate.h" | 25 #include "ui/views/test/test_views_delegate.h" |
| 26 #include "ui/views/view.h" | 26 #include "ui/views/view.h" |
| 27 #include "ui/views/widget/tooltip_manager.h" | 27 #include "ui/views/widget/tooltip_manager.h" |
| 28 #include "ui/views/widget/widget.h" | 28 #include "ui/views/widget/widget.h" |
| 29 #include "ui/wm/core/default_activation_client.h" | 29 #include "ui/wm/core/default_activation_client.h" |
| 30 #include "ui/wm/core/default_screen_position_client.h" |
| 30 #include "ui/wm/core/wm_state.h" | 31 #include "ui/wm/core/wm_state.h" |
| 31 #include "ui/wm/public/tooltip_client.h" | 32 #include "ui/wm/public/tooltip_client.h" |
| 32 #include "ui/wm/public/window_types.h" | 33 #include "ui/wm/public/window_types.h" |
| 33 | 34 |
| 34 #if defined(OS_WIN) | 35 #if defined(OS_WIN) |
| 35 #include "ui/base/win/scoped_ole_initializer.h" | 36 #include "ui/base/win/scoped_ole_initializer.h" |
| 36 #endif | 37 #endif |
| 37 | 38 |
| 38 #if !defined(OS_CHROMEOS) | 39 #if !defined(OS_CHROMEOS) |
| 39 #include "ui/views/widget/desktop_aura/desktop_native_widget_aura.h" | 40 #include "ui/views/widget/desktop_aura/desktop_native_widget_aura.h" |
| (...skipping 364 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 404 // Returns the index of |window| in its parent's children. | 405 // Returns the index of |window| in its parent's children. |
| 405 int IndexInParent(const aura::Window* window) { | 406 int IndexInParent(const aura::Window* window) { |
| 406 aura::Window::Windows::const_iterator i = | 407 aura::Window::Windows::const_iterator i = |
| 407 std::find(window->parent()->children().begin(), | 408 std::find(window->parent()->children().begin(), |
| 408 window->parent()->children().end(), | 409 window->parent()->children().end(), |
| 409 window); | 410 window); |
| 410 return i == window->parent()->children().end() ? -1 : | 411 return i == window->parent()->children().end() ? -1 : |
| 411 static_cast<int>(i - window->parent()->children().begin()); | 412 static_cast<int>(i - window->parent()->children().begin()); |
| 412 } | 413 } |
| 413 | 414 |
| 414 class TestScreenPositionClient : public aura::client::ScreenPositionClient { | |
| 415 public: | |
| 416 TestScreenPositionClient() {} | |
| 417 ~TestScreenPositionClient() override {} | |
| 418 | |
| 419 // ScreenPositionClient overrides: | |
| 420 void ConvertPointToScreen(const aura::Window* window, | |
| 421 gfx::Point* point) override {} | |
| 422 void ConvertPointFromScreen(const aura::Window* window, | |
| 423 gfx::Point* point) override {} | |
| 424 void ConvertHostPointToScreen(aura::Window* root_gwindow, | |
| 425 gfx::Point* point) override { | |
| 426 NOTREACHED(); | |
| 427 } | |
| 428 void SetBounds(aura::Window* window, | |
| 429 const gfx::Rect& bounds, | |
| 430 const gfx::Display& display) override { | |
| 431 window->SetBounds(bounds); | |
| 432 } | |
| 433 | |
| 434 private: | |
| 435 DISALLOW_COPY_AND_ASSIGN(TestScreenPositionClient); | |
| 436 }; | |
| 437 | |
| 438 } // namespace | 415 } // namespace |
| 439 | 416 |
| 440 class TooltipControllerCaptureTest : public TooltipControllerTest { | 417 class TooltipControllerCaptureTest : public TooltipControllerTest { |
| 441 public: | 418 public: |
| 442 TooltipControllerCaptureTest() {} | 419 TooltipControllerCaptureTest() {} |
| 443 ~TooltipControllerCaptureTest() override {} | 420 ~TooltipControllerCaptureTest() override {} |
| 444 | 421 |
| 445 void SetUp() override { | 422 void SetUp() override { |
| 446 TooltipControllerTest::SetUp(); | 423 TooltipControllerTest::SetUp(); |
| 447 aura::client::SetScreenPositionClient(GetRootWindow(), | 424 aura::client::SetScreenPositionClient(GetRootWindow(), |
| 448 &screen_position_client_); | 425 &screen_position_client_); |
| 449 #if !defined(OS_CHROMEOS) | 426 #if !defined(OS_CHROMEOS) |
| 450 desktop_screen_.reset(CreateDesktopScreen()); | 427 desktop_screen_.reset(CreateDesktopScreen()); |
| 451 gfx::Screen::SetScreenInstance(gfx::SCREEN_TYPE_NATIVE, | 428 gfx::Screen::SetScreenInstance(gfx::SCREEN_TYPE_NATIVE, |
| 452 desktop_screen_.get()); | 429 desktop_screen_.get()); |
| 453 #endif | 430 #endif |
| 454 } | 431 } |
| 455 | 432 |
| 456 void TearDown() override { | 433 void TearDown() override { |
| 457 #if !defined(OS_CHROMEOS) | 434 #if !defined(OS_CHROMEOS) |
| 458 gfx::Screen::SetScreenInstance(gfx::SCREEN_TYPE_NATIVE, test_screen()); | 435 gfx::Screen::SetScreenInstance(gfx::SCREEN_TYPE_NATIVE, test_screen()); |
| 459 desktop_screen_.reset(); | 436 desktop_screen_.reset(); |
| 460 #endif | 437 #endif |
| 461 aura::client::SetScreenPositionClient(GetRootWindow(), NULL); | 438 aura::client::SetScreenPositionClient(GetRootWindow(), NULL); |
| 462 TooltipControllerTest::TearDown(); | 439 TooltipControllerTest::TearDown(); |
| 463 } | 440 } |
| 464 | 441 |
| 465 private: | 442 private: |
| 466 TestScreenPositionClient screen_position_client_; | 443 wm::DefaultScreenPositionClient screen_position_client_; |
| 467 scoped_ptr<gfx::Screen> desktop_screen_; | 444 scoped_ptr<gfx::Screen> desktop_screen_; |
| 468 | 445 |
| 469 DISALLOW_COPY_AND_ASSIGN(TooltipControllerCaptureTest); | 446 DISALLOW_COPY_AND_ASSIGN(TooltipControllerCaptureTest); |
| 470 }; | 447 }; |
| 471 | 448 |
| 472 // Verifies when capture is released the TooltipController resets state. | 449 // Verifies when capture is released the TooltipController resets state. |
| 473 // Flaky on all builders. http://crbug.com/388268 | 450 // Flaky on all builders. http://crbug.com/388268 |
| 474 TEST_F(TooltipControllerCaptureTest, DISABLED_CloseOnCaptureLost) { | 451 TEST_F(TooltipControllerCaptureTest, DISABLED_CloseOnCaptureLost) { |
| 475 view_->GetWidget()->SetCapture(view_); | 452 view_->GetWidget()->SetCapture(view_); |
| 476 RunAllPendingInMessageLoop(); | 453 RunAllPendingInMessageLoop(); |
| (...skipping 338 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 815 helper_->FireTooltipTimer(); | 792 helper_->FireTooltipTimer(); |
| 816 tooltip_bounds1 = test_tooltip_->location(); | 793 tooltip_bounds1 = test_tooltip_->location(); |
| 817 | 794 |
| 818 EXPECT_NE(tooltip_bounds1_1, tooltip_bounds1); | 795 EXPECT_NE(tooltip_bounds1_1, tooltip_bounds1); |
| 819 EXPECT_EQ(reference_string, helper_->GetTooltipText()); | 796 EXPECT_EQ(reference_string, helper_->GetTooltipText()); |
| 820 } | 797 } |
| 821 | 798 |
| 822 } // namespace test | 799 } // namespace test |
| 823 } // namespace corewm | 800 } // namespace corewm |
| 824 } // namespace views | 801 } // namespace views |
| OLD | NEW |