Cast: Stop logging kVideoFrameSentToEncoder and rename a couple events.
[chromium-blink-merge.git] / chrome / browser / chromeos / kiosk_mode / kiosk_mode_idle_logout_unittest.cc
bloba71d5b3ec4e4d7b022d28983558a34dfd0d3429e
1 // Copyright (c) 2012 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.
5 #include "chrome/browser/chromeos/kiosk_mode/kiosk_mode_idle_logout.h"
7 #include "ash/shell.h"
8 #include "ash/test/ash_test_base.h"
9 #include "base/bind.h"
10 #include "base/memory/scoped_ptr.h"
11 #include "base/message_loop/message_loop.h"
12 #include "base/synchronization/waitable_event.h"
13 #include "chrome/browser/chrome_notification_types.h"
14 #include "chrome/browser/chromeos/login/user_manager.h"
15 #include "chrome/browser/chromeos/settings/device_settings_test_helper.h"
16 #include "content/public/browser/notification_registrar.h"
17 #include "content/public/browser/notification_service.h"
18 #include "testing/gtest/include/gtest/gtest.h"
19 #include "ui/wm/core/user_activity_detector.h"
21 namespace chromeos {
23 class KioskModeIdleLogoutTest : public ash::test::AshTestBase {
24 public:
25 KioskModeIdleLogoutTest()
26 : idle_logout_(NULL) {
29 virtual void SetUp() OVERRIDE {
30 AshTestBase::SetUp();
31 idle_logout_ = new KioskModeIdleLogout();
34 virtual void TearDown() OVERRIDE {
35 delete idle_logout_;
36 AshTestBase::TearDown();
39 bool LoginUserObserverRegistered() {
40 return idle_logout_->registrar_.IsRegistered(
41 idle_logout_,
42 chrome::NOTIFICATION_LOGIN_USER_CHANGED,
43 content::NotificationService::AllSources());
46 bool UserActivityObserverRegistered() {
47 return ash::Shell::GetInstance()->user_activity_detector()->HasObserver(
48 idle_logout_);
51 ScopedDeviceSettingsTestHelper device_settings_test_helper_;
53 KioskModeIdleLogout* idle_logout_;
54 content::NotificationRegistrar registrar_;
57 // http://crbug.com/177918
58 TEST_F(KioskModeIdleLogoutTest, DISABLED_CheckObserversBeforeUserLogin) {
59 EXPECT_TRUE(LoginUserObserverRegistered());
60 EXPECT_FALSE(UserActivityObserverRegistered());
63 // http://crbug.com/177918
64 TEST_F(KioskModeIdleLogoutTest, DISABLED_CheckObserversAfterUserLogin) {
65 content::NotificationService::current()->Notify(
66 chrome::NOTIFICATION_LOGIN_USER_CHANGED,
67 content::Source<UserManager>(UserManager::Get()),
68 // Ideally this should be the user logged in, but since we won't really be
69 // checking for the current logged in user in our observer anyway, giving
70 // NoDetails here is fine.
71 content::NotificationService::NoDetails());
73 RunAllPendingInMessageLoop();
74 EXPECT_FALSE(LoginUserObserverRegistered());
75 EXPECT_TRUE(UserActivityObserverRegistered());
78 } // namespace chromeos