feat: move webFrame scheme privilege methods to main process (#16416)
* chore: deprecate webFrame.registerURLSchemeAsPrivileged * Add register schemes protocol api * update branch to enable browser process API * Revert deprecation changes * Fetch API support * Updated api to take an array, still working on tests * Update tests * Remove web frame API * Minor changes * update scheme registrations on browser and renderer process * fix: enable ses.getBlobData spec * Update breaking changes doc
This commit is contained in:
parent
257de6a963
commit
940c4c0787
19 changed files with 319 additions and 319 deletions
|
@ -4,7 +4,7 @@ const dirtyChai = require('dirty-chai')
|
|||
const path = require('path')
|
||||
const { closeWindow } = require('./window-helpers')
|
||||
const { remote, webFrame } = require('electron')
|
||||
const { BrowserWindow, protocol, ipcMain } = remote
|
||||
const { BrowserWindow, ipcMain } = remote
|
||||
|
||||
const { expect } = chai
|
||||
chai.use(dirtyChai)
|
||||
|
@ -20,124 +20,6 @@ describe('webFrame module', function () {
|
|||
return closeWindow(w).then(function () { w = null })
|
||||
})
|
||||
|
||||
// FIXME: Disabled with C70.
|
||||
xdescribe('webFrame.registerURLSchemeAsPrivileged', function () {
|
||||
it('supports fetch api by default', function (done) {
|
||||
const url = 'file://' + fixtures + '/assets/logo.png'
|
||||
window.fetch(url).then(function (response) {
|
||||
assert(response.ok)
|
||||
done()
|
||||
}).catch(function (err) {
|
||||
done('unexpected error : ' + err)
|
||||
})
|
||||
})
|
||||
|
||||
it('allows CORS requests by default', function (done) {
|
||||
allowsCORSRequests(200, `<html>
|
||||
<script>
|
||||
const {ipcRenderer, webFrame} = require('electron')
|
||||
webFrame.registerURLSchemeAsPrivileged('cors1')
|
||||
fetch('cors1://myhost').then(function (response) {
|
||||
ipcRenderer.send('response', response.status)
|
||||
}).catch(function (response) {
|
||||
ipcRenderer.send('response', 'failed')
|
||||
})
|
||||
</script>
|
||||
</html>`, done)
|
||||
})
|
||||
|
||||
it('allows CORS and fetch requests when specified', function (done) {
|
||||
allowsCORSRequests(200, `<html>
|
||||
<script>
|
||||
const {ipcRenderer, webFrame} = require('electron')
|
||||
webFrame.registerURLSchemeAsPrivileged('cors2', { supportFetchAPI: true, corsEnabled: true })
|
||||
fetch('cors2://myhost').then(function (response) {
|
||||
ipcRenderer.send('response', response.status)
|
||||
}).catch(function (response) {
|
||||
ipcRenderer.send('response', 'failed')
|
||||
})
|
||||
</script>
|
||||
</html>`, done)
|
||||
})
|
||||
|
||||
it('allows CORS and fetch requests when half-specified', function (done) {
|
||||
allowsCORSRequests(200, `<html>
|
||||
<script>
|
||||
const {ipcRenderer, webFrame} = require('electron')
|
||||
webFrame.registerURLSchemeAsPrivileged('cors3', { supportFetchAPI: true })
|
||||
fetch('cors3://myhost').then(function (response) {
|
||||
ipcRenderer.send('response', response.status)
|
||||
}).catch(function (response) {
|
||||
ipcRenderer.send('response', 'failed')
|
||||
})
|
||||
</script>
|
||||
</html>`, done)
|
||||
})
|
||||
|
||||
it('disallows CORS, but allows fetch requests, when specified', function (done) {
|
||||
allowsCORSRequests('failed', `<html>
|
||||
<script>
|
||||
const {ipcRenderer, webFrame} = require('electron')
|
||||
webFrame.registerURLSchemeAsPrivileged('cors4', { supportFetchAPI: true, corsEnabled: false })
|
||||
fetch('cors4://myhost').then(function (response) {
|
||||
ipcRenderer.send('response', response.status)
|
||||
}).catch(function (response) {
|
||||
ipcRenderer.send('response', 'failed')
|
||||
})
|
||||
</script>
|
||||
</html>`, done)
|
||||
})
|
||||
|
||||
it('allows CORS, but disallows fetch requests, when specified', function (done) {
|
||||
allowsCORSRequests('failed', `<html>
|
||||
<script>
|
||||
const {ipcRenderer, webFrame} = require('electron')
|
||||
webFrame.registerURLSchemeAsPrivileged('cors5', { supportFetchAPI: false, corsEnabled: true })
|
||||
fetch('cors5://myhost').then(function (response) {
|
||||
ipcRenderer.send('response', response.status)
|
||||
}).catch(function (response) {
|
||||
ipcRenderer.send('response', 'failed')
|
||||
})
|
||||
</script>
|
||||
</html>`, done)
|
||||
})
|
||||
|
||||
let runNumber = 1
|
||||
function allowsCORSRequests (expected, content, done) {
|
||||
const standardScheme = remote.getGlobal('standardScheme') + runNumber
|
||||
const corsScheme = 'cors' + runNumber
|
||||
runNumber++
|
||||
|
||||
const url = standardScheme + '://fake-host'
|
||||
w = new BrowserWindow({ show: false })
|
||||
after(function (done) {
|
||||
protocol.unregisterProtocol(corsScheme, function () {
|
||||
protocol.unregisterProtocol(standardScheme, function () {
|
||||
done()
|
||||
})
|
||||
})
|
||||
})
|
||||
|
||||
const handler = function (request, callback) {
|
||||
callback({ data: content, mimeType: 'text/html' })
|
||||
}
|
||||
protocol.registerStringProtocol(standardScheme, handler, function (error) {
|
||||
if (error) return done(error)
|
||||
})
|
||||
|
||||
protocol.registerStringProtocol(corsScheme, function (request, callback) {
|
||||
callback('')
|
||||
}, function (error) {
|
||||
if (error) return done(error)
|
||||
ipcMain.once('response', function (event, status) {
|
||||
assert.strictEqual(status, expected)
|
||||
done()
|
||||
})
|
||||
w.loadURL(url)
|
||||
})
|
||||
}
|
||||
})
|
||||
|
||||
it('supports setting the visual and layout zoom level limits', function () {
|
||||
assert.doesNotThrow(function () {
|
||||
webFrame.setVisualZoomLevelLimits(1, 50)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue