summaryrefslogtreecommitdiffstats
path: root/extensions
diff options
context:
space:
mode:
authord.halman@gmail.com <d.halman@gmail.com@0039d316-1c4b-4281-b951-d872f2087c98>2014-03-22 06:14:18 +0000
committerd.halman@gmail.com <d.halman@gmail.com@0039d316-1c4b-4281-b951-d872f2087c98>2014-03-22 06:14:18 +0000
commit0b36507c63d3a524a1cdad7f1585c16327684b10 (patch)
treee12d734e14a12cf020e398cc17bc550be512b0a5 /extensions
parent002da7b2877ebd64d6ae62d98bf2a196c0a98eae (diff)
downloadchromium_src-0b36507c63d3a524a1cdad7f1585c16327684b10.zip
chromium_src-0b36507c63d3a524a1cdad7f1585c16327684b10.tar.gz
chromium_src-0b36507c63d3a524a1cdad7f1585c16327684b10.tar.bz2
Ensure extensions.getViews(type: "tab") contains tab created by window.open
A tab's ViewType is set by RenderViewCreated. It turns out window.open does not trigger a call to ExtensionWebContentsObserver::RenderViewCreated like tabs.create does. This is the reason ViewType is not set for window.open. The constructor is called for both cases, and I found that sending the same message: render_view_host->Send(new ExtensionMsg_NotifyRenderViewType( render_view_host->GetRoutingID(), GetViewType(web_contents()))); from the constructor (copy pasted from RenderViewCreated) ensures the view's type is set from the web contents whether or not the view was rendered. This passes the test extension posted in the bug description. However, this may be a simple cover up for the real issue of RenderViewCreated not being called in the window.open case. I am not extremely familiar with the way this object is supposed to be treated, so I'll defer to reviewers on the proper fix. BUG=341459 Review URL: https://codereview.chromium.org/200513007 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@258794 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'extensions')
-rw-r--r--extensions/browser/extension_web_contents_observer.cc15
-rw-r--r--extensions/browser/extension_web_contents_observer.h3
2 files changed, 15 insertions, 3 deletions
diff --git a/extensions/browser/extension_web_contents_observer.cc b/extensions/browser/extension_web_contents_observer.cc
index e64fff1..62ebed8 100644
--- a/extensions/browser/extension_web_contents_observer.cc
+++ b/extensions/browser/extension_web_contents_observer.cc
@@ -21,14 +21,15 @@ namespace extensions {
ExtensionWebContentsObserver::ExtensionWebContentsObserver(
content::WebContents* web_contents)
: content::WebContentsObserver(web_contents),
- browser_context_(web_contents->GetBrowserContext()) {}
+ browser_context_(web_contents->GetBrowserContext()) {
+ NotifyRenderViewType(web_contents->GetRenderViewHost());
+}
ExtensionWebContentsObserver::~ExtensionWebContentsObserver() {}
void ExtensionWebContentsObserver::RenderViewCreated(
content::RenderViewHost* render_view_host) {
- render_view_host->Send(new ExtensionMsg_NotifyRenderViewType(
- render_view_host->GetRoutingID(), GetViewType(web_contents())));
+ NotifyRenderViewType(render_view_host);
const Extension* extension = GetExtension(render_view_host);
if (!extension)
@@ -82,6 +83,14 @@ void ExtensionWebContentsObserver::RenderViewCreated(
}
}
+void ExtensionWebContentsObserver::NotifyRenderViewType(
+ content::RenderViewHost* render_view_host) {
+ if (render_view_host) {
+ render_view_host->Send(new ExtensionMsg_NotifyRenderViewType(
+ render_view_host->GetRoutingID(), GetViewType(web_contents())));
+ }
+}
+
const Extension* ExtensionWebContentsObserver::GetExtension(
content::RenderViewHost* render_view_host) {
std::string extension_id = GetExtensionId(render_view_host);
diff --git a/extensions/browser/extension_web_contents_observer.h b/extensions/browser/extension_web_contents_observer.h
index a366e43..5cb797b 100644
--- a/extensions/browser/extension_web_contents_observer.h
+++ b/extensions/browser/extension_web_contents_observer.h
@@ -45,6 +45,9 @@ class ExtensionWebContentsObserver : public content::WebContentsObserver {
// NULL if the render view host is not for a valid extension.
const Extension* GetExtension(content::RenderViewHost* render_view_host);
+ // Updates ViewType for RenderViewHost based on GetViewType(web_contents()).
+ void NotifyRenderViewType(content::RenderViewHost* render_view_host);
+
// Returns the extension or app ID associated with a render view host. Returns
// the empty string if the render view host is not for a valid extension.
static std::string GetExtensionId(content::RenderViewHost* render_view_host);