Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(186)

Side by Side Diff: ash/wm/maximize_mode/maximize_mode_controller_unittest.cc

Issue 263813002: Take a screenshot in maximize mode when volume down and power are pressed. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Merge Created 6 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
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"
14 #include "ash/test/test_screenshot_delegate.h"
13 #include "ash/test/test_volume_control_delegate.h" 15 #include "ash/test/test_volume_control_delegate.h"
14 #include "ui/aura/test/event_generator.h" 16 #include "ui/aura/test/event_generator.h"
15 #include "ui/events/event_handler.h" 17 #include "ui/events/event_handler.h"
16 #include "ui/gfx/vector3d_f.h" 18 #include "ui/gfx/vector3d_f.h"
17 19
18 namespace ash { 20 namespace ash {
19 21
20 namespace { 22 namespace {
21 23
22 const float kDegreesToRadians = 3.14159265f / 180.0f; 24 const float kDegreesToRadians = 3.14159265f / 180.0f;
(...skipping 299 matching lines...) Expand 10 before | Expand all | Expand 10 after
322 // Lid open 90 degrees. 324 // Lid open 90 degrees.
323 TriggerAccelerometerUpdate(gfx::Vector3dF(0.0f, 0.0f, 1.0f), 325 TriggerAccelerometerUpdate(gfx::Vector3dF(0.0f, 0.0f, 1.0f),
324 gfx::Vector3dF(-1.0f, 0.0f, 0.0f)); 326 gfx::Vector3dF(-1.0f, 0.0f, 0.0f));
325 327
326 event_generator.PressKey(ui::VKEY_ESCAPE, 0); 328 event_generator.PressKey(ui::VKEY_ESCAPE, 0);
327 event_generator.ReleaseKey(ui::VKEY_ESCAPE, 0); 329 event_generator.ReleaseKey(ui::VKEY_ESCAPE, 0);
328 EXPECT_GT(counter.event_count(), 0u); 330 EXPECT_GT(counter.event_count(), 0u);
329 counter.reset(); 331 counter.reset();
330 } 332 }
331 333
334 #if defined(OS_CHROMEOS)
335 // Tests that a screenshot can be taken in maximize mode by holding volume down
336 // and pressing power.
337 TEST_F(MaximizeModeControllerTest, Screenshot) {
338 Shell::GetInstance()->lock_state_controller()->SetDelegate(
339 new test::TestLockStateControllerDelegate);
340 aura::Window* root = Shell::GetPrimaryRootWindow();
341 aura::test::EventGenerator event_generator(root, root);
342 test::TestScreenshotDelegate* delegate = GetScreenshotDelegate();
343 delegate->set_can_take_screenshot(true);
344
345 // Open up 270 degrees.
346 TriggerAccelerometerUpdate(gfx::Vector3dF(0.0f, 0.0f, 1.0f),
347 gfx::Vector3dF(1.0f, 0.0f, 0.0f));
348 ASSERT_TRUE(IsMaximizeModeStarted());
349
350 // Pressing power alone does not take a screenshot.
351 event_generator.PressKey(ui::VKEY_POWER, 0);
352 event_generator.ReleaseKey(ui::VKEY_POWER, 0);
353 EXPECT_EQ(0, delegate->handle_take_screenshot_count());
354
355 // Holding volume down and pressing power takes a screenshot.
356 event_generator.PressKey(ui::VKEY_VOLUME_DOWN, 0);
357 event_generator.PressKey(ui::VKEY_POWER, 0);
358 event_generator.ReleaseKey(ui::VKEY_POWER, 0);
359 EXPECT_EQ(1, delegate->handle_take_screenshot_count());
360 event_generator.ReleaseKey(ui::VKEY_VOLUME_DOWN, 0);
361 }
362 #endif // OS_CHROMEOS
363
332 // Tests that maximize mode does not block Volume Up & Down events. 364 // Tests that maximize mode does not block Volume Up & Down events.
333 TEST_F(MaximizeModeControllerTest, AllowsVolumeControl) { 365 TEST_F(MaximizeModeControllerTest, AllowsVolumeControl) {
334 aura::Window* root = Shell::GetPrimaryRootWindow(); 366 aura::Window* root = Shell::GetPrimaryRootWindow();
335 aura::test::EventGenerator event_generator(root, root); 367 aura::test::EventGenerator event_generator(root, root);
336 368
337 TestVolumeControlDelegate* volume_delegate = 369 TestVolumeControlDelegate* volume_delegate =
338 new TestVolumeControlDelegate(true); 370 new TestVolumeControlDelegate(true);
339 ash::Shell::GetInstance()->system_tray_delegate()->SetVolumeControlDelegate( 371 ash::Shell::GetInstance()->system_tray_delegate()->SetVolumeControlDelegate(
340 scoped_ptr<VolumeControlDelegate>(volume_delegate).Pass()); 372 scoped_ptr<VolumeControlDelegate>(volume_delegate).Pass());
341 373
(...skipping 98 matching lines...) Expand 10 before | Expand all | Expand 10 after
440 // Open 90 degrees. 472 // Open 90 degrees.
441 TriggerAccelerometerUpdate(base, gfx::Vector3dF(-1.0f, 0.0f, 0.0f)); 473 TriggerAccelerometerUpdate(base, gfx::Vector3dF(-1.0f, 0.0f, 0.0f));
442 EXPECT_FALSE(IsMaximizeModeStarted()); 474 EXPECT_FALSE(IsMaximizeModeStarted());
443 475
444 // Send an update that would not relaunch MaximizeMode. 90 degrees. 476 // Send an update that would not relaunch MaximizeMode. 90 degrees.
445 TriggerAccelerometerUpdate(base, gfx::Vector3dF(-1.0f, 0.0f, 0.0f)); 477 TriggerAccelerometerUpdate(base, gfx::Vector3dF(-1.0f, 0.0f, 0.0f));
446 EXPECT_FALSE(maximize_mode_controller()->rotation_locked()); 478 EXPECT_FALSE(maximize_mode_controller()->rotation_locked());
447 } 479 }
448 480
449 } // namespace ash 481 } // namespace ash
OLDNEW
« no previous file with comments | « ash/wm/maximize_mode/maximize_mode_controller.cc ('k') | ash/wm/maximize_mode/maximize_mode_event_blocker.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698