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

Side by Side Diff: extensions/shell/browser/shell_desktop_controller_unittest.cc

Issue 468393005: app_shell: Shut down in response to power button. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: fix a comment Created 6 years, 4 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
(Empty)
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
3 // found in the LICENSE file.
4
5 #include "extensions/shell/browser/shell_desktop_controller.h"
6
7 #include "base/macros.h"
James Cook 2014/08/23 00:55:00 Nice IWYU
8 #include "base/memory/scoped_ptr.h"
9 #include "base/time/time.h"
10 #include "ui/aura/test/aura_test_base.h"
11
12 #if defined(OS_CHROMEOS)
13 #include "chromeos/dbus/dbus_thread_manager.h"
14 #include "chromeos/dbus/fake_dbus_thread_manager.h"
15 #include "chromeos/dbus/fake_power_manager_client.h"
16 #endif
17
18 namespace extensions {
19
20 class ShellDesktopControllerTest : public aura::test::AuraTestBase {
21 public:
22 ShellDesktopControllerTest()
23 #if defined(OS_CHROMEOS)
24 : power_manager_client_(NULL)
25 #endif
26 {
27 }
28 virtual ~ShellDesktopControllerTest() {}
29
30 virtual void SetUp() OVERRIDE {
31 #if defined(OS_CHROMEOS)
32 chromeos::FakeDBusThreadManager* manager =
33 new chromeos::FakeDBusThreadManager();
34 power_manager_client_ = new chromeos::FakePowerManagerClient();
35 manager->SetPowerManagerClient(make_scoped_ptr(power_manager_client_).
36 PassAs<chromeos::PowerManagerClient>());
37 chromeos::DBusThreadManager::InitializeForTesting(manager);
38 #endif
39 aura::test::AuraTestBase::SetUp();
40 controller_.reset(new ShellDesktopController());
41 }
42
43 virtual void TearDown() OVERRIDE {
44 controller_.reset();
45 aura::test::AuraTestBase::TearDown();
46 #if defined(OS_CHROMEOS)
47 chromeos::DBusThreadManager::Shutdown();
48 #endif
49 }
50
51 protected:
52 scoped_ptr<ShellDesktopController> controller_;
53
54 #if defined(OS_CHROMEOS)
55 chromeos::FakePowerManagerClient* power_manager_client_; // Weak pointer.
James Cook 2014/08/23 00:55:00 nit: "Weak pointer" -> "Not owned", because we hav
Daniel Erat 2014/08/23 02:21:31 i can never remember if you're the reviewer who te
56 #endif
57
58 private:
59 DISALLOW_COPY_AND_ASSIGN(ShellDesktopControllerTest);
60 };
61
62 #if defined(OS_CHROMEOS)
63 TEST_F(ShellDesktopControllerTest, PowerButton) {
James Cook 2014/08/23 00:55:00 nit: Comment above the test about what it intends
Daniel Erat 2014/08/23 02:21:31 Done.
64 // Ignore button releases.
65 power_manager_client_->SendPowerButtonEvent(false /* down */,
66 base::TimeTicks());
67 EXPECT_EQ(0, power_manager_client_->num_request_shutdown_calls());
68
69 // A button press should trigger a shutdown request.
70 power_manager_client_->SendPowerButtonEvent(true /* down */,
71 base::TimeTicks());
72 EXPECT_EQ(1, power_manager_client_->num_request_shutdown_calls());
73 }
74 #endif
75
76 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698