| Index: extensions/test/extension_test_notification_observer.cc
|
| diff --git a/chrome/browser/extensions/extension_test_notification_observer.cc b/extensions/test/extension_test_notification_observer.cc
|
| similarity index 47%
|
| rename from chrome/browser/extensions/extension_test_notification_observer.cc
|
| rename to extensions/test/extension_test_notification_observer.cc
|
| index a9f3d8f2084d5afddb962c7af15634102ca6f833..314fb594aeeaffd92bf70f1d9d10fb661ce00d47 100644
|
| --- a/chrome/browser/extensions/extension_test_notification_observer.cc
|
| +++ b/extensions/test/extension_test_notification_observer.cc
|
| @@ -1,27 +1,18 @@
|
| -// Copyright 2013 The Chromium Authors. All rights reserved.
|
| +// Copyright 2016 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/extensions/extension_test_notification_observer.h"
|
| +#include "extensions/test/extension_test_notification_observer.h"
|
|
|
| -#include <stddef.h>
|
| -
|
| -#include "base/callback_list.h"
|
| -#include "base/scoped_observer.h"
|
| -#include "chrome/browser/extensions/extension_action_test_util.h"
|
| -#include "chrome/browser/extensions/extension_service.h"
|
| -#include "chrome/browser/extensions/extension_util.h"
|
| -#include "chrome/browser/profiles/profile_manager.h"
|
| -#include "chrome/browser/ui/browser.h"
|
| -#include "chrome/browser/ui/browser_window.h"
|
| -#include "chrome/browser/ui/tabs/tab_strip_model.h"
|
| +#include "content/public/browser/browser_context.h"
|
| +#include "content/public/browser/notification_details.h"
|
| #include "content/public/browser/notification_registrar.h"
|
| #include "content/public/browser/notification_service.h"
|
| -#include "content/public/browser/render_view_host.h"
|
| +#include "content/public/browser/render_frame_host.h"
|
| #include "content/public/test/test_utils.h"
|
| -#include "extensions/browser/extension_system.h"
|
| +#include "extensions/browser/extension_registry.h"
|
| +#include "extensions/browser/notification_types.h"
|
| #include "extensions/browser/process_manager.h"
|
| -#include "extensions/browser/process_manager_observer.h"
|
| #include "extensions/common/extension.h"
|
|
|
| using extensions::Extension;
|
| @@ -30,28 +21,13 @@ namespace {
|
|
|
| // A callback that returns true if the condition has been met and takes no
|
| // arguments.
|
| -typedef base::Callback<bool(void)> ConditionCallback;
|
| -
|
| -bool HasPageActionVisibilityReachedTarget(
|
| - Browser* browser, size_t target_visible_page_action_count) {
|
| - return extensions::extension_action_test_util::GetVisiblePageActionCount(
|
| - browser->tab_strip_model()->GetActiveWebContents()) ==
|
| - target_visible_page_action_count;
|
| -}
|
| -
|
| -bool HaveAllExtensionRenderFrameHostsFinishedLoading(
|
| - extensions::ProcessManager* manager) {
|
| - extensions::ProcessManager::FrameSet all_views = manager->GetAllFrames();
|
| - for (content::RenderFrameHost* host : manager->GetAllFrames()) {
|
| - if (content::WebContents::FromRenderFrameHost(host)->IsLoading())
|
| - return false;
|
| - }
|
| - return true;
|
| -}
|
| +using ConditionCallback = base::Callback<bool(void)>;
|
|
|
| -bool IsExtensionNotIdle(const std::string& extension_id,
|
| - content::BrowserContext* context) {
|
| - return !extensions::util::IsExtensionIdle(extension_id, context);
|
| +const Extension* GetNonTerminatedExtensions(const std::string& id,
|
| + content::BrowserContext* context) {
|
| + return extensions::ExtensionRegistry::Get(context)->GetExtensionById(
|
| + id, extensions::ExtensionRegistry::EVERYTHING &
|
| + ~extensions::ExtensionRegistry::TERMINATED);
|
| }
|
|
|
| } // namespace
|
| @@ -59,39 +35,9 @@ bool IsExtensionNotIdle(const std::string& extension_id,
|
| ////////////////////////////////////////////////////////////////////////////////
|
| // ExtensionTestNotificationObserver::NotificationSet
|
|
|
| -class ExtensionTestNotificationObserver::NotificationSet
|
| - : public content::NotificationObserver,
|
| - public extensions::ProcessManagerObserver {
|
| - public:
|
| - NotificationSet() : process_manager_observer_(this) {}
|
| - ~NotificationSet() override {}
|
| -
|
| - void Add(int type, const content::NotificationSource& source);
|
| - void Add(int type);
|
| - void AddExtensionFrameUnregistration(extensions::ProcessManager* manager);
|
| -
|
| - // Notified any time an Add()ed notification is received.
|
| - // The details of the notification are dropped.
|
| - base::CallbackList<void()>& callback_list() {
|
| - return callback_list_;
|
| - }
|
| -
|
| - private:
|
| - // content::NotificationObserver:
|
| - void Observe(int type,
|
| - const content::NotificationSource& source,
|
| - const content::NotificationDetails& details) override;
|
| -
|
| - // extensions::ProcessManagerObserver:
|
| - void OnExtensionFrameUnregistered(
|
| - const std::string& extension_id,
|
| - content::RenderFrameHost* render_frame_host) override;
|
| -
|
| - content::NotificationRegistrar notification_registrar_;
|
| - base::CallbackList<void()> callback_list_;
|
| - ScopedObserver<extensions::ProcessManager, extensions::ProcessManagerObserver>
|
| - process_manager_observer_;
|
| -};
|
| +ExtensionTestNotificationObserver::NotificationSet::NotificationSet()
|
| + : process_manager_observer_(this) {}
|
| +ExtensionTestNotificationObserver::NotificationSet::~NotificationSet() {}
|
|
|
| void ExtensionTestNotificationObserver::NotificationSet::Add(
|
| int type,
|
| @@ -125,86 +71,33 @@ void ExtensionTestNotificationObserver::NotificationSet::
|
| // ExtensionTestNotificationObserver
|
|
|
| ExtensionTestNotificationObserver::ExtensionTestNotificationObserver(
|
| - Browser* browser)
|
| - : browser_(browser),
|
| - profile_(NULL),
|
| + content::BrowserContext* context)
|
| + : context_(context),
|
| extension_installs_observed_(0),
|
| extension_load_errors_observed_(0),
|
| - crx_installers_done_observed_(0) {
|
| -}
|
| + crx_installers_done_observed_(0) {}
|
|
|
| ExtensionTestNotificationObserver::~ExtensionTestNotificationObserver() {}
|
|
|
| -Profile* ExtensionTestNotificationObserver::GetProfile() {
|
| - if (!profile_) {
|
| - if (browser_)
|
| - profile_ = browser_->profile();
|
| - else
|
| - profile_ = ProfileManager::GetActiveUserProfile();
|
| - }
|
| - return profile_;
|
| -}
|
| -
|
| void ExtensionTestNotificationObserver::WaitForNotification(
|
| int notification_type) {
|
| // TODO(bauerb): Using a WindowedNotificationObserver like this can break
|
| // easily, if the notification we're waiting for is sent before this method.
|
| // Change it so that the WindowedNotificationObserver is constructed earlier.
|
| content::NotificationRegistrar registrar;
|
| - registrar.Add(
|
| - this, notification_type, content::NotificationService::AllSources());
|
| + registrar.Add(this, notification_type,
|
| + content::NotificationService::AllSources());
|
| content::WindowedNotificationObserver(
|
| - notification_type, content::NotificationService::AllSources()).Wait();
|
| -}
|
| -
|
| -bool ExtensionTestNotificationObserver::WaitForPageActionVisibilityChangeTo(
|
| - int count) {
|
| - extensions::ExtensionActionAPI::Get(GetProfile())->AddObserver(this);
|
| - WaitForCondition(
|
| - base::Bind(&HasPageActionVisibilityReachedTarget, browser_, count),
|
| - NULL);
|
| - extensions::ExtensionActionAPI::Get(GetProfile())->
|
| - RemoveObserver(this);
|
| - return true;
|
| -}
|
| -
|
| -bool ExtensionTestNotificationObserver::WaitForExtensionViewsToLoad() {
|
| - extensions::ProcessManager* manager =
|
| - extensions::ProcessManager::Get(GetProfile());
|
| - NotificationSet notification_set;
|
| - notification_set.Add(content::NOTIFICATION_WEB_CONTENTS_DESTROYED);
|
| - notification_set.Add(content::NOTIFICATION_LOAD_STOP);
|
| - notification_set.AddExtensionFrameUnregistration(manager);
|
| - WaitForCondition(
|
| - base::Bind(&HaveAllExtensionRenderFrameHostsFinishedLoading, manager),
|
| - ¬ification_set);
|
| - return true;
|
| -}
|
| -
|
| -bool ExtensionTestNotificationObserver::WaitForExtensionIdle(
|
| - const std::string& extension_id) {
|
| - NotificationSet notification_set;
|
| - notification_set.Add(content::NOTIFICATION_RENDERER_PROCESS_TERMINATED);
|
| - WaitForCondition(base::Bind(&extensions::util::IsExtensionIdle, extension_id,
|
| - GetProfile()),
|
| - ¬ification_set);
|
| - return true;
|
| -}
|
| -
|
| -bool ExtensionTestNotificationObserver::WaitForExtensionNotIdle(
|
| - const std::string& extension_id) {
|
| - NotificationSet notification_set;
|
| - notification_set.Add(content::NOTIFICATION_LOAD_STOP);
|
| - WaitForCondition(base::Bind(&IsExtensionNotIdle, extension_id, GetProfile()),
|
| - ¬ification_set);
|
| - return true;
|
| + notification_type, content::NotificationService::AllSources())
|
| + .Wait();
|
| }
|
|
|
| bool ExtensionTestNotificationObserver::WaitForExtensionInstallError() {
|
| int before = extension_installs_observed_;
|
| content::WindowedNotificationObserver(
|
| extensions::NOTIFICATION_EXTENSION_INSTALL_ERROR,
|
| - content::NotificationService::AllSources()).Wait();
|
| + content::NotificationService::AllSources())
|
| + .Wait();
|
| return extension_installs_observed_ == before;
|
| }
|
|
|
| @@ -212,11 +105,6 @@ void ExtensionTestNotificationObserver::WaitForExtensionLoad() {
|
| WaitForNotification(extensions::NOTIFICATION_EXTENSION_LOADED_DEPRECATED);
|
| }
|
|
|
| -void ExtensionTestNotificationObserver::WaitForExtensionAndViewLoad() {
|
| - this->WaitForExtensionLoad();
|
| - WaitForExtensionViewsToLoad();
|
| -}
|
| -
|
| bool ExtensionTestNotificationObserver::WaitForExtensionLoadError() {
|
| int before = extension_load_errors_observed_;
|
| WaitForNotification(extensions::NOTIFICATION_EXTENSION_LOAD_ERROR);
|
| @@ -225,23 +113,22 @@ bool ExtensionTestNotificationObserver::WaitForExtensionLoadError() {
|
|
|
| bool ExtensionTestNotificationObserver::WaitForExtensionCrash(
|
| const std::string& extension_id) {
|
| - ExtensionService* service = extensions::ExtensionSystem::Get(
|
| - GetProfile())->extension_service();
|
| -
|
| - if (!service->GetExtensionById(extension_id, true)) {
|
| + if (!GetNonTerminatedExtensions(extension_id, context_)) {
|
| // The extension is already unloaded, presumably due to a crash.
|
| return true;
|
| }
|
| +
|
| content::WindowedNotificationObserver(
|
| extensions::NOTIFICATION_EXTENSION_PROCESS_TERMINATED,
|
| - content::NotificationService::AllSources()).Wait();
|
| - return (service->GetExtensionById(extension_id, true) == NULL);
|
| + content::NotificationService::AllSources())
|
| + .Wait();
|
| + return (GetNonTerminatedExtensions(extension_id, context_) == NULL);
|
| }
|
|
|
| bool ExtensionTestNotificationObserver::WaitForCrxInstallerDone() {
|
| int before = crx_installers_done_observed_;
|
| WaitForNotification(extensions::NOTIFICATION_CRX_INSTALLER_DONE);
|
| - return crx_installers_done_observed_ == (before + 1);
|
| + return crx_installers_done_observed_ == before + 1;
|
| }
|
|
|
| void ExtensionTestNotificationObserver::Watch(
|
| @@ -266,19 +153,19 @@ void ExtensionTestNotificationObserver::Observe(
|
| switch (type) {
|
| case extensions::NOTIFICATION_EXTENSION_LOADED_DEPRECATED:
|
| last_loaded_extension_id_ =
|
| - content::Details<const Extension>(details).ptr()->id();
|
| + content::Details<const Extension>(details).ptr()->id();
|
| VLOG(1) << "Got EXTENSION_LOADED notification.";
|
| break;
|
|
|
| case extensions::NOTIFICATION_CRX_INSTALLER_DONE:
|
| VLOG(1) << "Got CRX_INSTALLER_DONE notification.";
|
| {
|
| - const Extension* extension =
|
| + const Extension* extension =
|
| content::Details<const Extension>(details).ptr();
|
| - if (extension)
|
| - last_loaded_extension_id_ = extension->id();
|
| - else
|
| - last_loaded_extension_id_.clear();
|
| + if (extension)
|
| + last_loaded_extension_id_ = extension->id();
|
| + else
|
| + last_loaded_extension_id_.clear();
|
| }
|
| ++crx_installers_done_observed_;
|
| break;
|
| @@ -294,11 +181,6 @@ void ExtensionTestNotificationObserver::Observe(
|
| }
|
| }
|
|
|
| -void ExtensionTestNotificationObserver::OnPageActionsUpdated(
|
| - content::WebContents* web_contents) {
|
| - MaybeQuit();
|
| -}
|
| -
|
| void ExtensionTestNotificationObserver::WaitForCondition(
|
| const ConditionCallback& condition,
|
| NotificationSet* notification_set) {
|
| @@ -312,9 +194,8 @@ void ExtensionTestNotificationObserver::WaitForCondition(
|
|
|
| std::unique_ptr<base::CallbackList<void()>::Subscription> subscription;
|
| if (notification_set) {
|
| - subscription = notification_set->callback_list().Add(
|
| - base::Bind(&ExtensionTestNotificationObserver::MaybeQuit,
|
| - base::Unretained(this)));
|
| + subscription = notification_set->callback_list().Add(base::Bind(
|
| + &ExtensionTestNotificationObserver::MaybeQuit, base::Unretained(this)));
|
| }
|
| runner->Run();
|
|
|
|
|