blob: c2d371f98531aaa131e390c024da2ac8ea179a2c [file] [log] [blame]
// Copyright 2012 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/sync/test/integration/extensions_helper.h"
#include "base/check.h"
#include "base/logging.h"
#include "base/task/single_thread_task_runner.h"
#include "base/test/bind.h"
#include "chrome/browser/extensions/updater/extension_updater.h"
#include "chrome/browser/profiles/profile.h"
#include "chrome/browser/sync/test/integration/sync_datatype_helper.h"
#include "chrome/browser/sync/test/integration/sync_extension_helper.h"
#include "extensions/browser/extension_registry.h"
#include "extensions/buildflags/buildflags.h"
#include "extensions/common/manifest.h"
static_assert(BUILDFLAG(ENABLE_EXTENSIONS_CORE));
using sync_datatype_helper::test;
namespace extensions_helper {
// Returns a unique extension name based in the integer |index|.
std::string CreateFakeExtensionName(int index) {
return SyncExtensionHelper::GetInstance()->CreateFakeExtensionName(index);
}
bool HasSameExtensions(int index1, int index2) {
return SyncExtensionHelper::GetInstance()->ExtensionStatesMatch(
test()->GetProfile(index1), test()->GetProfile(index2));
}
bool AllProfilesHaveSameExtensions() {
for (int i = 1; i < test()->num_clients(); ++i) {
if (!SyncExtensionHelper::GetInstance()->ExtensionStatesMatch(
test()->GetProfile(0), test()->GetProfile(i))) {
LOG(ERROR) << "Profile " << i
<< " doesnt have the same extensions as"
" profile 0.";
return false;
}
}
return true;
}
std::string InstallExtension(Profile* profile, int index) {
return SyncExtensionHelper::GetInstance()->InstallExtension(
profile, CreateFakeExtensionName(index),
extensions::Manifest::TYPE_EXTENSION);
}
std::string InstallExtensionForAllProfiles(int index) {
std::string extension_id;
for (Profile* profile : test()->GetAllProfiles()) {
extension_id = InstallExtension(profile, index);
}
return extension_id;
}
void UninstallExtension(Profile* profile, int index) {
return SyncExtensionHelper::GetInstance()->UninstallExtension(
profile, CreateFakeExtensionName(index));
}
std::vector<int> GetInstalledExtensions(Profile* profile) {
std::vector<int> indices;
std::vector<std::string> names =
SyncExtensionHelper::GetInstance()->GetInstalledExtensionNames(profile);
for (std::vector<std::string>::const_iterator it = names.begin();
it != names.end(); ++it) {
int index;
if (SyncExtensionHelper::GetInstance()->ExtensionNameToIndex(*it, &index)) {
indices.push_back(index);
}
}
return indices;
}
void EnableExtension(Profile* profile, int index) {
return SyncExtensionHelper::GetInstance()->EnableExtension(
profile, CreateFakeExtensionName(index));
}
void DisableExtension(Profile* profile, int index) {
return SyncExtensionHelper::GetInstance()->DisableExtension(
profile, CreateFakeExtensionName(index));
}
bool IsExtensionEnabled(Profile* profile, int index) {
return SyncExtensionHelper::GetInstance()->IsExtensionEnabled(
profile, CreateFakeExtensionName(index));
}
void IncognitoEnableExtension(Profile* profile, int index) {
return SyncExtensionHelper::GetInstance()->IncognitoEnableExtension(
profile, CreateFakeExtensionName(index));
}
void IncognitoDisableExtension(Profile* profile, int index) {
return SyncExtensionHelper::GetInstance()->IncognitoDisableExtension(
profile, CreateFakeExtensionName(index));
}
bool IsIncognitoEnabled(Profile* profile, int index) {
return SyncExtensionHelper::GetInstance()->IsIncognitoEnabled(
profile, CreateFakeExtensionName(index));
}
void InstallExtensionsPendingForSync(Profile* profile) {
SyncExtensionHelper::GetInstance()->InstallExtensionsPendingForSync(profile);
}
} // namespace extensions_helper
ExtensionsMatchChecker::ExtensionsMatchChecker()
: profiles_(test()->GetAllProfiles()) {
DCHECK_GE(profiles_.size(), 2U);
for (Profile* profile : profiles_) {
SyncExtensionHelper::GetInstance()->InstallExtensionsPendingForSync(
profile);
auto* updater = extensions::ExtensionUpdater::Get(profile);
CHECK(updater);
CHECK(updater->enabled());
updater->SetUpdatingStartedCallbackForTesting(
base::BindLambdaForTesting(
[self = weak_ptr_factory_.GetWeakPtr(), profile]() {
base::SingleThreadTaskRunner::GetCurrentDefault()->PostTask(
FROM_HERE,
base::BindOnce(
&ExtensionsMatchChecker::OnExtensionUpdatingStarted, self,
base::Unretained(profile)));
}));
extensions::ExtensionRegistry* registry =
extensions::ExtensionRegistry::Get(profile);
registry->AddObserver(this);
}
}
ExtensionsMatchChecker::~ExtensionsMatchChecker() {
for (Profile* profile : profiles_) {
extensions::ExtensionRegistry* registry =
extensions::ExtensionRegistry::Get(profile);
registry->RemoveObserver(this);
}
}
bool ExtensionsMatchChecker::IsExitConditionSatisfied(std::ostream* os) {
*os << "Waiting for extensions to match";
auto it = profiles_.begin();
Profile* profile0 = *it;
++it;
for (; it != profiles_.end(); ++it) {
if (!SyncExtensionHelper::GetInstance()->ExtensionStatesMatch(profile0,
*it)) {
return false;
}
}
return true;
}
void ExtensionsMatchChecker::OnExtensionLoaded(
content::BrowserContext* context,
const extensions::Extension* extension) {
CheckExitCondition();
}
void ExtensionsMatchChecker::OnExtensionUnloaded(
content::BrowserContext* context,
const extensions::Extension* extension,
extensions::UnloadedExtensionReason reason) {
CheckExitCondition();
}
void ExtensionsMatchChecker::OnExtensionInstalled(
content::BrowserContext* browser_context,
const extensions::Extension* extension,
bool is_update) {
CheckExitCondition();
}
void ExtensionsMatchChecker::OnExtensionUninstalled(
content::BrowserContext* browser_context,
const extensions::Extension* extension,
extensions::UninstallReason reason) {
CheckExitCondition();
}
void ExtensionsMatchChecker::OnExtensionUpdatingStarted(Profile* profile) {
// The extension system is trying to check for updates. In the real world,
// this would be where synced extensions are asynchronously downloaded from
// the web store and installed. In this test framework, we use this event as
// a signal that it's time to asynchronously fake the installation of these
// extensions.
SyncExtensionHelper::GetInstance()->InstallExtensionsPendingForSync(profile);
CheckExitCondition();
}