blob: 58126e410ffb4fa72b8fb600e9a7fa01454227e6 [file] [log] [blame]
// Copyright 2018 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "chrome/browser/safe_browsing/advanced_protection_status_manager.h"
#include "base/command_line.h"
#include "base/test/task_environment.h"
#include "build/build_config.h"
#include "components/prefs/pref_service.h"
#include "components/safe_browsing/core/common/safe_browsing_prefs.h"
#include "components/safe_browsing/core/common/safebrowsing_switches.h"
#include "components/signin/public/identity_manager/account_info.h"
#include "components/signin/public/identity_manager/identity_test_environment.h"
#include "components/sync_preferences/testing_pref_service_syncable.h"
#include "testing/gtest/include/gtest/gtest.h"
#if BUILDFLAG(IS_ANDROID)
#include "chrome/browser/safe_browsing/advanced_protection_status_manager_android.h"
#include "chrome/browser/safe_browsing/android/advanced_protection_status_manager_test_util.h"
#else
#include "chrome/browser/safe_browsing/advanced_protection_status_manager_desktop.h"
#endif
namespace safe_browsing {
#if BUILDFLAG(IS_ANDROID)
typedef AdvancedProtectionStatusManagerAndroid
AdvancedProtectionStatusManagerPlatform;
#else
typedef AdvancedProtectionStatusManagerDesktop
AdvancedProtectionStatusManagerPlatform;
#endif
class AdvancedProtectionStatusManagerTest : public testing::Test {
public:
AdvancedProtectionStatusManagerTest() {
RegisterProfilePrefs(pref_service_.registry());
}
void SetUp() override {
#if BUILDFLAG(IS_ANDROID)
SetAdvancedProtectionStateForTesting(
/*is_advanced_protection_requested_by_os=*/false);
#endif // BUILDFLAG(IS_ANDROID)
}
std::unique_ptr<AdvancedProtectionStatusManagerPlatform> BuildManager(
PrefService* pref_service,
signin::IdentityManager* identity_manager) {
#if BUILDFLAG(IS_ANDROID)
return std::make_unique<AdvancedProtectionStatusManagerAndroid>();
#else
return std::unique_ptr<AdvancedProtectionStatusManagerDesktop>(
new AdvancedProtectionStatusManagerDesktop(
pref_service, identity_manager,
base::TimeDelta() /*no min delay*/));
#endif
}
protected:
sync_preferences::TestingPrefServiceSyncable pref_service_;
};
// On ChromeOS, there is no unconsented primary account. We can only track the
// primary account.
#if !BUILDFLAG(IS_CHROMEOS)
TEST_F(AdvancedProtectionStatusManagerTest, TracksUnconsentedPrimaryAccount) {
base::test::TaskEnvironment task_environment;
signin::IdentityTestEnvironment identity_test_env(
/*test_url_loader_factory=*/nullptr, &pref_service_);
// Sign in, but don't set this as the primary account.
AccountInfo account_info = identity_test_env.MakePrimaryAccountAvailable(
"test@test.com", signin::ConsentLevel::kSignin);
account_info.is_under_advanced_protection = true;
identity_test_env.UpdateAccountInfoForAccount(account_info);
auto manager =
BuildManager(&pref_service_, identity_test_env.identity_manager());
#if BUILDFLAG(IS_ANDROID)
EXPECT_FALSE(manager->IsUnderAdvancedProtection());
#else
EXPECT_TRUE(manager->IsUnderAdvancedProtection());
#endif
manager->Shutdown();
}
#endif // !BUILDFLAG(IS_CHROMEOS)
} // namespace safe_browsing