d5d1fa8290
* fix: use Chromium's determined new site instance as candidate when navigating. When navigating to a new address, consider using Chromium's determined site instance for the new page as it should belong to an existing browsing instance when the navigation was triggered by window.open(). fixes 8100. * Revert "fix: use Chromium's determined new site instance as candidate when navigating." This reverts commit eb95f935654a2c4d4457821297670836c10fdfd5. * fix: delegate site instance creation back to content when sandboxed. * fix: ensure site isolation is on * test: adapt ut for cross-site navigation * fix: register pending processes during a navigation. * refactor: dont call loadURL for a window constructed from an existing webContents. * test: add sandboxed affinity UT's. * fix: check affinity before deciding if to force a new site instance. * chore: adapt subsequent patch. * refactor: constify logically const methods. * fix: do not reuse site instances when navigation redirects cross-site. * test: ensure localStorage accessible after x-site redirect. * test: adapt localStorage acess denied UT for site isolation. * fix: do not send render-view-deleted for speculative frames. * chore: amend tests after rebase. * test: add ut for webContents' render-view-deleted emission * fix: introduce current-render-view-deleted for current RVH's deletions. Revert render-view-deleted to being emitted with any RVH's deletion. current-render-view-deleted is emitted only when the RVH being deleted is the current one. * refactor: style and comments fixed.
121 lines
3.8 KiB
HTML
121 lines
3.8 KiB
HTML
<html>
|
|
<script type="text/javascript" charset="utf-8">
|
|
function timeout(ms) {
|
|
return new Promise((resolve) => {
|
|
setTimeout(resolve, ms)
|
|
})
|
|
}
|
|
async function invokeGc () {
|
|
// it seems calling window.gc once does not guarantee garbage will be
|
|
// collected, so we repeat 10 times with interval of 100 ms
|
|
for (let i = 0; i < 10; i++) {
|
|
window.gc()
|
|
await timeout(100)
|
|
}
|
|
}
|
|
|
|
const [,test] = window.location.href.split('?')
|
|
if (window.opener && test !== 'reload-remote') {
|
|
window.callback = () => {
|
|
opener.require('electron').ipcRenderer.send('answer', document.body.innerHTML)
|
|
}
|
|
} else {
|
|
const {ipcRenderer, remote} = require('electron')
|
|
const tests = {
|
|
'reload-remote-child': () => {
|
|
open(`${location.protocol}//${location.pathname}?reload-remote`)
|
|
},
|
|
'reload-remote': async () => {
|
|
const p = ipcRenderer.sendSync('get-remote-module-path')
|
|
const Hello = remote.require(p)
|
|
if (!ipcRenderer.sendSync('reloaded')) {
|
|
ipcRenderer.send('reload')
|
|
return
|
|
}
|
|
await invokeGc()
|
|
ipcRenderer.send('answer', new Hello().say())
|
|
},
|
|
// FIXME: Chromium 67 - getProcessMemoryInfo has been removed
|
|
// 'allocate-memory': async () => {
|
|
// await invokeGc()
|
|
// const {privateBytes: bytesBeforeOpen} = process.getProcessMemoryInfo()
|
|
// let w = open('./allocate-memory.html')
|
|
// await invokeGc()
|
|
// const {privateBytes: bytesAfterOpen} = process.getProcessMemoryInfo()
|
|
// w.close()
|
|
// w = null
|
|
// await invokeGc()
|
|
// const {privateBytes: bytesAfterClose} = process.getProcessMemoryInfo()
|
|
// ipcRenderer.send('answer', {
|
|
// bytesBeforeOpen, bytesAfterOpen, bytesAfterClose
|
|
// })
|
|
// },
|
|
'window-events': () => {
|
|
document.title = 'changed'
|
|
},
|
|
'webcontents-stop': () => {
|
|
stop()
|
|
},
|
|
'webcontents-events': () => {
|
|
addEventListener('load', () => {
|
|
location.hash = 'in-page-navigate'
|
|
setTimeout(() => {
|
|
location.reload()
|
|
}, 50)
|
|
})
|
|
},
|
|
'exit-event': () => {
|
|
process.on('exit', () => {
|
|
ipcRenderer.send('answer', location.href)
|
|
})
|
|
location.assign('http://www.google.com')
|
|
},
|
|
'window-open': () => {
|
|
addEventListener('load', () => {
|
|
popup = open(window.location.href, 'popup!', 'top=60,left=50,width=500,height=600')
|
|
popup.addEventListener('DOMContentLoaded', () => {
|
|
popup.document.write('<h1>scripting from opener</h1>')
|
|
popup.callback()
|
|
}, false)
|
|
})
|
|
},
|
|
'window-open-external': () => {
|
|
addEventListener('load', () => {
|
|
ipcRenderer.once('open-the-popup', (event, url) => {
|
|
popup = open(url, '', 'top=65,left=55,width=505,height=605')
|
|
})
|
|
ipcRenderer.once('touch-the-popup', () => {
|
|
let errorMessage = null
|
|
try {
|
|
const childDoc = popup.document
|
|
} catch (error) {
|
|
errorMessage = error.message
|
|
}
|
|
ipcRenderer.send('answer', errorMessage)
|
|
})
|
|
ipcRenderer.send('opener-loaded')
|
|
})
|
|
},
|
|
'verify-ipc-sender': () => {
|
|
popup = open()
|
|
ipcRenderer.once('verified', () => {
|
|
ipcRenderer.send('parent-answer')
|
|
})
|
|
popup.ipcRenderer.once('verified', () => {
|
|
popup.ipcRenderer.send('child-answer')
|
|
})
|
|
ipcRenderer.send('parent-ready')
|
|
popup.ipcRenderer.send('child-ready')
|
|
}
|
|
}
|
|
|
|
addEventListener('unload', () => {
|
|
if (window.popup)
|
|
popup.close()
|
|
}, false)
|
|
|
|
if (tests.hasOwnProperty(test))
|
|
tests[test]()
|
|
}
|
|
</script>
|
|
</html>
|