| 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/test/ash_test_base.h" | 10 #include "ash/test/ash_test_base.h" |
| (...skipping 130 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 141 EXPECT_TRUE(IsMaximizeModeStarted()); | 141 EXPECT_TRUE(IsMaximizeModeStarted()); |
| 142 | 142 |
| 143 // Open 90 degrees. | 143 // Open 90 degrees. |
| 144 TriggerAccelerometerUpdate(base, gfx::Vector3dF(-1.0f, 0.0f, 0.0f)); | 144 TriggerAccelerometerUpdate(base, gfx::Vector3dF(-1.0f, 0.0f, 0.0f)); |
| 145 EXPECT_FALSE(IsMaximizeModeStarted()); | 145 EXPECT_FALSE(IsMaximizeModeStarted()); |
| 146 } | 146 } |
| 147 | 147 |
| 148 // Tests that when the hinge is nearly vertically aligned, the current state | 148 // Tests that when the hinge is nearly vertically aligned, the current state |
| 149 // persists as the computed angle is highly inaccurate in this orientation. | 149 // persists as the computed angle is highly inaccurate in this orientation. |
| 150 TEST_F(MaximizeModeControllerTest, HingeAligned) { | 150 TEST_F(MaximizeModeControllerTest, HingeAligned) { |
| 151 // Laptop in normal orientation lid open 90 degrees. | 151 // Laptop in normal orientation lid open 90 degrees. |
| 152 TriggerAccelerometerUpdate(gfx::Vector3dF(0.0f, 0.0f, 1.0f), | 152 TriggerAccelerometerUpdate(gfx::Vector3dF(0.0f, 0.0f, 1.0f), |
| 153 gfx::Vector3dF(-1.0f, 0.0f, 0.0f)); | 153 gfx::Vector3dF(-1.0f, 0.0f, 0.0f)); |
| 154 EXPECT_FALSE(IsMaximizeModeStarted()); | 154 EXPECT_FALSE(IsMaximizeModeStarted()); |
| 155 | 155 |
| 156 // Completely vertical. | 156 // Completely vertical. |
| 157 TriggerAccelerometerUpdate(gfx::Vector3dF(0.0f, -1.0f, 0.0f), | 157 TriggerAccelerometerUpdate(gfx::Vector3dF(0.0f, -1.0f, 0.0f), |
| 158 gfx::Vector3dF(0.0f, -1.0f, 0.0f)); | 158 gfx::Vector3dF(0.0f, -1.0f, 0.0f)); |
| 159 EXPECT_FALSE(IsMaximizeModeStarted()); | 159 EXPECT_FALSE(IsMaximizeModeStarted()); |
| 160 | 160 |
| 161 // Close to vertical but with hinge appearing to be open 270 degrees. | 161 // Close to vertical but with hinge appearing to be open 270 degrees. |
| (...skipping 140 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 302 // Open up 270 degrees. | 302 // Open up 270 degrees. |
| 303 TriggerAccelerometerUpdate(gfx::Vector3dF(0.0f, 0.0f, 1.0f), | 303 TriggerAccelerometerUpdate(gfx::Vector3dF(0.0f, 0.0f, 1.0f), |
| 304 gfx::Vector3dF(1.0f, 0.0f, 0.0f)); | 304 gfx::Vector3dF(1.0f, 0.0f, 0.0f)); |
| 305 ASSERT_TRUE(IsMaximizeModeStarted()); | 305 ASSERT_TRUE(IsMaximizeModeStarted()); |
| 306 | 306 |
| 307 event_generator.PressKey(ui::VKEY_ESCAPE, 0); | 307 event_generator.PressKey(ui::VKEY_ESCAPE, 0); |
| 308 event_generator.ReleaseKey(ui::VKEY_ESCAPE, 0); | 308 event_generator.ReleaseKey(ui::VKEY_ESCAPE, 0); |
| 309 EXPECT_EQ(0u, counter.event_count()); | 309 EXPECT_EQ(0u, counter.event_count()); |
| 310 counter.reset(); | 310 counter.reset(); |
| 311 | 311 |
| 312 // Touch should not be blocked. | 312 // Touch should not be blocked. |
| 313 event_generator.PressTouch(); | 313 event_generator.PressTouch(); |
| 314 event_generator.ReleaseTouch(); | 314 event_generator.ReleaseTouch(); |
| 315 EXPECT_GT(counter.event_count(), 0u); | 315 EXPECT_GT(counter.event_count(), 0u); |
| 316 counter.reset(); | 316 counter.reset(); |
| 317 | 317 |
| 318 gfx::Vector3dF base; | 318 gfx::Vector3dF base; |
| 319 | 319 |
| 320 // Lid open 90 degrees. | 320 // Lid open 90 degrees. |
| 321 TriggerAccelerometerUpdate(gfx::Vector3dF(0.0f, 0.0f, 1.0f), | 321 TriggerAccelerometerUpdate(gfx::Vector3dF(0.0f, 0.0f, 1.0f), |
| 322 gfx::Vector3dF(-1.0f, 0.0f, 0.0f)); | 322 gfx::Vector3dF(-1.0f, 0.0f, 0.0f)); |
| 323 | 323 |
| 324 event_generator.PressKey(ui::VKEY_ESCAPE, 0); | 324 event_generator.PressKey(ui::VKEY_ESCAPE, 0); |
| 325 event_generator.ReleaseKey(ui::VKEY_ESCAPE, 0); | 325 event_generator.ReleaseKey(ui::VKEY_ESCAPE, 0); |
| 326 EXPECT_GT(counter.event_count(), 0u); | 326 EXPECT_GT(counter.event_count(), 0u); |
| 327 counter.reset(); | 327 counter.reset(); |
| 328 } | 328 } |
| 329 | 329 |
| 330 TEST_F(MaximizeModeControllerTest, LaptopTest) { | 330 TEST_F(MaximizeModeControllerTest, LaptopTest) { |
| 331 // Feeds in sample accelerometer data and verifies that there are no | 331 // Feeds in sample accelerometer data and verifies that there are no |
| 332 // transitions into touchview / maximize mode while shaking the device around | 332 // transitions into touchview / maximize mode while shaking the device around |
| 333 // with the hinge at less than 180 degrees. | 333 // with the hinge at less than 180 degrees. |
| 334 ASSERT_EQ(0u, kAccelerometerLaptopModeTestDataLength % 6); | 334 ASSERT_TRUE(kAccelerometerLaptopModeTestDataLength % 6 == 0); |
| 335 for (size_t i = 0; i < kAccelerometerLaptopModeTestDataLength / 6; ++i) { | 335 for (size_t i = 0; i < kAccelerometerLaptopModeTestDataLength / 6; ++i) { |
| 336 gfx::Vector3dF base(kAccelerometerLaptopModeTestData[i * 6], | 336 gfx::Vector3dF base(kAccelerometerLaptopModeTestData[i * 6], |
| 337 kAccelerometerLaptopModeTestData[i * 6 + 1], | 337 kAccelerometerLaptopModeTestData[i * 6 + 1], |
| 338 kAccelerometerLaptopModeTestData[i * 6 + 2]); | 338 kAccelerometerLaptopModeTestData[i * 6 + 2]); |
| 339 gfx::Vector3dF lid(kAccelerometerLaptopModeTestData[i * 6 + 3], | 339 gfx::Vector3dF lid(kAccelerometerLaptopModeTestData[i * 6 + 3], |
| 340 kAccelerometerLaptopModeTestData[i * 6 + 4], | 340 kAccelerometerLaptopModeTestData[i * 6 + 4], |
| 341 kAccelerometerLaptopModeTestData[i * 6 + 5]); | 341 kAccelerometerLaptopModeTestData[i * 6 + 5]); |
| 342 TriggerAccelerometerUpdate(base, lid); | 342 TriggerAccelerometerUpdate(base, lid); |
| 343 // There are a lot of samples, so ASSERT rather than EXPECT to only generate | 343 // There are a lot of samples, so ASSERT rather than EXPECT to only generate |
| 344 // one failure rather than potentially hundreds. | 344 // one failure rather than potentially hundreds. |
| 345 ASSERT_FALSE(IsMaximizeModeStarted()); | 345 ASSERT_FALSE(IsMaximizeModeStarted()); |
| 346 } | 346 } |
| 347 } | 347 } |
| 348 | 348 |
| 349 TEST_F(MaximizeModeControllerTest, MaximizeModeTest) { | 349 TEST_F(MaximizeModeControllerTest, MaximizeModeTest) { |
| 350 // Trigger maximize mode by opening to 270 to begin the test in maximize mode. | 350 // Trigger maximize mode by opening to 270 to begin the test in maximize mode. |
| 351 TriggerAccelerometerUpdate(gfx::Vector3dF(0.0f, 0.0f, -1.0f), | 351 TriggerAccelerometerUpdate(gfx::Vector3dF(0.0f, 0.0f, -1.0f), |
| 352 gfx::Vector3dF(-1.0f, 0.0f, 0.0f)); | 352 gfx::Vector3dF(-1.0f, 0.0f, 0.0f)); |
| 353 ASSERT_TRUE(IsMaximizeModeStarted()); | 353 ASSERT_TRUE(IsMaximizeModeStarted()); |
| 354 | 354 |
| 355 // Feeds in sample accelerometer data and verifies that there are no | 355 // Feeds in sample accelerometer data and verifies that there are no |
| 356 // transitions out of touchview / maximize mode while shaking the device | 356 // transitions out of touchview / maximize mode while shaking the device |
| 357 // around. | 357 // around. |
| 358 ASSERT_EQ(0u, kAccelerometerFullyOpenTestDataLength % 6); | 358 ASSERT_TRUE(kAccelerometerFullyOpenTestDataLength % 6 == 0); |
| 359 for (size_t i = 0; i < kAccelerometerFullyOpenTestDataLength / 6; ++i) { | 359 for (size_t i = 0; i < kAccelerometerFullyOpenTestDataLength / 6; ++i) { |
| 360 gfx::Vector3dF base(kAccelerometerFullyOpenTestData[i * 6], | 360 gfx::Vector3dF base(kAccelerometerFullyOpenTestData[i * 6], |
| 361 kAccelerometerFullyOpenTestData[i * 6 + 1], | 361 kAccelerometerFullyOpenTestData[i * 6 + 1], |
| 362 kAccelerometerFullyOpenTestData[i * 6 + 2]); | 362 kAccelerometerFullyOpenTestData[i * 6 + 2]); |
| 363 gfx::Vector3dF lid(kAccelerometerFullyOpenTestData[i * 6 + 3], | 363 gfx::Vector3dF lid(kAccelerometerFullyOpenTestData[i * 6 + 3], |
| 364 kAccelerometerFullyOpenTestData[i * 6 + 4], | 364 kAccelerometerFullyOpenTestData[i * 6 + 4], |
| 365 kAccelerometerFullyOpenTestData[i * 6 + 5]); | 365 kAccelerometerFullyOpenTestData[i * 6 + 5]); |
| 366 TriggerAccelerometerUpdate(base, lid); | 366 TriggerAccelerometerUpdate(base, lid); |
| 367 // There are a lot of samples, so ASSERT rather than EXPECT to only generate | 367 // There are a lot of samples, so ASSERT rather than EXPECT to only generate |
| 368 // one failure rather than potentially hundreds. | 368 // one failure rather than potentially hundreds. |
| (...skipping 18 matching lines...) Expand all Loading... |
| 387 gravity.set_x(-cos(degrees * kDegreesToRadians)); | 387 gravity.set_x(-cos(degrees * kDegreesToRadians)); |
| 388 gravity.set_y(sin(degrees * kDegreesToRadians)); | 388 gravity.set_y(sin(degrees * kDegreesToRadians)); |
| 389 TriggerAccelerometerUpdate(gravity, gravity); | 389 TriggerAccelerometerUpdate(gravity, gravity); |
| 390 EXPECT_EQ(gfx::Display::ROTATE_0, GetInternalDisplayRotation()); | 390 EXPECT_EQ(gfx::Display::ROTATE_0, GetInternalDisplayRotation()); |
| 391 | 391 |
| 392 maximize_mode_controller()->set_rotation_locked(false); | 392 maximize_mode_controller()->set_rotation_locked(false); |
| 393 TriggerAccelerometerUpdate(gravity, gravity); | 393 TriggerAccelerometerUpdate(gravity, gravity); |
| 394 EXPECT_EQ(gfx::Display::ROTATE_90, GetInternalDisplayRotation()); | 394 EXPECT_EQ(gfx::Display::ROTATE_90, GetInternalDisplayRotation()); |
| 395 } | 395 } |
| 396 | 396 |
| 397 // Tests that if the display was rotated before entering maximize mode that | 397 // Tests that when MaximizeModeController turns off MaximizeMode that on the |
| 398 // rotation becomes locked. | 398 // next accelerometer update the rotation lock is cleared. |
| 399 TEST_F(MaximizeModeControllerTest, | 399 TEST_F(MaximizeModeControllerTest, ExitingMaximizeModeClearRotationLock) { |
| 400 RotatedDisplayLocksRotationUponEnteringMaximizeMode) { | 400 // The base remains steady. |
| 401 DisplayManager* display_manager = Shell::GetInstance()->display_manager(); | 401 gfx::Vector3dF base(0.0f, 0.0f, 1.0f); |
| 402 display_manager->SetDisplayRotation(gfx::Display::InternalDisplayId(), | |
| 403 gfx::Display::ROTATE_90); | |
| 404 | |
| 405 // Trigger a non-maximize mode accelerometer update. Ensure that the display | |
| 406 // does not rotate. | |
| 407 TriggerAccelerometerUpdate(gfx::Vector3dF(0.0f, 0.0f, 1.0f), | |
| 408 gfx::Vector3dF(-1.0f, 0.0f, 0.0f)); | |
| 409 EXPECT_FALSE(IsMaximizeModeStarted()); | |
| 410 EXPECT_EQ(gfx::Display::ROTATE_90, GetInternalDisplayRotation()); | |
| 411 | 402 |
| 412 // Trigger maximize mode by opening to 270. | 403 // Trigger maximize mode by opening to 270. |
| 413 TriggerAccelerometerUpdate(gfx::Vector3dF(0.0f, 0.0f, -1.0f), | 404 TriggerAccelerometerUpdate(gfx::Vector3dF(0.0f, 0.0f, -1.0f), |
| 414 gfx::Vector3dF(-1.0f, 0.0f, 0.0f)); | 405 gfx::Vector3dF(-1.0f, 0.0f, 0.0f)); |
| 415 ASSERT_TRUE(IsMaximizeModeStarted()); | 406 ASSERT_TRUE(IsMaximizeModeStarted()); |
| 416 EXPECT_TRUE(maximize_mode_controller()->rotation_locked()); | 407 |
| 417 EXPECT_EQ(gfx::Display::ROTATE_90, GetInternalDisplayRotation()); | 408 maximize_mode_controller()->set_rotation_locked(true); |
| 409 |
| 410 // Open 90 degrees. |
| 411 TriggerAccelerometerUpdate(base, gfx::Vector3dF(-1.0f, 0.0f, 0.0f)); |
| 412 EXPECT_FALSE(IsMaximizeModeStarted()); |
| 413 |
| 414 // Send an update that would not relaunch MaximizeMode. 90 degrees. |
| 415 TriggerAccelerometerUpdate(base, gfx::Vector3dF(-1.0f, 0.0f, 0.0f)); |
| 416 EXPECT_FALSE(maximize_mode_controller()->rotation_locked()); |
| 418 } | 417 } |
| 419 | 418 |
| 420 } // namespace ash | 419 } // namespace ash |
| OLD | NEW |