Index: chrome/browser/chromeos/accessibility/accessibility_manager_browsertest.cc |
diff --git a/chrome/browser/chromeos/accessibility/accessibility_manager_browsertest.cc b/chrome/browser/chromeos/accessibility/accessibility_manager_browsertest.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..230f22caa898a2242c7568975a35913f6ac898a7 |
--- /dev/null |
+++ b/chrome/browser/chromeos/accessibility/accessibility_manager_browsertest.cc |
@@ -0,0 +1,301 @@ |
+// Copyright (c) 2013 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include "chrome/browser/chromeos/accessibility/accessibility_manager.h" |
+ |
+#include "ash/magnifier/magnification_controller.h" |
+#include "ash/shell.h" |
+#include "base/command_line.h" |
+#include "base/prefs/pref_service.h" |
+#include "chrome/browser/browser_process.h" |
+#include "chrome/browser/chromeos/accessibility/magnification_manager.h" |
+#include "chrome/browser/chromeos/cros/cros_in_process_browser_test.h" |
+#include "chrome/browser/chromeos/login/helper.h" |
+#include "chrome/browser/chromeos/login/login_utils.h" |
+#include "chrome/browser/chromeos/login/user_manager.h" |
+#include "chrome/browser/chromeos/login/user_manager_impl.h" |
+#include "chrome/browser/profiles/profile.h" |
+#include "chrome/browser/profiles/profile_manager.h" |
+#include "chrome/common/chrome_notification_types.h" |
+#include "chrome/common/pref_names.h" |
+#include "chrome/test/base/testing_profile.h" |
+#include "chromeos/chromeos_switches.h" |
+#include "content/public/browser/notification_service.h" |
+#include "testing/gtest/include/gtest/gtest.h" |
+ |
+namespace chromeos { |
+ |
+namespace { |
+ |
+const char kTestUserName[] = "owner@invalid.domain"; |
+ |
+class MockAccessibilityObserver : public content::NotificationObserver { |
+ public: |
+ MockAccessibilityObserver() : observed_(false), |
+ observed_enabled_(false), |
+ observed_type_(-1) { |
+ registrar_.Add( |
+ this, |
+ chrome::NOTIFICATION_CROS_ACCESSIBILITY_TOGGLE_SPOKEN_FEEDBACK, |
+ content::NotificationService::AllSources()); |
+ registrar_.Add( |
+ this, |
+ chrome::NOTIFICATION_CROS_ACCESSIBILITY_TOGGLE_HIGH_CONTRAST_MODE, |
+ content::NotificationService::AllSources()); |
+ } |
+ |
Daniel Erat
2013/04/26 13:58:58
needs a virtual d'tor
yoshiki
2013/05/24 18:49:45
Done.
|
+ bool observed() const { return observed_; } |
+ bool observed_enabled() const { return observed_enabled_; } |
+ int observed_type() const { return observed_type_; } |
+ |
+ void reset() { observed_ = false; } |
+ |
+ private: |
+ // content::NotificationObserver implimentation: |
+ virtual void Observe(int type, |
+ const content::NotificationSource& source, |
+ const content::NotificationDetails& details) OVERRIDE { |
+ AccessibilityStatusEventDetails* accessibility_status = |
+ content::Details<AccessibilityStatusEventDetails>( |
+ details).ptr(); |
+ ASSERT_FALSE(observed_); |
+ |
+ switch (type) { |
+ case chrome::NOTIFICATION_CROS_ACCESSIBILITY_TOGGLE_SPOKEN_FEEDBACK: |
+ observed_ = true; |
+ observed_enabled_ = accessibility_status->enabled; |
+ observed_type_ = type; |
+ break; |
+ case chrome::NOTIFICATION_CROS_ACCESSIBILITY_TOGGLE_HIGH_CONTRAST_MODE: |
+ observed_ = true; |
+ observed_enabled_ = accessibility_status->enabled; |
+ observed_type_ = type; |
+ break; |
+ } |
+ } |
+ |
+ bool observed_; |
+ bool observed_enabled_; |
+ int observed_type_; |
+ |
+ content::NotificationRegistrar registrar_; |
+}; |
Daniel Erat
2013/04/26 13:58:58
DISALLOW_COPY_AND_ASSIGN
yoshiki
2013/05/24 18:49:45
Done.
|
+ |
+void SetHighContrastEnabled(bool enabled) { |
+ return AccessibilityManager::Get()->EnableHighContrast(enabled); |
+} |
+ |
+bool IsHighContrastEnabled() { |
+ return AccessibilityManager::Get()->IsHighContrastEnabled(); |
+} |
+ |
+void SetSpokenFeedbackEnabled(bool enabled) { |
+ return AccessibilityManager::Get()->EnableSpokenFeedback( |
+ enabled, NULL, ash::A11Y_NOTIFICATION_NONE); |
+} |
+ |
+bool IsSpokenFeedbackEnabled() { |
+ return AccessibilityManager::Get()->IsSpokenFeedbackEnabled(); |
+} |
+ |
+Profile* profile() { |
Daniel Erat
2013/04/26 13:58:58
i don't think i've seen inline-style lowercase nam
yoshiki
2013/05/24 18:49:45
Done.
|
+ Profile* profile = ProfileManager::GetDefaultProfileOrOffTheRecord(); |
+ DCHECK(profile); |
+ return profile; |
+} |
+ |
+PrefService* prefs() { |
Daniel Erat
2013/04/26 13:58:58
same here
yoshiki
2013/05/24 18:49:45
Done.
|
+ return profile()->GetPrefs(); |
+} |
+ |
+void SetHighContrastEnabledToPref(bool enabled) { |
+ prefs()->SetBoolean(prefs::kHighContrastEnabled, enabled); |
+} |
+ |
+void SetSpokenFeedbackEnabledToPref(bool enabled) { |
+ prefs()->SetBoolean(prefs::kSpokenFeedbackEnabled, enabled); |
+} |
+ |
+} // anonymouse namespace |
+ |
+class AccessibilityManagerTest : public CrosInProcessBrowserTest { |
+ protected: |
+ AccessibilityManagerTest() {} |
+ virtual ~AccessibilityManagerTest() {} |
+ |
+ virtual void SetUpCommandLine(CommandLine* command_line) OVERRIDE { |
+ command_line->AppendSwitch(chromeos::switches::kLoginManager); |
+ command_line->AppendSwitchASCII(chromeos::switches::kLoginProfile, |
+ TestingProfile::kTestUserProfileDir); |
+ } |
+ |
+ virtual void SetUpOnMainThread() OVERRIDE { |
+ } |
+ |
+ content::NotificationRegistrar registrar_; |
+ DISALLOW_COPY_AND_ASSIGN(AccessibilityManagerTest); |
+}; |
+ |
+IN_PROC_BROWSER_TEST_F(AccessibilityManagerTest, Login) { |
+ // Confirms that magnifier is disabled on the login screen. |
+ EXPECT_FALSE(IsSpokenFeedbackEnabled()); |
+ EXPECT_FALSE(IsHighContrastEnabled()); |
+ |
+ // Logs in. |
+ UserManager::Get()->UserLoggedIn(kTestUserName, kTestUserName, true); |
+ |
+ // Confirms that magnifier is still disabled just after login. |
+ EXPECT_FALSE(IsSpokenFeedbackEnabled()); |
+ EXPECT_FALSE(IsHighContrastEnabled()); |
+ |
+ UserManager::Get()->SessionStarted(); |
+ |
+ // Confirms that magnifier is still disabled just after login. |
+ EXPECT_FALSE(IsSpokenFeedbackEnabled()); |
+ EXPECT_FALSE(IsHighContrastEnabled()); |
+ |
+ // Enables magnifier. |
+ SetSpokenFeedbackEnabled(true); |
+ // Confirms that magnifier is enabled. |
+ EXPECT_TRUE(IsSpokenFeedbackEnabled()); |
+ |
+ // Enables magnifier. |
+ SetHighContrastEnabled(true); |
+ // Confirms that magnifier is enabled. |
+ EXPECT_TRUE(IsHighContrastEnabled()); |
+} |
+ |
+IN_PROC_BROWSER_TEST_F(AccessibilityManagerTest, TypePref) { |
+ // Logs in |
Daniel Erat
2013/04/26 13:58:58
nit: add trailing period
yoshiki
2013/05/24 18:49:45
Done.
|
+ UserManager::Get()->UserLoggedIn(kTestUserName, kTestUserName, true); |
+ UserManager::Get()->SessionStarted(); |
+ |
+ // Confirms that magnifier is disabled just after login. |
+ EXPECT_FALSE(IsSpokenFeedbackEnabled()); |
+ EXPECT_FALSE(IsHighContrastEnabled()); |
+ |
+ // Sets the pref as true to enable magnifier. |
+ SetSpokenFeedbackEnabledToPref(true); |
+ // Confirms that magnifier is enabled. |
+ EXPECT_TRUE(IsSpokenFeedbackEnabled()); |
+ |
+ // Enables magnifier. |
+ SetHighContrastEnabled(true); |
+ // Confirms that magnifier is enabled. |
+ EXPECT_TRUE(IsHighContrastEnabled()); |
+ |
+ SetSpokenFeedbackEnabledToPref(false); |
+ EXPECT_FALSE(IsSpokenFeedbackEnabled()); |
+ |
+ SetHighContrastEnabledToPref(false); |
+ EXPECT_FALSE(IsHighContrastEnabled()); |
+} |
+ |
+IN_PROC_BROWSER_TEST_F(AccessibilityManagerTest, ResumeSavedPref) { |
+ // Loads the profile of the user. |
+ UserManager::Get()->UserLoggedIn(kTestUserName, kTestUserName, true); |
+ |
+ // Sets the pref as true to enable magnifier before login. |
+ SetSpokenFeedbackEnabledToPref(true); |
+ EXPECT_TRUE(IsSpokenFeedbackEnabled()); |
+ |
+ // Sets the pref as true to enable magnifier before login. |
+ SetHighContrastEnabledToPref(true); |
+ EXPECT_TRUE(IsHighContrastEnabled()); |
+ |
+ // Logs in. |
+ UserManager::Get()->SessionStarted(); |
+ |
+ // Confirms that magnifier is enabled just after login. |
+ EXPECT_TRUE(IsSpokenFeedbackEnabled()); |
+ EXPECT_TRUE(IsHighContrastEnabled()); |
+} |
+ |
+IN_PROC_BROWSER_TEST_F(AccessibilityManagerTest, |
+ ChangingTypeInvokesNotification) { |
+ MockAccessibilityObserver observer; |
+ |
+ // Logs in |
Daniel Erat
2013/04/26 13:58:58
nit: add trailing period (or remove unnecessary co
yoshiki
2013/05/24 18:49:45
Done.
|
+ UserManager::Get()->UserLoggedIn(kTestUserName, kTestUserName, true); |
+ UserManager::Get()->SessionStarted(); |
+ |
+ EXPECT_FALSE(observer.observed()); |
+ observer.reset(); |
+ |
+ SetSpokenFeedbackEnabled(true); |
+ EXPECT_TRUE(observer.observed()); |
+ EXPECT_TRUE(observer.observed_enabled()); |
+ EXPECT_EQ(observer.observed_type(), |
+ chrome::NOTIFICATION_CROS_ACCESSIBILITY_TOGGLE_SPOKEN_FEEDBACK); |
+ EXPECT_TRUE(IsSpokenFeedbackEnabled()); |
+ |
+ observer.reset(); |
+ SetSpokenFeedbackEnabled(false); |
+ EXPECT_TRUE(observer.observed()); |
+ EXPECT_FALSE(observer.observed_enabled()); |
+ EXPECT_EQ(observer.observed_type(), |
+ chrome::NOTIFICATION_CROS_ACCESSIBILITY_TOGGLE_SPOKEN_FEEDBACK); |
+ EXPECT_FALSE(IsSpokenFeedbackEnabled()); |
+ |
+ observer.reset(); |
+ SetHighContrastEnabled(true); |
+ EXPECT_TRUE(observer.observed()); |
+ EXPECT_TRUE(observer.observed_enabled()); |
+ EXPECT_EQ(observer.observed_type(), |
+ chrome::NOTIFICATION_CROS_ACCESSIBILITY_TOGGLE_HIGH_CONTRAST_MODE); |
+ EXPECT_TRUE(IsHighContrastEnabled()); |
+ |
+ observer.reset(); |
+ SetHighContrastEnabled(false); |
+ EXPECT_TRUE(observer.observed()); |
+ EXPECT_FALSE(observer.observed_enabled()); |
+ EXPECT_EQ(observer.observed_type(), |
+ chrome::NOTIFICATION_CROS_ACCESSIBILITY_TOGGLE_HIGH_CONTRAST_MODE); |
+ EXPECT_FALSE(IsHighContrastEnabled()); |
+} |
+ |
+IN_PROC_BROWSER_TEST_F(AccessibilityManagerTest, |
+ ChangingTypePrefInvokesNotification) { |
+ MockAccessibilityObserver observer; |
+ |
+ // Logs in |
Daniel Erat
2013/04/26 13:58:58
here too
yoshiki
2013/05/24 18:49:45
Done.
|
+ UserManager::Get()->UserLoggedIn(kTestUserName, kTestUserName, true); |
+ UserManager::Get()->SessionStarted(); |
+ |
+ EXPECT_FALSE(observer.observed()); |
+ observer.reset(); |
+ |
+ SetSpokenFeedbackEnabledToPref(true); |
+ EXPECT_TRUE(observer.observed()); |
+ EXPECT_TRUE(observer.observed_enabled()); |
+ EXPECT_EQ(observer.observed_type(), |
+ chrome::NOTIFICATION_CROS_ACCESSIBILITY_TOGGLE_SPOKEN_FEEDBACK); |
+ EXPECT_TRUE(IsSpokenFeedbackEnabled()); |
+ |
+ observer.reset(); |
+ SetSpokenFeedbackEnabledToPref(false); |
+ EXPECT_TRUE(observer.observed()); |
+ EXPECT_FALSE(observer.observed_enabled()); |
+ EXPECT_EQ(observer.observed_type(), |
+ chrome::NOTIFICATION_CROS_ACCESSIBILITY_TOGGLE_SPOKEN_FEEDBACK); |
+ EXPECT_FALSE(IsSpokenFeedbackEnabled()); |
+ |
+ observer.reset(); |
+ SetHighContrastEnabledToPref(true); |
+ EXPECT_TRUE(observer.observed()); |
+ EXPECT_TRUE(observer.observed_enabled()); |
+ EXPECT_EQ(observer.observed_type(), |
+ chrome::NOTIFICATION_CROS_ACCESSIBILITY_TOGGLE_HIGH_CONTRAST_MODE); |
+ EXPECT_TRUE(IsHighContrastEnabled()); |
+ |
+ observer.reset(); |
+ SetHighContrastEnabledToPref(false); |
+ EXPECT_TRUE(observer.observed()); |
+ EXPECT_FALSE(observer.observed_enabled()); |
+ EXPECT_EQ(observer.observed_type(), |
+ chrome::NOTIFICATION_CROS_ACCESSIBILITY_TOGGLE_HIGH_CONTRAST_MODE); |
+ EXPECT_FALSE(IsHighContrastEnabled()); |
+} |
+ |
+} // namespace chromeos |