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

Side by Side Diff: extensions/test/extension_test_notification_observer.h

Issue 2393343002: Split ExtensionTestObserver and move to //extensions. (Closed)
Patch Set: . Created 4 years, 2 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 2013 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 #ifndef CHROME_BROWSER_EXTENSIONS_EXTENSION_TEST_NOTIFICATION_OBSERVER_H_ 5 #ifndef EXTENSIONS_TEST_EXTENSION_TEST_NOTIFICATION_OBSERVER_H_
6 #define CHROME_BROWSER_EXTENSIONS_EXTENSION_TEST_NOTIFICATION_OBSERVER_H_ 6 #define EXTENSIONS_TEST_EXTENSION_TEST_NOTIFICATION_OBSERVER_H_
7 7
8 #include <memory>
8 #include <string> 9 #include <string>
9 10
10 #include "base/callback.h" 11 #include "base/callback.h"
11 #include "base/compiler_specific.h" 12 #include "base/callback_list.h"
12 #include "chrome/browser/chrome_notification_types.h" 13 #include "base/macros.h"
13 #include "chrome/browser/extensions/api/extension_action/extension_action_api.h" 14 #include "base/scoped_observer.h"
14 #include "chrome/browser/ui/browser.h"
15 #include "chrome/browser/ui/location_bar/location_bar.h"
16 #include "content/public/browser/notification_details.h" 15 #include "content/public/browser/notification_details.h"
Devlin 2016/10/11 22:53:45 forward declaration?
Rahul Chaturvedi 2016/10/12 20:25:54 Done.
17 #include "content/public/browser/notification_observer.h" 16 #include "content/public/browser/notification_observer.h"
17 #include "content/public/browser/notification_registrar.h"
18 #include "content/public/browser/notification_types.h" 18 #include "content/public/browser/notification_types.h"
Devlin 2016/10/11 22:53:45 Where do we use this?
Rahul Chaturvedi 2016/10/12 20:25:53 We aren't. Looks like a lot of other tests are tho
19 #include "extensions/browser/process_manager.h"
Devlin 2016/10/11 22:53:46 forward declaration?
Rahul Chaturvedi 2016/10/12 20:25:54 Done.
20 #include "extensions/browser/process_manager_observer.h"
19 21
20 namespace content { 22 namespace content {
23 class BrowserContext;
21 class WindowedNotificationObserver; 24 class WindowedNotificationObserver;
22 } 25 }
23 26
24 // Test helper class for observing extension-related events. 27 // Test helper class for observing extension-related events.
25 class ExtensionTestNotificationObserver 28 class ExtensionTestNotificationObserver : public content::NotificationObserver {
26 : public content::NotificationObserver,
27 public extensions::ExtensionActionAPI::Observer {
28 public: 29 public:
29 explicit ExtensionTestNotificationObserver(Browser* browser); 30 explicit ExtensionTestNotificationObserver(content::BrowserContext* context);
30 ~ExtensionTestNotificationObserver() override; 31 ~ExtensionTestNotificationObserver() override;
31 32
32 // Wait for the number of visible page actions to change to |count|.
33 bool WaitForPageActionVisibilityChangeTo(int count);
34
35 // Wait for an extension install error to be raised. Returns true if an 33 // Wait for an extension install error to be raised. Returns true if an
36 // error was raised. 34 // error was raised.
37 bool WaitForExtensionInstallError(); 35 bool WaitForExtensionInstallError();
38 36
39 // Waits until an extension is loaded and all view have loaded.
40 void WaitForExtensionAndViewLoad();
41
42 // Waits until an extension is loaded. 37 // Waits until an extension is loaded.
43 void WaitForExtensionLoad(); 38 void WaitForExtensionLoad();
44 39
45 // Waits for an extension load error. Returns true if the error really 40 // Waits for an extension load error. Returns true if the error really
46 // happened. 41 // happened.
47 bool WaitForExtensionLoadError(); 42 bool WaitForExtensionLoadError();
48 43
49 // Wait for the specified extension to crash. Returns true if it really 44 // Wait for the specified extension to crash. Returns true if it really
50 // crashed. 45 // crashed.
51 bool WaitForExtensionCrash(const std::string& extension_id); 46 bool WaitForExtensionCrash(const std::string& extension_id);
52 47
53 // Wait for the crx installer to be done. Returns true if it really is done. 48 // Wait for the crx installer to be done. Returns true if it really is done.
54 bool WaitForCrxInstallerDone(); 49 bool WaitForCrxInstallerDone();
55 50
56 // Wait for all extension views to load.
57 bool WaitForExtensionViewsToLoad();
58
59 // Wait for extension to be idle.
60 bool WaitForExtensionIdle(const std::string& extension_id);
61
62 // Wait for extension to be not idle.
63 bool WaitForExtensionNotIdle(const std::string& extension_id);
64
65 // Watch for the given event type from the given source. 51 // Watch for the given event type from the given source.
66 // After calling this method, call Wait() to ensure that RunMessageLoop() is 52 // After calling this method, call Wait() to ensure that RunMessageLoop() is
67 // called appropriately and cleanup is performed. 53 // called appropriately and cleanup is performed.
68 void Watch(int type, const content::NotificationSource& source); 54 void Watch(int type, const content::NotificationSource& source);
69 55
70 // After registering one or more event types with Watch(), call 56 // After registering one or more event types with Watch(), call
71 // this method to run the message loop and perform cleanup. 57 // this method to run the message loop and perform cleanup.
72 void Wait(); 58 void Wait();
73 59
74 const std::string& last_loaded_extension_id() { 60 const std::string& last_loaded_extension_id() {
75 return last_loaded_extension_id_; 61 return last_loaded_extension_id_;
76 } 62 }
77 void set_last_loaded_extension_id( 63 void set_last_loaded_extension_id(
78 const std::string& last_loaded_extension_id) { 64 const std::string& last_loaded_extension_id) {
79 last_loaded_extension_id_ = last_loaded_extension_id; 65 last_loaded_extension_id_ = last_loaded_extension_id;
80 } 66 }
81 67
82 // content::NotificationObserver 68 // content::NotificationObserver
83 void Observe(int type, 69 void Observe(int type,
84 const content::NotificationSource& source, 70 const content::NotificationSource& source,
85 const content::NotificationDetails& details) override; 71 const content::NotificationDetails& details) override;
86 72
87 private: 73 protected:
88 class NotificationSet; 74 class NotificationSet : public content::NotificationObserver,
75 public extensions::ProcessManagerObserver {
76 public:
77 NotificationSet();
78 ~NotificationSet() override;
89 79
90 Profile* GetProfile(); 80 void Add(int type, const content::NotificationSource& source);
81 void Add(int type);
82 void AddExtensionFrameUnregistration(extensions::ProcessManager* manager);
91 83
92 void WaitForNotification(int notification_type); 84 // Notified any time an Add()ed notification is received.
85 // The details of the notification are dropped.
86 base::CallbackList<void()>& callback_list() { return callback_list_; }
87
88 private:
89 // content::NotificationObserver:
90 void Observe(int type,
91 const content::NotificationSource& source,
92 const content::NotificationDetails& details) override;
93
94 // extensions::ProcessManagerObserver:
95 void OnExtensionFrameUnregistered(
96 const std::string& extension_id,
97 content::RenderFrameHost* render_frame_host) override;
98
99 content::NotificationRegistrar notification_registrar_;
100 base::CallbackList<void()> callback_list_;
101 ScopedObserver<extensions::ProcessManager,
102 extensions::ProcessManagerObserver>
103 process_manager_observer_;
104 DISALLOW_COPY_AND_ASSIGN(NotificationSet);
105 };
93 106
94 // Wait for |condition_| to be met. |notification_set| is the set of 107 // Wait for |condition_| to be met. |notification_set| is the set of
95 // notifications to wait for and to check |condition| when observing. This 108 // notifications to wait for and to check |condition| when observing. This
96 // can be NULL if we are instead waiting for a different observer method, like 109 // can be NULL if we are instead waiting for a different observer method, like
97 // OnPageActionsUpdated(). 110 // OnPageActionsUpdated().
98 void WaitForCondition(const base::Callback<bool(void)>& condition, 111 void WaitForCondition(const base::Callback<bool(void)>& condition,
99 NotificationSet* notification_set); 112 NotificationSet* notification_set);
100 113
114 void WaitForNotification(int notification_type);
115
101 // Quits the message loop if |condition_| is met. 116 // Quits the message loop if |condition_| is met.
102 void MaybeQuit(); 117 void MaybeQuit();
103 118
104 // extensions::ExtensionActionAPI::Observer: 119 content::BrowserContext* context_;
Devlin 2016/10/11 22:53:46 nit: prefer making this private and exposing conte
Rahul Chaturvedi 2016/10/12 20:25:53 Done.
105 void OnPageActionsUpdated(content::WebContents* contents) override;
106 120
107 Browser* browser_; 121 private:
108 Profile* profile_;
109
110 content::NotificationRegistrar registrar_; 122 content::NotificationRegistrar registrar_;
111 std::unique_ptr<content::WindowedNotificationObserver> observer_; 123 std::unique_ptr<content::WindowedNotificationObserver> observer_;
112 124
113 std::string last_loaded_extension_id_; 125 std::string last_loaded_extension_id_;
114 int extension_installs_observed_; 126 int extension_installs_observed_;
115 int extension_load_errors_observed_; 127 int extension_load_errors_observed_;
116 int crx_installers_done_observed_; 128 int crx_installers_done_observed_;
117 129
118 // The condition for which we are waiting. This should be checked in any 130 // The condition for which we are waiting. This should be checked in any
119 // observing methods that could trigger it. 131 // observing methods that could trigger it.
120 base::Callback<bool(void)> condition_; 132 base::Callback<bool(void)> condition_;
121 133
122 // The closure to quit the currently-running message loop. 134 // The closure to quit the currently-running message loop.
123 base::Closure quit_closure_; 135 base::Closure quit_closure_;
136
137 DISALLOW_COPY_AND_ASSIGN(ExtensionTestNotificationObserver);
124 }; 138 };
125 139
126 #endif // CHROME_BROWSER_EXTENSIONS_EXTENSION_TEST_NOTIFICATION_OBSERVER_H_ 140 #endif // EXTENSIONS_TEST_EXTENSION_TEST_NOTIFICATION_OBSERVER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698