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

Side by Side Diff: chrome/browser/chromeos/arc/arc_session_manager_unittest.cc

Issue 2702723002: Extract kArcEnabled preference from ArcSessionManager part 1. (Closed)
Patch Set: Address comments. Created 3 years, 10 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
OLDNEW
1 // Copyright 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 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 <memory> 5 #include <memory>
6 #include <string> 6 #include <string>
7 #include <tuple> 7 #include <tuple>
8 #include <vector> 8 #include <vector>
9 9
10 #include "base/bind.h" 10 #include "base/bind.h"
11 #include "base/command_line.h" 11 #include "base/command_line.h"
12 #include "base/files/file_path.h" 12 #include "base/files/file_path.h"
13 #include "base/files/file_util.h" 13 #include "base/files/file_util.h"
14 #include "base/files/scoped_temp_dir.h" 14 #include "base/files/scoped_temp_dir.h"
15 #include "base/logging.h" 15 #include "base/logging.h"
16 #include "base/macros.h" 16 #include "base/macros.h"
17 #include "base/memory/ptr_util.h" 17 #include "base/memory/ptr_util.h"
18 #include "base/observer_list.h" 18 #include "base/observer_list.h"
19 #include "base/run_loop.h" 19 #include "base/run_loop.h"
20 #include "base/values.h" 20 #include "base/values.h"
21 #include "chrome/browser/chromeos/arc/arc_optin_uma.h" 21 #include "chrome/browser/chromeos/arc/arc_optin_uma.h"
22 #include "chrome/browser/chromeos/arc/arc_session_manager.h" 22 #include "chrome/browser/chromeos/arc/arc_session_manager.h"
23 #include "chrome/browser/chromeos/arc/arc_util.h"
23 #include "chrome/browser/chromeos/arc/optin/arc_terms_of_service_oobe_negotiator .h" 24 #include "chrome/browser/chromeos/arc/optin/arc_terms_of_service_oobe_negotiator .h"
24 #include "chrome/browser/chromeos/arc/test/arc_data_removed_waiter.h" 25 #include "chrome/browser/chromeos/arc/test/arc_data_removed_waiter.h"
25 #include "chrome/browser/chromeos/login/screens/arc_terms_of_service_screen_acto r.h" 26 #include "chrome/browser/chromeos/login/screens/arc_terms_of_service_screen_acto r.h"
26 #include "chrome/browser/chromeos/login/screens/arc_terms_of_service_screen_acto r_observer.h" 27 #include "chrome/browser/chromeos/login/screens/arc_terms_of_service_screen_acto r_observer.h"
27 #include "chrome/browser/chromeos/login/ui/login_display_host.h" 28 #include "chrome/browser/chromeos/login/ui/login_display_host.h"
28 #include "chrome/browser/chromeos/login/users/fake_chrome_user_manager.h" 29 #include "chrome/browser/chromeos/login/users/fake_chrome_user_manager.h"
29 #include "chrome/browser/chromeos/login/users/scoped_user_manager_enabler.h" 30 #include "chrome/browser/chromeos/login/users/scoped_user_manager_enabler.h"
30 #include "chrome/browser/chromeos/login/users/wallpaper/wallpaper_manager.h" 31 #include "chrome/browser/chromeos/login/users/wallpaper/wallpaper_manager.h"
31 #include "chrome/browser/chromeos/profiles/profile_helper.h" 32 #include "chrome/browser/chromeos/profiles/profile_helper.h"
32 #include "chrome/browser/policy/profile_policy_connector.h" 33 #include "chrome/browser/policy/profile_policy_connector.h"
(...skipping 340 matching lines...) Expand 10 before | Expand all | Expand 10 after
373 ASSERT_EQ(ArcSessionManager::State::ACTIVE, arc_session_manager()->state()); 374 ASSERT_EQ(ArcSessionManager::State::ACTIVE, arc_session_manager()->state());
374 375
375 arc_session_manager()->CancelAuthCode(); 376 arc_session_manager()->CancelAuthCode();
376 ASSERT_EQ(ArcSessionManager::State::ACTIVE, arc_session_manager()->state()); 377 ASSERT_EQ(ArcSessionManager::State::ACTIVE, arc_session_manager()->state());
377 ASSERT_TRUE(pref->GetBoolean(prefs::kArcEnabled)); 378 ASSERT_TRUE(pref->GetBoolean(prefs::kArcEnabled));
378 379
379 // Correctly stop service. 380 // Correctly stop service.
380 arc_session_manager()->Shutdown(); 381 arc_session_manager()->Shutdown();
381 } 382 }
382 383
383 TEST_F(ArcSessionManagerTest, EnableDisablesArc) {
384 const PrefService* pref = profile()->GetPrefs();
385 arc_session_manager()->OnPrimaryUserProfilePrepared(profile());
386
387 EXPECT_FALSE(pref->GetBoolean(prefs::kArcEnabled));
388 arc_session_manager()->SetArcPlayStoreEnabled(true);
389 EXPECT_TRUE(pref->GetBoolean(prefs::kArcEnabled));
390 arc_session_manager()->SetArcPlayStoreEnabled(false);
391 EXPECT_FALSE(pref->GetBoolean(prefs::kArcEnabled));
392
393 // Correctly stop service.
394 arc_session_manager()->Shutdown();
395 }
396
397 TEST_F(ArcSessionManagerTest, SignInStatus) { 384 TEST_F(ArcSessionManagerTest, SignInStatus) {
398 PrefService* const prefs = profile()->GetPrefs(); 385 PrefService* const prefs = profile()->GetPrefs();
399 386
400 EXPECT_TRUE(arc_session_manager()->sign_in_start_time().is_null()); 387 EXPECT_TRUE(arc_session_manager()->sign_in_start_time().is_null());
401 EXPECT_TRUE(arc_session_manager()->arc_start_time().is_null()); 388 EXPECT_TRUE(arc_session_manager()->arc_start_time().is_null());
402 389
403 EXPECT_FALSE(prefs->GetBoolean(prefs::kArcSignedIn)); 390 EXPECT_FALSE(prefs->GetBoolean(prefs::kArcSignedIn));
404 prefs->SetBoolean(prefs::kArcEnabled, true); 391 prefs->SetBoolean(prefs::kArcEnabled, true);
405 392
406 arc_session_manager()->OnPrimaryUserProfilePrepared(profile()); 393 arc_session_manager()->OnPrimaryUserProfilePrepared(profile());
(...skipping 192 matching lines...) Expand 10 before | Expand all | Expand 10 after
599 if (backup_restore_pref_value().is_bool()) { 586 if (backup_restore_pref_value().is_bool()) {
600 prefs->SetManagedPref(prefs::kArcBackupRestoreEnabled, 587 prefs->SetManagedPref(prefs::kArcBackupRestoreEnabled,
601 backup_restore_pref_value().DeepCopy()); 588 backup_restore_pref_value().DeepCopy());
602 } 589 }
603 if (location_service_pref_value().is_bool()) { 590 if (location_service_pref_value().is_bool()) {
604 prefs->SetManagedPref(prefs::kArcLocationServiceEnabled, 591 prefs->SetManagedPref(prefs::kArcLocationServiceEnabled,
605 location_service_pref_value().DeepCopy()); 592 location_service_pref_value().DeepCopy());
606 } 593 }
607 594
608 arc_session_manager()->OnPrimaryUserProfilePrepared(profile()); 595 arc_session_manager()->OnPrimaryUserProfilePrepared(profile());
609 EXPECT_TRUE(arc_session_manager()->IsArcPlayStoreEnabled()); 596 EXPECT_TRUE(arc::IsArcPlayStoreEnabledForProfile(profile()));
610 EXPECT_TRUE(arc_session_manager()->IsArcManaged()); 597 EXPECT_TRUE(arc::IsArcPlayStoreEnabledPreferenceManagedForProfile(profile()));
611 598
612 // Terms of Service should be skipped if both ArcBackupRestoreEnabled and 599 // Terms of Service should be skipped if both ArcBackupRestoreEnabled and
613 // ArcLocationServiceEnabled are managed. 600 // ArcLocationServiceEnabled are managed.
614 const ArcSessionManager::State expected_state = 601 const ArcSessionManager::State expected_state =
615 backup_restore_pref_value().is_bool() && 602 backup_restore_pref_value().is_bool() &&
616 location_service_pref_value().is_bool() 603 location_service_pref_value().is_bool()
617 ? ArcSessionManager::State::ACTIVE 604 ? ArcSessionManager::State::ACTIVE
618 : ArcSessionManager::State::SHOWING_TERMS_OF_SERVICE; 605 : ArcSessionManager::State::SHOWING_TERMS_OF_SERVICE;
619 EXPECT_EQ(expected_state, arc_session_manager()->state()); 606 EXPECT_EQ(expected_state, arc_session_manager()->state());
620 607
(...skipping 199 matching lines...) Expand 10 before | Expand all | Expand 10 after
820 ArcSessionOobeOptInNegotiatorTest, 807 ArcSessionOobeOptInNegotiatorTest,
821 ::testing::Values(true, false)); 808 ::testing::Values(true, false));
822 809
823 TEST_P(ArcSessionOobeOptInNegotiatorTest, OobeTermsAccepted) { 810 TEST_P(ArcSessionOobeOptInNegotiatorTest, OobeTermsAccepted) {
824 actor()->Show(); 811 actor()->Show();
825 MaybeWaitForDataRemoved(); 812 MaybeWaitForDataRemoved();
826 EXPECT_EQ(ArcSessionManager::State::SHOWING_TERMS_OF_SERVICE, 813 EXPECT_EQ(ArcSessionManager::State::SHOWING_TERMS_OF_SERVICE,
827 arc_session_manager()->state()); 814 arc_session_manager()->state());
828 ReportResult(true); 815 ReportResult(true);
829 EXPECT_EQ(ArcSessionManager::State::ACTIVE, arc_session_manager()->state()); 816 EXPECT_EQ(ArcSessionManager::State::ACTIVE, arc_session_manager()->state());
830 EXPECT_TRUE(arc_session_manager()->IsArcPlayStoreEnabled()); 817 EXPECT_TRUE(IsArcPlayStoreEnabledForProfile(profile()));
831 } 818 }
832 819
833 TEST_P(ArcSessionOobeOptInNegotiatorTest, OobeTermsRejected) { 820 TEST_P(ArcSessionOobeOptInNegotiatorTest, OobeTermsRejected) {
834 actor()->Show(); 821 actor()->Show();
835 MaybeWaitForDataRemoved(); 822 MaybeWaitForDataRemoved();
836 EXPECT_EQ(ArcSessionManager::State::SHOWING_TERMS_OF_SERVICE, 823 EXPECT_EQ(ArcSessionManager::State::SHOWING_TERMS_OF_SERVICE,
837 arc_session_manager()->state()); 824 arc_session_manager()->state());
838 ReportResult(false); 825 ReportResult(false);
839 EXPECT_EQ(ArcSessionManager::State::STOPPED, arc_session_manager()->state()); 826 EXPECT_EQ(ArcSessionManager::State::STOPPED, arc_session_manager()->state());
840 EXPECT_FALSE(!IsManagedUser() && 827 if (!IsManagedUser())
841 arc_session_manager()->IsArcPlayStoreEnabled()); 828 EXPECT_FALSE(IsArcPlayStoreEnabledForProfile(profile()));
842 } 829 }
843 830
844 TEST_P(ArcSessionOobeOptInNegotiatorTest, OobeTermsActorDestroyed) { 831 TEST_P(ArcSessionOobeOptInNegotiatorTest, OobeTermsActorDestroyed) {
845 actor()->Show(); 832 actor()->Show();
846 MaybeWaitForDataRemoved(); 833 MaybeWaitForDataRemoved();
847 EXPECT_EQ(ArcSessionManager::State::SHOWING_TERMS_OF_SERVICE, 834 EXPECT_EQ(ArcSessionManager::State::SHOWING_TERMS_OF_SERVICE,
848 arc_session_manager()->state()); 835 arc_session_manager()->state());
849 CloseLoginDisplayHost(); 836 CloseLoginDisplayHost();
850 ReportActorDestroyed(); 837 ReportActorDestroyed();
851 EXPECT_EQ(ArcSessionManager::State::STOPPED, arc_session_manager()->state()); 838 EXPECT_EQ(ArcSessionManager::State::STOPPED, arc_session_manager()->state());
852 EXPECT_FALSE(!IsManagedUser() && 839 if (!IsManagedUser())
853 arc_session_manager()->IsArcPlayStoreEnabled()); 840 EXPECT_FALSE(IsArcPlayStoreEnabledForProfile(profile()));
854 } 841 }
855 842
856 } // namespace arc 843 } // namespace arc
OLDNEW
« no previous file with comments | « chrome/browser/chromeos/arc/arc_session_manager.cc ('k') | chrome/browser/chromeos/arc/arc_util.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698