Chromium Code Reviews| 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 "ash/wm/maximize_mode/maximize_mode_controller.h" | 5 #include "ash/wm/maximize_mode/maximize_mode_controller.h" |
| 6 | 6 |
| 7 #include "ash/accelerometer/accelerometer_controller.h" | 7 #include "ash/accelerometer/accelerometer_controller.h" |
| 8 #include "ash/display/display_manager.h" | 8 #include "ash/display/display_manager.h" |
| 9 #include "ash/shell.h" | 9 #include "ash/shell.h" |
| 10 #include "ash/system/tray/system_tray_delegate.h" | 10 #include "ash/system/tray/system_tray_delegate.h" |
| 11 #include "ash/test/ash_test_base.h" | 11 #include "ash/test/ash_test_base.h" |
| 12 #include "ash/test/display_manager_test_api.h" | 12 #include "ash/test/display_manager_test_api.h" |
| 13 #include "ash/test/test_lock_state_controller_delegate.h" | 13 #include "ash/test/test_lock_state_controller_delegate.h" |
| 14 #include "ash/test/test_screenshot_delegate.h" | 14 #include "ash/test/test_screenshot_delegate.h" |
| 15 #include "ash/test/test_system_tray_delegate.h" | 15 #include "ash/test/test_system_tray_delegate.h" |
| 16 #include "ash/test/test_volume_control_delegate.h" | 16 #include "ash/test/test_volume_control_delegate.h" |
| 17 #include "ash/wm/maximize_mode/internal_input_device_list.h" | 17 #include "ash/wm/maximize_mode/internal_input_device_list.h" |
| 18 #include "ash/wm/maximize_mode/maximize_mode_event_blocker.h" | 18 #include "ash/wm/maximize_mode/maximize_mode_event_blocker.h" |
| 19 #include "ui/aura/test/event_generator.h" | 19 #include "ui/aura/test/event_generator.h" |
| 20 #include "ui/events/event_handler.h" | 20 #include "ui/events/event_handler.h" |
| 21 #include "ui/events/test/events_test_utils_x11.h" | |
| 21 #include "ui/gfx/vector3d_f.h" | 22 #include "ui/gfx/vector3d_f.h" |
| 22 #include "ui/message_center/message_center.h" | 23 #include "ui/message_center/message_center.h" |
| 23 | 24 |
| 24 namespace ash { | 25 namespace ash { |
| 25 | 26 |
| 26 namespace { | 27 namespace { |
| 27 | 28 |
| 28 const float kDegreesToRadians = 3.14159265f / 180.0f; | 29 const float kDegreesToRadians = 3.14159265f / 180.0f; |
| 29 | 30 |
| 30 // Filter to count the number of events seen. | 31 // Filter to count the number of events seen. |
| (...skipping 378 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 409 event_generator.ReleaseKey(ui::VKEY_POWER, 0); | 410 event_generator.ReleaseKey(ui::VKEY_POWER, 0); |
| 410 EXPECT_EQ(0, delegate->handle_take_screenshot_count()); | 411 EXPECT_EQ(0, delegate->handle_take_screenshot_count()); |
| 411 | 412 |
| 412 // Holding volume down and pressing power takes a screenshot. | 413 // Holding volume down and pressing power takes a screenshot. |
| 413 event_generator.PressKey(ui::VKEY_VOLUME_DOWN, 0); | 414 event_generator.PressKey(ui::VKEY_VOLUME_DOWN, 0); |
| 414 event_generator.PressKey(ui::VKEY_POWER, 0); | 415 event_generator.PressKey(ui::VKEY_POWER, 0); |
| 415 event_generator.ReleaseKey(ui::VKEY_POWER, 0); | 416 event_generator.ReleaseKey(ui::VKEY_POWER, 0); |
| 416 EXPECT_EQ(1, delegate->handle_take_screenshot_count()); | 417 EXPECT_EQ(1, delegate->handle_take_screenshot_count()); |
| 417 event_generator.ReleaseKey(ui::VKEY_VOLUME_DOWN, 0); | 418 event_generator.ReleaseKey(ui::VKEY_VOLUME_DOWN, 0); |
| 418 } | 419 } |
| 419 #endif // OS_CHROMEOS | |
| 420 | 420 |
| 421 // Tests that maximize mode does not block Volume Up & Down events. | 421 // Tests that maximize mode does not block Volume Up & Down events. |
|
jonross
2014/05/23 18:48:49
Update description to clarify that this differenti
bruthig
2014/05/23 19:50:07
Done.
| |
| 422 TEST_F(MaximizeModeControllerTest, AllowsVolumeControl) { | 422 TEST_F(MaximizeModeControllerTest, AllowsVolumeControl) { |
| 423 aura::Window* root = Shell::GetPrimaryRootWindow(); | 423 aura::Window* root = Shell::GetPrimaryRootWindow(); |
| 424 aura::test::EventGenerator event_generator(root, root); | 424 aura::test::EventGenerator event_generator(root, root); |
| 425 | 425 |
| 426 TestVolumeControlDelegate* volume_delegate = | 426 TestVolumeControlDelegate* volume_delegate = |
| 427 new TestVolumeControlDelegate(true); | 427 new TestVolumeControlDelegate(true); |
| 428 ash::Shell::GetInstance()->system_tray_delegate()->SetVolumeControlDelegate( | 428 ash::Shell::GetInstance()->system_tray_delegate()->SetVolumeControlDelegate( |
| 429 scoped_ptr<VolumeControlDelegate>(volume_delegate).Pass()); | 429 scoped_ptr<VolumeControlDelegate>(volume_delegate).Pass()); |
| 430 | 430 |
| 431 // Trigger maximize mode by opening to 270 to begin the test in maximize mode. | 431 // Trigger maximize mode by opening to 270 to begin the test in maximize mode. |
| 432 TriggerAccelerometerUpdate(gfx::Vector3dF(0.0f, 0.0f, -1.0f), | 432 TriggerAccelerometerUpdate(gfx::Vector3dF(0.0f, 0.0f, -1.0f), |
| 433 gfx::Vector3dF(-1.0f, 0.0f, 0.0f)); | 433 gfx::Vector3dF(-1.0f, 0.0f, 0.0f)); |
| 434 ASSERT_TRUE(IsMaximizeModeStarted()); | 434 ASSERT_TRUE(IsMaximizeModeStarted()); |
| 435 | 435 |
| 436 ui::ScopedXI2Event xevent; | |
| 437 | |
| 438 // Verify F9 button event is blocked | |
| 439 ASSERT_EQ(0, volume_delegate->handle_volume_down_count()); | |
| 440 xevent.InitKeyEvent(ui::ET_KEY_PRESSED, ui::VKEY_VOLUME_DOWN, ui::EF_NONE); | |
| 441 ui::KeyEvent press_f9(xevent, false /*is_char*/); | |
| 442 press_f9.set_flags(ui::EF_FUNCTION_KEY); | |
| 443 event_generator.Dispatch(&press_f9); | |
| 444 EXPECT_EQ(0, volume_delegate->handle_volume_down_count()); | |
| 445 | |
| 446 // Verify F10 button event is blocked | |
| 447 ASSERT_EQ(0, volume_delegate->handle_volume_up_count()); | |
| 448 xevent.InitKeyEvent(ui::ET_KEY_PRESSED, ui::VKEY_VOLUME_UP, ui::EF_NONE); | |
| 449 ui::KeyEvent press_f10(xevent, false /*is_char*/); | |
| 450 press_f10.set_flags(ui::EF_FUNCTION_KEY); | |
| 451 event_generator.Dispatch(&press_f10); | |
| 452 EXPECT_EQ(0, volume_delegate->handle_volume_up_count()); | |
| 453 | |
| 436 // Verify volume down button event is not blocked | 454 // Verify volume down button event is not blocked |
| 437 ASSERT_EQ(0, volume_delegate->handle_volume_down_count()); | 455 ASSERT_EQ(0, volume_delegate->handle_volume_down_count()); |
| 438 event_generator.PressKey(ui::VKEY_VOLUME_DOWN, 0); | 456 xevent.InitKeyEvent(ui::ET_KEY_PRESSED, ui::VKEY_VOLUME_DOWN, ui::EF_NONE); |
| 439 event_generator.ReleaseKey(ui::VKEY_VOLUME_DOWN, 0); | 457 ui::KeyEvent press_vol_down(xevent, false /*is_char*/); |
| 458 event_generator.Dispatch(&press_vol_down); | |
| 440 EXPECT_EQ(1, volume_delegate->handle_volume_down_count()); | 459 EXPECT_EQ(1, volume_delegate->handle_volume_down_count()); |
| 441 | 460 |
| 442 // Verify volume up event is not blocked | 461 // Verify volume up event is not blocked |
| 443 ASSERT_EQ(0, volume_delegate->handle_volume_up_count()); | 462 ASSERT_EQ(0, volume_delegate->handle_volume_up_count()); |
| 444 event_generator.PressKey(ui::VKEY_VOLUME_UP, 0); | 463 xevent.InitKeyEvent(ui::ET_KEY_PRESSED, ui::VKEY_VOLUME_UP, ui::EF_NONE); |
| 445 event_generator.ReleaseKey(ui::VKEY_VOLUME_UP, 0); | 464 ui::KeyEvent press_vol_up(xevent, false /*is_char*/); |
| 465 event_generator.Dispatch(&press_vol_up); | |
| 446 EXPECT_EQ(1, volume_delegate->handle_volume_up_count()); | 466 EXPECT_EQ(1, volume_delegate->handle_volume_up_count()); |
| 447 } | 467 } |
| 468 #endif // OS_CHROMEOS | |
|
jonross
2014/05/23 18:48:49
I see this is being brought into chrome os. Is the
bruthig
2014/05/23 19:50:07
This is a chrome os specific test.
jonross
2014/05/26 13:55:41
Sounds good.
| |
| 448 | 469 |
| 449 TEST_F(MaximizeModeControllerTest, LaptopTest) { | 470 TEST_F(MaximizeModeControllerTest, LaptopTest) { |
| 450 // Feeds in sample accelerometer data and verifies that there are no | 471 // Feeds in sample accelerometer data and verifies that there are no |
| 451 // transitions into touchview / maximize mode while shaking the device around | 472 // transitions into touchview / maximize mode while shaking the device around |
| 452 // with the hinge at less than 180 degrees. | 473 // with the hinge at less than 180 degrees. |
| 453 ASSERT_TRUE(kAccelerometerLaptopModeTestDataLength % 6 == 0); | 474 ASSERT_TRUE(kAccelerometerLaptopModeTestDataLength % 6 == 0); |
| 454 for (size_t i = 0; i < kAccelerometerLaptopModeTestDataLength / 6; ++i) { | 475 for (size_t i = 0; i < kAccelerometerLaptopModeTestDataLength / 6; ++i) { |
| 455 gfx::Vector3dF base(kAccelerometerLaptopModeTestData[i * 6], | 476 gfx::Vector3dF base(kAccelerometerLaptopModeTestData[i * 6], |
| 456 kAccelerometerLaptopModeTestData[i * 6 + 1], | 477 kAccelerometerLaptopModeTestData[i * 6 + 1], |
| 457 kAccelerometerLaptopModeTestData[i * 6 + 2]); | 478 kAccelerometerLaptopModeTestData[i * 6 + 2]); |
| (...skipping 132 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 590 ASSERT_NE(gfx::Display::ROTATE_90, GetInternalDisplayRotation()); | 611 ASSERT_NE(gfx::Display::ROTATE_90, GetInternalDisplayRotation()); |
| 591 TriggerAccelerometerUpdate(gfx::Vector3dF(0.0f, 1.0f, 0.0f), | 612 TriggerAccelerometerUpdate(gfx::Vector3dF(0.0f, 1.0f, 0.0f), |
| 592 gfx::Vector3dF(0.0f, 1.0f, 0.0f)); | 613 gfx::Vector3dF(0.0f, 1.0f, 0.0f)); |
| 593 ASSERT_EQ(gfx::Display::ROTATE_90, GetInternalDisplayRotation()); | 614 ASSERT_EQ(gfx::Display::ROTATE_90, GetInternalDisplayRotation()); |
| 594 EXPECT_EQ(0u, message_center->NotificationCount()); | 615 EXPECT_EQ(0u, message_center->NotificationCount()); |
| 595 EXPECT_FALSE(message_center->HasPopupNotifications()); | 616 EXPECT_FALSE(message_center->HasPopupNotifications()); |
| 596 } | 617 } |
| 597 #endif | 618 #endif |
| 598 | 619 |
| 599 } // namespace ash | 620 } // namespace ash |
| OLD | NEW |