diff --git a/shell/browser/api/electron_api_web_contents.cc b/shell/browser/api/electron_api_web_contents.cc index a71c2d8ea11f..3e3e0d3b9f5f 100644 --- a/shell/browser/api/electron_api_web_contents.cc +++ b/shell/browser/api/electron_api_web_contents.cc @@ -1066,22 +1066,13 @@ void WebContents::RenderFrameCreated( rwh_impl->disable_hidden_ = !background_throttling_; } -void WebContents::RenderViewHostChanged(content::RenderViewHost* old_host, - content::RenderViewHost* new_host) { - currently_committed_process_id_ = new_host->GetProcess()->GetID(); -} - void WebContents::RenderViewDeleted(content::RenderViewHost* render_view_host) { // This event is necessary for tracking any states with respect to // intermediate render view hosts aka speculative render view hosts. Currently // used by object-registry.js to ref count remote objects. Emit("render-view-deleted", render_view_host->GetProcess()->GetID()); - if (-1 == currently_committed_process_id_ || - render_view_host->GetProcess()->GetID() == - currently_committed_process_id_) { - currently_committed_process_id_ = -1; - + if (web_contents()->GetRenderViewHost() == render_view_host) { // When the RVH that has been deleted is the current RVH it means that the // the web contents are being closed. This is communicated by this event. // Currently tracked by guest-window-manager.js to destroy the diff --git a/shell/browser/api/electron_api_web_contents.h b/shell/browser/api/electron_api_web_contents.h index 0c1387d137d6..757f61a7d30b 100644 --- a/shell/browser/api/electron_api_web_contents.h +++ b/shell/browser/api/electron_api_web_contents.h @@ -556,8 +556,6 @@ class WebContents : public gin::Wrappable, const base::TimeTicks& proceed_time) override; void RenderViewCreated(content::RenderViewHost* render_view_host) override; void RenderFrameCreated(content::RenderFrameHost* render_frame_host) override; - void RenderViewHostChanged(content::RenderViewHost* old_host, - content::RenderViewHost* new_host) override; void RenderViewDeleted(content::RenderViewHost*) override; void RenderProcessGone(base::TerminationStatus status) override; void RenderFrameDeleted(content::RenderFrameHost* render_frame_host) override; @@ -696,10 +694,6 @@ class WebContents : public gin::Wrappable, bool initially_shown_ = true; - // The ID of the process of the currently committed RenderViewHost. - // -1 means no speculative RVH has been committed yet. - int currently_committed_process_id_ = -1; - service_manager::BinderRegistryWithArgs registry_; mojo::ReceiverSet receivers_; diff --git a/spec-main/api-web-contents-spec.ts b/spec-main/api-web-contents-spec.ts index 536c13734f40..d45ce0517bd3 100644 --- a/spec-main/api-web-contents-spec.ts +++ b/spec-main/api-web-contents-spec.ts @@ -1156,6 +1156,10 @@ describe('webContents module', () => { res.end(); } else if (req.url === '/redirected') { res.end(''); + } else if (req.url === '/first-window-open') { + res.end(``); + } else if (req.url === '/second-window-open') { + res.end(''); } else { res.end(); } @@ -1192,6 +1196,27 @@ describe('webContents module', () => { expect(currentRenderViewDeletedEmitted).to.be.false('current-render-view-deleted was emitted'); }); + it('does not emit current-render-view-deleted when speculative RVHs are deleted and nativeWindowOpen is set to true', async () => { + const parentWindow = new BrowserWindow({ show: false, webPreferences: { nativeWindowOpen: true } }); + let currentRenderViewDeletedEmitted = false; + let childWindow:BrowserWindow; + const destroyed = emittedOnce(parentWindow.webContents, 'destroyed'); + const renderViewDeletedHandler = () => { + currentRenderViewDeletedEmitted = true; + }; + app.once('browser-window-created', (event, window) => { + childWindow = window; + window.webContents.on('current-render-view-deleted' as any, renderViewDeletedHandler); + }); + parentWindow.loadURL(`${serverUrl}/first-window-open`); + setTimeout(() => { + childWindow.webContents.removeListener('current-render-view-deleted' as any, renderViewDeletedHandler); + parentWindow.close(); + }, 500); + await destroyed; + expect(currentRenderViewDeletedEmitted).to.be.false('child window was destroyed'); + }); + it('emits current-render-view-deleted if the current RVHs are deleted', async () => { const w = new BrowserWindow({ show: false }); let currentRenderViewDeletedEmitted = false;