test: asyncawaitify one of sandbox related tests (#15252)

This commit is contained in:
Alexey Kuzmin 2018-10-19 05:28:23 +02:00 committed by Samuel Attard
parent 363712d057
commit b3f134de06
3 changed files with 34 additions and 31 deletions

View file

@ -1555,41 +1555,42 @@ describe('BrowserWindow module', () => {
}) })
}) })
it('should open windows in another domain with cross-scripting disabled', (done) => { it('should open windows in another domain with cross-scripting disabled', async () => {
w.destroy() const w = await openTheWindow({
w = new BrowserWindow({
show: false, show: false,
webPreferences: { webPreferences: {
sandbox: true, sandbox: true,
preload: preload preload
} }
}) })
ipcRenderer.send('set-web-preferences-on-next-new-window', w.webContents.id, 'preload', preload) ipcRenderer.send('set-web-preferences-on-next-new-window', w.webContents.id, 'preload', preload)
let popupWindow
w.loadFile(path.join(fixtures, 'api', 'sandbox.html'), { search: 'window-open-external' }) w.loadFile(path.join(fixtures, 'api', 'sandbox.html'), { search: 'window-open-external' })
w.webContents.once('new-window', (e, url, frameName, disposition, options) => { const expectedPopupUrl = 'http://www.google.com/#q=electron' // Set in the "sandbox.html".
assert.strictEqual(url, 'http://www.google.com/#q=electron')
assert.strictEqual(options.width, 505)
assert.strictEqual(options.height, 605)
ipcMain.once('child-loaded', function (event, openerIsNull, html) {
assert(openerIsNull)
assert.strictEqual(html, '<h1>http://www.google.com/#q=electron</h1>')
ipcMain.once('answer', function (event, exceptionMessage) {
assert(/Blocked a frame with origin/.test(exceptionMessage))
// FIXME this popup window should be closed in sandbox.html // The page is going to open a popup that it won't be able to close.
closeWindow(popupWindow, { assertSingleWindow: false }).then(() => { // We have to close it from here later.
popupWindow = null // XXX(alexeykuzmin): It will leak if the test fails too soon.
done() const [, popupWindow] = await emittedOnce(app, 'browser-window-created')
})
})
w.webContents.send('child-loaded')
})
})
app.once('browser-window-created', function (event, window) { // Wait for a message from the popup's preload script.
popupWindow = window const [, openerIsNull, html, locationHref] = await emittedOnce(ipcMain, 'child-loaded')
}) expect(openerIsNull).to.be.true('window.opener is not null')
expect(html).to.equal(`<h1>${expectedPopupUrl}</h1>`,
'looks like a http: request has not been intercepted locally')
expect(locationHref).to.equal(expectedPopupUrl)
// Ask the page to access the popup.
w.webContents.send('touch-the-popup')
const [, exceptionMessage] = await emittedOnce(ipcMain, 'answer')
// We don't need the popup anymore, and its parent page can't close it,
// so let's close it from here before we run any checks.
await closeWindow(popupWindow, { assertSingleWindow: false })
expect(exceptionMessage).to.be.a('string',
`child's .document is accessible from its parent window`)
expect(exceptionMessage).to.match(/^Blocked a frame with origin/)
}) })
it('should inherit the sandbox setting in opened windows', (done) => { it('should inherit the sandbox setting in opened windows', (done) => {

View file

@ -81,12 +81,14 @@
}, },
'window-open-external': () => { 'window-open-external': () => {
addEventListener('load', () => { addEventListener('load', () => {
ipcRenderer.once('child-loaded', (e) => { ipcRenderer.once('touch-the-popup', () => {
let errorMessage = null
try { try {
let childDoc = popup.document const childDoc = popup.document
} catch (e) { } catch (error) {
ipcRenderer.send('answer', e.message) errorMessage = error.message
} }
ipcRenderer.send('answer', errorMessage)
}) })
popup = open('http://www.google.com/#q=electron', '', 'top=65,left=55,width=505,height=605') popup = open('http://www.google.com/#q=electron', '', 'top=65,left=55,width=505,height=605')
}) })

View file

@ -23,7 +23,7 @@
} }
} else if (location.href !== 'about:blank') { } else if (location.href !== 'about:blank') {
addEventListener('DOMContentLoaded', () => { addEventListener('DOMContentLoaded', () => {
ipcRenderer.send('child-loaded', window.opener == null, document.body.innerHTML) ipcRenderer.send('child-loaded', window.opener == null, document.body.innerHTML, location.href)
}, false) }, false)
} }
})() })()