| Index: chrome/browser/chromeos/policy/user_policy_manager_factory_chromeos.cc
|
| diff --git a/chrome/browser/chromeos/policy/user_policy_manager_factory_chromeos.cc b/chrome/browser/chromeos/policy/user_policy_manager_factory_chromeos.cc
|
| index 6a27aaf1f54acab6c9fee9a68daf619662b114a6..850b9b0234ea459f42bce7ba8968c7622a19cee8 100644
|
| --- a/chrome/browser/chromeos/policy/user_policy_manager_factory_chromeos.cc
|
| +++ b/chrome/browser/chromeos/policy/user_policy_manager_factory_chromeos.cc
|
| @@ -199,17 +199,14 @@ UserPolicyManagerFactoryChromeOS::CreateManagerForProfile(
|
| const user_manager::UserManager* const user_manager =
|
| user_manager::UserManager::Get();
|
|
|
| - // We want to block for policy in a few situations: if the user is new, or if
|
| - // we are forcing an online signin. An online signin will be forced if there
|
| - // has been a credential error, or if the initial session creation was not
|
| - // completed (the oauth_token_status is not set to valid by OAuth2LoginManager
|
| - // until profile creation/session restore is complete).
|
| + // We want to block for policy if the session has never been initialized
|
| + // (generally true if the user is new, or if there was a crash before the
|
| + // profile finished initializing). There is code in UserSelectionScreen to
|
| + // force an online signin for uninitialized sessions to help ensure we are
|
| + // able to load policy.
|
| const bool block_forever_for_policy =
|
| !user_manager->IsLoggedInAsStub() &&
|
| - (user_manager->IsCurrentUserNew() ||
|
| - user_manager->GetActiveUser()->force_online_signin() ||
|
| - user_manager->GetActiveUser()->oauth_token_status() !=
|
| - user_manager::User::OAUTH2_TOKEN_STATUS_VALID);
|
| + !user_manager->GetActiveUser()->profile_ever_initialized();
|
|
|
| const bool wait_for_policy_fetch =
|
| block_forever_for_policy || !is_browser_restart;
|
|
|