test: remove a bunch of usage of the remote module (#21119)

This commit is contained in:
Jeremy Apthorp 2019-11-14 14:09:03 -08:00 committed by GitHub
parent 4f1536479e
commit 26ecf63ab4
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
22 changed files with 124 additions and 125 deletions

View file

@ -80,7 +80,12 @@ describe('BrowserWindow module', () => {
}) })
it('should emit beforeunload handler', async () => { it('should emit beforeunload handler', async () => {
await w.loadFile(path.join(fixtures, 'api', 'beforeunload-false.html')) await w.loadFile(path.join(fixtures, 'api', 'beforeunload-false.html'))
const beforeunload = emittedOnce(w, 'onbeforeunload') const beforeunload = new Promise(resolve => {
ipcMain.once('onbeforeunload', (e) => {
e.returnValue = null
resolve()
})
})
w.close() w.close()
await beforeunload await beforeunload
}) })
@ -164,8 +169,9 @@ describe('BrowserWindow module', () => {
expect(content).to.equal('close') expect(content).to.equal('close')
}) })
it('should emit beforeunload event', async () => { it('should emit beforeunload event', async () => {
w.loadFile(path.join(fixtures, 'api', 'close-beforeunload-false.html')) w.loadFile(path.join(__dirname, 'fixtures', 'api', 'close-beforeunload-false.html'))
await emittedOnce(w, 'onbeforeunload') const [e] = await emittedOnce(ipcMain, 'onbeforeunload')
e.returnValue = null
}) })
}) })
@ -1552,7 +1558,7 @@ describe('BrowserWindow module', () => {
expect(test).to.eql('preload') expect(test).to.eql('preload')
}) })
it('can successfully delete the Buffer global', async () => { it('can successfully delete the Buffer global', async () => {
const preload = path.join(fixtures, 'module', 'delete-buffer.js') const preload = path.join(__dirname, 'fixtures', 'module', 'delete-buffer.js')
const w = new BrowserWindow({ const w = new BrowserWindow({
show: false, show: false,
webPreferences: { webPreferences: {
@ -1676,7 +1682,7 @@ describe('BrowserWindow module', () => {
describe('"enableRemoteModule" option', () => { describe('"enableRemoteModule" option', () => {
const generateSpecs = (description: string, sandbox: boolean) => { const generateSpecs = (description: string, sandbox: boolean) => {
describe(description, () => { describe(description, () => {
const preload = path.join(fixtures, 'module', 'preload-remote.js') const preload = path.join(__dirname, 'fixtures', 'module', 'preload-remote.js')
it('enables the remote module by default', async () => { it('enables the remote module by default', async () => {
const w = new BrowserWindow({ const w = new BrowserWindow({
@ -1794,7 +1800,7 @@ describe('BrowserWindow module', () => {
preload preload
} }
}) })
const htmlPath = path.join(fixtures, 'api', 'sandbox.html?exit-event') const htmlPath = path.join(__dirname, 'fixtures', 'api', 'sandbox.html?exit-event')
const pageUrl = 'file://' + htmlPath const pageUrl = 'file://' + htmlPath
w.loadURL(pageUrl) w.loadURL(pageUrl)
const [, url] = await emittedOnce(ipcMain, 'answer') const [, url] = await emittedOnce(ipcMain, 'answer')
@ -1815,7 +1821,7 @@ describe('BrowserWindow module', () => {
w.webContents.once('new-window', (event, url, frameName, disposition, options) => { w.webContents.once('new-window', (event, url, frameName, disposition, options) => {
options.webPreferences!.preload = preload options.webPreferences!.preload = preload
}) })
const htmlPath = path.join(fixtures, 'api', 'sandbox.html?window-open') const htmlPath = path.join(__dirname, 'fixtures', 'api', 'sandbox.html?window-open')
const pageUrl = 'file://' + htmlPath const pageUrl = 'file://' + htmlPath
const answer = emittedOnce(ipcMain, 'answer') const answer = emittedOnce(ipcMain, 'answer')
w.loadURL(pageUrl) w.loadURL(pageUrl)
@ -1844,7 +1850,7 @@ describe('BrowserWindow module', () => {
options.webPreferences!.preload = preload options.webPreferences!.preload = preload
}) })
w.loadFile( w.loadFile(
path.join(fixtures, 'api', 'sandbox.html'), path.join(__dirname, 'fixtures', 'api', 'sandbox.html'),
{ search: 'window-open-external' } { search: 'window-open-external' }
) )
@ -1921,7 +1927,11 @@ describe('BrowserWindow module', () => {
prefs.foo = 'bar' prefs.foo = 'bar'
}) })
w.loadFile(path.join(fixtures, 'api', 'new-window.html')) w.loadFile(path.join(fixtures, 'api', 'new-window.html'))
const [, , webPreferences] = await emittedOnce(ipcMain, 'answer') const [[, childWebContents]] = await Promise.all([
emittedOnce(app, 'web-contents-created'),
emittedOnce(ipcMain, 'answer')
])
const webPreferences = (childWebContents as any).getLastWebPreferences()
expect(webPreferences.foo).to.equal('bar') expect(webPreferences.foo).to.equal('bar')
}) })
@ -1952,7 +1962,7 @@ describe('BrowserWindow module', () => {
'parent-answer', 'parent-answer',
'child-answer' 'child-answer'
], done) ], done)
w.loadFile(path.join(fixtures, 'api', 'sandbox.html'), { search: 'verify-ipc-sender' }) w.loadFile(path.join(__dirname, 'fixtures', 'api', 'sandbox.html'), { search: 'verify-ipc-sender' })
}) })
describe('event handling', () => { describe('event handling', () => {
@ -1988,7 +1998,7 @@ describe('BrowserWindow module', () => {
'did-frame-finish-load', 'did-frame-finish-load',
'dom-ready' 'dom-ready'
], done) ], done)
w.loadFile(path.join(fixtures, 'api', 'sandbox.html'), { search: 'webcontents-events' }) w.loadFile(path.join(__dirname, 'fixtures', 'api', 'sandbox.html'), { search: 'webcontents-events' })
}) })
}) })
@ -2021,7 +2031,7 @@ describe('BrowserWindow module', () => {
sandbox: true sandbox: true
} }
}) })
w.loadFile(path.join(fixtures, 'api', 'sandbox.html'), { search: 'reload-remote' }) w.loadFile(path.join(__dirname, 'fixtures', 'api', 'sandbox.html'), { search: 'reload-remote' })
ipcMain.on('get-remote-module-path', (event) => { ipcMain.on('get-remote-module-path', (event) => {
event.returnValue = path.join(fixtures, 'module', 'hello.js') event.returnValue = path.join(fixtures, 'module', 'hello.js')
@ -2057,7 +2067,7 @@ describe('BrowserWindow module', () => {
options.webPreferences!.preload = preload options.webPreferences!.preload = preload
}) })
w.loadFile(path.join(fixtures, 'api', 'sandbox.html'), { search: 'reload-remote-child' }) w.loadFile(path.join(__dirname, 'fixtures', 'api', 'sandbox.html'), { search: 'reload-remote-child' })
ipcMain.on('get-remote-module-path', (event) => { ipcMain.on('get-remote-module-path', (event) => {
event.returnValue = path.join(fixtures, 'module', 'hello-child.js') event.returnValue = path.join(fixtures, 'module', 'hello-child.js')
@ -2233,7 +2243,11 @@ describe('BrowserWindow module', () => {
prefs.foo = 'bar' prefs.foo = 'bar'
}) })
w.loadFile(path.join(fixtures, 'api', 'new-window.html')) w.loadFile(path.join(fixtures, 'api', 'new-window.html'))
const [, , webPreferences] = await emittedOnce(ipcMain, 'answer') const [[, childWebContents]] = await Promise.all([
emittedOnce(app, 'web-contents-created'),
emittedOnce(ipcMain, 'answer')
])
const webPreferences = (childWebContents as any).getLastWebPreferences()
expect(webPreferences.foo).to.equal('bar') expect(webPreferences.foo).to.equal('bar')
}) })
it('should have nodeIntegration disabled in child windows', async () => { it('should have nodeIntegration disabled in child windows', async () => {
@ -2359,22 +2373,27 @@ describe('BrowserWindow module', () => {
beforeEach(() => { beforeEach(() => {
w = new BrowserWindow({ show: false, webPreferences: { nodeIntegration: true } }) w = new BrowserWindow({ show: false, webPreferences: { nodeIntegration: true } })
}) })
afterEach(() => {
ipcMain.removeAllListeners('onbeforeunload')
})
afterEach(closeAllWindows) afterEach(closeAllWindows)
it('returning undefined would not prevent close', (done) => { it('returning undefined would not prevent close', (done) => {
w.once('closed', () => { done() }) w.once('closed', () => { done() })
w.loadFile(path.join(fixtures, 'api', 'close-beforeunload-undefined.html')) w.loadFile(path.join(__dirname, 'fixtures', 'api', 'close-beforeunload-undefined.html'))
}) })
it('returning false would prevent close', (done) => { it('returning false would prevent close', async () => {
w.once('onbeforeunload' as any, () => { done() }) w.loadFile(path.join(__dirname, 'fixtures', 'api', 'close-beforeunload-false.html'))
w.loadFile(path.join(fixtures, 'api', 'close-beforeunload-false.html')) const [e] = await emittedOnce(ipcMain, 'onbeforeunload')
e.returnValue = null
}) })
it('returning empty string would prevent close', (done) => { it('returning empty string would prevent close', (done) => {
w.once('onbeforeunload' as any, () => { done() }) ipcMain.once('onbeforeunload', (e) => { e.returnValue = null; done() })
w.loadFile(path.join(fixtures, 'api', 'close-beforeunload-empty-string.html')) w.loadFile(path.join(__dirname, 'fixtures', 'api', 'close-beforeunload-empty-string.html'))
}) })
it('emits for each close attempt', (done) => { it('emits for each close attempt', (done) => {
let beforeUnloadCount = 0 let beforeUnloadCount = 0
w.on('onbeforeunload' as any, () => { ipcMain.on('onbeforeunload', (e) => {
e.returnValue = null
beforeUnloadCount += 1 beforeUnloadCount += 1
if (beforeUnloadCount < 3) { if (beforeUnloadCount < 3) {
w.close() w.close()
@ -2382,12 +2401,13 @@ describe('BrowserWindow module', () => {
done() done()
} }
}) })
w.webContents.once('did-finish-load', () => { w.close() }) w.webContents.once('did-finish-load', () => { w.webContents.executeJavaScript('window.close()', true) })
w.loadFile(path.join(fixtures, 'api', 'beforeunload-false-prevent3.html')) w.loadFile(path.join(__dirname, 'fixtures', 'api', 'beforeunload-false-prevent3.html'))
}) })
it('emits for each reload attempt', (done) => { it('emits for each reload attempt', (done) => {
let beforeUnloadCount = 0 let beforeUnloadCount = 0
w.on('onbeforeunload' as any, () => { ipcMain.on('onbeforeunload', (e) => {
e.returnValue = null
beforeUnloadCount += 1 beforeUnloadCount += 1
if (beforeUnloadCount < 3) { if (beforeUnloadCount < 3) {
w.reload() w.reload()
@ -2401,11 +2421,12 @@ describe('BrowserWindow module', () => {
}) })
w.reload() w.reload()
}) })
w.loadFile(path.join(fixtures, 'api', 'beforeunload-false-prevent3.html')) w.loadFile(path.join(__dirname, 'fixtures', 'api', 'beforeunload-false-prevent3.html'))
}) })
it('emits for each navigation attempt', (done) => { it('emits for each navigation attempt', (done) => {
let beforeUnloadCount = 0 let beforeUnloadCount = 0
w.on('onbeforeunload' as any, () => { ipcMain.on('onbeforeunload', (e) => {
e.returnValue = null
beforeUnloadCount += 1 beforeUnloadCount += 1
if (beforeUnloadCount < 3) { if (beforeUnloadCount < 3) {
w.loadURL('about:blank') w.loadURL('about:blank')
@ -2419,7 +2440,7 @@ describe('BrowserWindow module', () => {
}) })
w.loadURL('about:blank') w.loadURL('about:blank')
}) })
w.loadFile(path.join(fixtures, 'api', 'beforeunload-false-prevent3.html')) w.loadFile(path.join(__dirname, 'fixtures', 'api', 'beforeunload-false-prevent3.html'))
}) })
}) })

View file

@ -45,24 +45,6 @@ describe('ipc main module', () => {
}) })
}) })
describe('remote objects registry', () => {
it('does not dereference until the render view is deleted (regression)', (done) => {
const w = new BrowserWindow({
show: false,
webPreferences: {
nodeIntegration: true
}
})
ipcMain.once('error-message', (event, message) => {
expect(message).to.match(/^Cannot call method 'getURL' on missing remote object/)
done()
})
w.loadFile(path.join(fixtures, 'api', 'render-view-deleted.html'))
})
})
describe('ipcMain.on', () => { describe('ipcMain.on', () => {
it('is not used for internals', async () => { it('is not used for internals', async () => {
const appPath = path.join(fixtures, 'api', 'ipc-main-listeners') const appPath = path.join(fixtures, 'api', 'ipc-main-listeners')

View file

@ -158,6 +158,24 @@ ifdescribe(features.isRemoteModuleEnabled())('remote module', () => {
}) })
}) })
describe('remote objects registry', () => {
it('does not dereference until the render view is deleted (regression)', (done) => {
const w = new BrowserWindow({
show: false,
webPreferences: {
nodeIntegration: true
}
})
ipcMain.once('error-message', (event, message) => {
expect(message).to.match(/^Cannot call method 'getURL' on missing remote object/)
done()
})
w.loadFile(path.join(fixtures, 'api', 'render-view-deleted.html'))
})
})
describe('remote listeners', () => { describe('remote listeners', () => {
afterEach(closeAllWindows) afterEach(closeAllWindows)
@ -168,7 +186,7 @@ ifdescribe(features.isRemoteModuleEnabled())('remote module', () => {
nodeIntegration: true nodeIntegration: true
} }
}) })
await w.loadFile(path.join(__dirname, '..', 'spec', 'fixtures', 'api', 'remote-event-handler.html')) await w.loadFile(path.join(fixtures, 'api', 'remote-event-handler.html'))
w.webContents.reload() w.webContents.reload()
await emittedOnce(w.webContents, 'did-finish-load') await emittedOnce(w.webContents, 'did-finish-load')

View file

@ -47,20 +47,20 @@ describe('webContents module', () => {
w.webContents.once('will-prevent-unload', () => { w.webContents.once('will-prevent-unload', () => {
expect.fail('should not have fired') expect.fail('should not have fired')
}) })
w.loadFile(path.join(fixturesPath, 'api', 'close-beforeunload-undefined.html')) w.loadFile(path.join(__dirname, 'fixtures', 'api', 'close-beforeunload-undefined.html'))
}) })
it('emits if beforeunload returns false', (done) => { it('emits if beforeunload returns false', async () => {
const w = new BrowserWindow({ show: false }) const w = new BrowserWindow({ show: false })
w.webContents.once('will-prevent-unload', () => done()) w.loadFile(path.join(__dirname, 'fixtures', 'api', 'close-beforeunload-false.html'))
w.loadFile(path.join(fixturesPath, 'api', 'close-beforeunload-false.html')) await emittedOnce(w.webContents, 'will-prevent-unload')
}) })
it('supports calling preventDefault on will-prevent-unload events', (done) => { it('supports calling preventDefault on will-prevent-unload events', async () => {
const w = new BrowserWindow({ show: false }) const w = new BrowserWindow({ show: false })
w.webContents.once('will-prevent-unload', event => event.preventDefault()) w.webContents.once('will-prevent-unload', event => event.preventDefault())
w.once('closed', () => done()) w.loadFile(path.join(__dirname, 'fixtures', 'api', 'close-beforeunload-false.html'))
w.loadFile(path.join(fixturesPath, 'api', 'close-beforeunload-false.html')) await emittedOnce(w, 'closed')
}) })
}) })
@ -695,15 +695,19 @@ describe('webContents module', () => {
describe('focus()', () => { describe('focus()', () => {
describe('when the web contents is hidden', () => { describe('when the web contents is hidden', () => {
afterEach(closeAllWindows) afterEach(closeAllWindows)
it('does not blur the focused window', (done) => { it('does not blur the focused window', async () => {
const w = new BrowserWindow({ show: false, webPreferences: { nodeIntegration: true } }) const w = new BrowserWindow({ show: false, webPreferences: { nodeIntegration: true } })
ipcMain.once('answer', (event, parentFocused, childFocused) => {
expect(parentFocused).to.be.true()
expect(childFocused).to.be.false()
done()
})
w.show() w.show()
w.loadFile(path.join(fixturesPath, 'pages', 'focus-web-contents.html')) await w.loadURL('about:blank')
w.focus()
const child = new BrowserWindow({ show: false })
child.loadURL('about:blank')
child.webContents.focus()
const currentFocused = w.isFocused()
const childFocused = child.isFocused()
child.close()
expect(currentFocused).to.be.true()
expect(childFocused).to.be.false()
}) })
}) })
}) })

View file

@ -5,7 +5,7 @@
var unloadPreventedCount = 0; var unloadPreventedCount = 0;
window.onbeforeunload = function() { window.onbeforeunload = function() {
setTimeout(function() { setTimeout(function() {
require('electron').remote.getCurrentWindow().emit('onbeforeunload'); require('electron').ipcRenderer.sendSync('onbeforeunload')
}, 0); }, 0);
if (unloadPreventedCount < 3) { if (unloadPreventedCount < 3) {
unloadPreventedCount++; unloadPreventedCount++;

View file

@ -5,7 +5,7 @@
var unloadPrevented = false; var unloadPrevented = false;
window.onbeforeunload = function() { window.onbeforeunload = function() {
setTimeout(function() { setTimeout(function() {
require('electron').remote.getCurrentWindow().emit('onbeforeunload'); require('electron').ipcRenderer.sendSync('onbeforeunload');
}, 0); }, 0);
if (!unloadPrevented) { if (!unloadPrevented) {

View file

@ -5,7 +5,7 @@
var unloadPrevented = false; var unloadPrevented = false;
window.onbeforeunload = function() { window.onbeforeunload = function() {
setTimeout(function() { setTimeout(function() {
require('electron').remote.getCurrentWindow().emit('onbeforeunload'); require('electron').ipcRenderer.sendSync('onbeforeunload');
}, 0); }, 0);
if (!unloadPrevented) { if (!unloadPrevented) {
unloadPrevented = true; unloadPrevented = true;

View file

@ -0,0 +1,16 @@
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
</head>
<body>
<webview nodeintegration src="./a.html"></webview>
<script>
var wv = document.querySelector('webview')
wv.addEventListener('dom-ready', () => {
wv.openDevTools()
})
</script>
</script>
</body>
</html>

View file

@ -164,7 +164,21 @@ describe('<webview> tag', function () {
const extensionPath = path.join(fixtures, 'devtools-extensions', 'foo') const extensionPath = path.join(fixtures, 'devtools-extensions', 'foo')
BrowserWindow.addDevToolsExtension(extensionPath) BrowserWindow.addDevToolsExtension(extensionPath)
w.loadFile(path.join(fixtures, 'pages', 'webview-devtools.html')) w.loadFile(path.join(__dirname, 'fixtures', 'pages', 'webview-devtools.html'))
app.once('web-contents-created', (e, webContents) => {
webContents.on('devtools-opened', function () {
const showPanelIntervalId = setInterval(function () {
if (!webContents.isDestroyed() && webContents.devToolsWebContents) {
webContents.devToolsWebContents.executeJavaScript('(' + function () {
const lastPanelId: any = (window as any).UI.inspectorView._tabbedPane._tabs.peekLast().id;
(window as any).UI.inspectorView.showPanel(lastPanelId)
}.toString() + ')()')
} else {
clearInterval(showPanelIntervalId)
}
}, 100)
})
})
const [, { runtimeId, tabId }] = await emittedOnce(ipcMain, 'answer') const [, { runtimeId, tabId }] = await emittedOnce(ipcMain, 'answer')
expect(runtimeId).to.equal('foo') expect(runtimeId).to.equal('foo')

View file

@ -233,7 +233,7 @@ ifdescribe(features.isRemoteModuleEnabled())('remote module', () => {
}) })
describe('remote value in browser', () => { describe('remote value in browser', () => {
const print = path.join(fixtures, 'module', 'print_name.js') const print = path.join(__dirname, '..', 'spec-main', 'fixtures', 'module', 'print_name.js')
const printName = remote.require(print) const printName = remote.require(print)
it('preserves NaN', () => { it('preserves NaN', () => {

View file

@ -5,7 +5,7 @@
var unloadPrevented = false; var unloadPrevented = false;
window.onbeforeunload = function() { window.onbeforeunload = function() {
setTimeout(function() { setTimeout(function() {
require('electron').remote.getCurrentWindow().emit('onbeforeunload'); require('electron').ipcRenderer.sendSync('onbeforeunload');
}, 0); }, 0);
if (!unloadPrevented) { if (!unloadPrevented) {
unloadPrevented = true; unloadPrevented = true;

View file

@ -1,4 +1,4 @@
const { ipcRenderer, remote } = require('electron') const { ipcRenderer } = require('electron')
ipcRenderer.send('answer', process.argv, remote.getCurrentWindow().webContents.getWebPreferences()) ipcRenderer.send('answer', process.argv)
window.close() window.close()

View file

@ -1,24 +0,0 @@
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
<script>
const {ipcRenderer, remote} = require('electron')
remote.getCurrentWindow().focus()
const child = new remote.BrowserWindow({show: false})
child.loadURL('about:blank')
child.webContents.focus()
const currentFocused = remote.getCurrentWindow().isFocused()
const childFocused = child.isFocused()
child.close()
ipcRenderer.send('answer', currentFocused, childFocused)
</script>
</head>
<body>
</body>
</html>

View file

@ -1,31 +0,0 @@
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
</head>
<body>
<webview nodeintegration src="./a.html"></webview>
<script>
var wv = document.querySelector('webview')
wv.addEventListener('dom-ready', () => {
const { remote } = require('electron')
const webContents = remote.webContents.fromId(wv.getWebContentsId())
webContents.on('devtools-opened', function () {
var showPanelIntevalId = setInterval(function () {
if (webContents.devToolsWebContents) {
webContents.devToolsWebContents.executeJavaScript('(' + (function () {
var lastPanelId = UI.inspectorView._tabbedPane._tabs.peekLast().id
UI.inspectorView.showPanel(lastPanelId)
}).toString() + ')()')
} else {
clearInterval(showPanelIntevalId)
}
}, 100)
})
wv.openDevTools()
})
</script>
</script>
</body>
</html>

View file

@ -1,8 +1,7 @@
<html> <html>
<body> <body>
<script type="text/javascript" charset="utf-8"> <script type="text/javascript" charset="utf-8">
var size = require('electron').remote.getCurrentWindow().getSize(); window.opener.postMessage('size: ' + outerWidth + ' ' + outerHeight, '*')
window.opener.postMessage('size: ' + size[0] + ' ' + size[1], '*')
</script> </script>
</body> </body>
</html> </html>