refactor: use owner window for BrowserWindow.fromWebContents (#25408)

This commit is contained in:
Jeremy Rose 2020-09-14 13:49:57 -07:00 committed by GitHub
parent 9f4a097e03
commit 87d67a9365
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -1579,6 +1579,30 @@ describe('BrowserWindow module', () => {
contents.destroy(); contents.destroy();
} }
}); });
it('returns the correct window for a BrowserView webcontents', async () => {
const w = new BrowserWindow({ show: false });
const bv = new BrowserView();
w.setBrowserView(bv);
defer(() => {
w.removeBrowserView(bv);
(bv.webContents as any).destroy();
});
await bv.webContents.loadURL('about:blank');
expect(BrowserWindow.fromWebContents(bv.webContents)!.id).to.equal(w.id);
});
it('returns the correct window for a WebView webcontents', async () => {
const w = new BrowserWindow({ show: false, webPreferences: { webviewTag: true } });
w.loadURL('data:text/html,<webview src="data:text/html,hi"></webview>');
// NOTE(nornagon): Waiting for 'did-attach-webview' is a workaround for
// https://github.com/electron/electron/issues/25413, and is not integral
// to the test.
const p = emittedOnce(w.webContents, 'did-attach-webview');
const [, webviewContents] = await emittedOnce(app, 'web-contents-created');
expect(BrowserWindow.fromWebContents(webviewContents)!.id).to.equal(w.id);
await p;
});
}); });
describe('BrowserWindow.openDevTools()', () => { describe('BrowserWindow.openDevTools()', () => {