test: move some remote specs to the main runner (#18636)
This commit is contained in:
parent
a9f601612f
commit
bb19142389
4 changed files with 118 additions and 84 deletions
|
@ -752,7 +752,7 @@ Calling `event.preventDefault()` will make it return empty sources.
|
||||||
|
|
||||||
Returns:
|
Returns:
|
||||||
|
|
||||||
* `event` Event
|
* `event` IpcMainEvent
|
||||||
* `moduleName` String
|
* `moduleName` String
|
||||||
|
|
||||||
Emitted when `remote.require()` is called in the renderer process.
|
Emitted when `remote.require()` is called in the renderer process.
|
||||||
|
@ -763,7 +763,7 @@ Custom value can be returned by setting `event.returnValue`.
|
||||||
|
|
||||||
Returns:
|
Returns:
|
||||||
|
|
||||||
* `event` Event
|
* `event` IpcMainEvent
|
||||||
* `globalName` String
|
* `globalName` String
|
||||||
|
|
||||||
Emitted when `remote.getGlobal()` is called in the renderer process.
|
Emitted when `remote.getGlobal()` is called in the renderer process.
|
||||||
|
@ -774,7 +774,7 @@ Custom value can be returned by setting `event.returnValue`.
|
||||||
|
|
||||||
Returns:
|
Returns:
|
||||||
|
|
||||||
* `event` Event
|
* `event` IpcMainEvent
|
||||||
* `moduleName` String
|
* `moduleName` String
|
||||||
|
|
||||||
Emitted when `remote.getBuiltin()` is called in the renderer process.
|
Emitted when `remote.getBuiltin()` is called in the renderer process.
|
||||||
|
@ -785,7 +785,7 @@ Custom value can be returned by setting `event.returnValue`.
|
||||||
|
|
||||||
Returns:
|
Returns:
|
||||||
|
|
||||||
* `event` Event
|
* `event` IpcMainEvent
|
||||||
|
|
||||||
Emitted when `remote.getCurrentWindow()` is called in the renderer process.
|
Emitted when `remote.getCurrentWindow()` is called in the renderer process.
|
||||||
Calling `event.preventDefault()` will prevent the object from being returned.
|
Calling `event.preventDefault()` will prevent the object from being returned.
|
||||||
|
@ -795,7 +795,7 @@ Custom value can be returned by setting `event.returnValue`.
|
||||||
|
|
||||||
Returns:
|
Returns:
|
||||||
|
|
||||||
* `event` Event
|
* `event` IpcMainEvent
|
||||||
|
|
||||||
Emitted when `remote.getCurrentWebContents()` is called in the renderer process.
|
Emitted when `remote.getCurrentWebContents()` is called in the renderer process.
|
||||||
Calling `event.preventDefault()` will prevent the object from being returned.
|
Calling `event.preventDefault()` will prevent the object from being returned.
|
||||||
|
@ -805,7 +805,7 @@ Custom value can be returned by setting `event.returnValue`.
|
||||||
|
|
||||||
Returns:
|
Returns:
|
||||||
|
|
||||||
* `event` Event
|
* `event` IpcMainEvent
|
||||||
* `guestWebContents` [WebContents](web-contents.md)
|
* `guestWebContents` [WebContents](web-contents.md)
|
||||||
|
|
||||||
Emitted when `<webview>.getWebContents()` is called in the renderer process.
|
Emitted when `<webview>.getWebContents()` is called in the renderer process.
|
||||||
|
|
112
spec-main/api-remote-spec.ts
Normal file
112
spec-main/api-remote-spec.ts
Normal file
|
@ -0,0 +1,112 @@
|
||||||
|
import { expect } from 'chai'
|
||||||
|
import { closeWindow } from './window-helpers'
|
||||||
|
|
||||||
|
import { BrowserWindow } from 'electron'
|
||||||
|
|
||||||
|
describe('remote module', () => {
|
||||||
|
let w = null as unknown as BrowserWindow
|
||||||
|
before(async () => {
|
||||||
|
w = new BrowserWindow({show: false, webPreferences: {nodeIntegration: true}})
|
||||||
|
await w.loadURL('about:blank')
|
||||||
|
})
|
||||||
|
after(async () => {
|
||||||
|
await closeWindow(w)
|
||||||
|
})
|
||||||
|
|
||||||
|
async function remotely(script: string) {
|
||||||
|
// executeJavaScript never returns if the script throws an error, so catch
|
||||||
|
// any errors manually.
|
||||||
|
const assembledScript = `(function() {
|
||||||
|
try {
|
||||||
|
return { result: ${script} }
|
||||||
|
} catch (e) {
|
||||||
|
return { error: e.message }
|
||||||
|
}
|
||||||
|
})()`
|
||||||
|
const {result, error} = await w.webContents.executeJavaScript(assembledScript)
|
||||||
|
if (error) {
|
||||||
|
throw new Error(error)
|
||||||
|
}
|
||||||
|
return result
|
||||||
|
}
|
||||||
|
|
||||||
|
describe('remote.getGlobal filtering', () => {
|
||||||
|
it('can return custom values', async () => {
|
||||||
|
w.webContents.once('remote-get-global', (event, name) => {
|
||||||
|
event.returnValue = name
|
||||||
|
})
|
||||||
|
expect(await remotely(`require('electron').remote.getGlobal('test')`)).to.equal('test')
|
||||||
|
})
|
||||||
|
|
||||||
|
it('throws when no returnValue set', async () => {
|
||||||
|
w.webContents.once('remote-get-global', (event, name) => {
|
||||||
|
event.preventDefault()
|
||||||
|
})
|
||||||
|
await expect(remotely(`require('electron').remote.getGlobal('test')`)).to.eventually.be.rejected(`Blocked remote.getGlobal('test')`)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('remote.getBuiltin filtering', () => {
|
||||||
|
it('can return custom values', async () => {
|
||||||
|
w.webContents.once('remote-get-builtin', (event, name) => {
|
||||||
|
event.returnValue = name
|
||||||
|
})
|
||||||
|
expect(await remotely(`require('electron').remote.getBuiltin('test')`)).to.equal('test')
|
||||||
|
})
|
||||||
|
|
||||||
|
it('throws when no returnValue set', async () => {
|
||||||
|
w.webContents.once('remote-get-builtin', (event, name) => {
|
||||||
|
event.preventDefault()
|
||||||
|
})
|
||||||
|
await expect(remotely(`require('electron').remote.getBuiltin('test')`)).to.eventually.be.rejected(`Blocked remote.getGlobal('test')`)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('remote.require filtering', () => {
|
||||||
|
it('can return custom values', async () => {
|
||||||
|
w.webContents.once('remote-require', (event, name) => {
|
||||||
|
event.returnValue = name
|
||||||
|
})
|
||||||
|
expect(await remotely(`require('electron').remote.require('test')`)).to.equal('test')
|
||||||
|
})
|
||||||
|
|
||||||
|
it('throws when no returnValue set', async () => {
|
||||||
|
w.webContents.once('remote-require', (event, name) => {
|
||||||
|
event.preventDefault()
|
||||||
|
})
|
||||||
|
await expect(remotely(`require('electron').remote.require('test')`)).to.eventually.be.rejected(`Blocked remote.require('test')`)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('remote.getCurrentWindow filtering', () => {
|
||||||
|
it('can return custom value', async () => {
|
||||||
|
w.webContents.once('remote-get-current-window', (e) => {
|
||||||
|
e.returnValue = 'some window'
|
||||||
|
})
|
||||||
|
expect(await remotely(`require('electron').remote.getCurrentWindow()`)).to.equal('some window')
|
||||||
|
})
|
||||||
|
|
||||||
|
it('throws when no returnValue set', async () => {
|
||||||
|
w.webContents.once('remote-get-current-window', (event) => {
|
||||||
|
event.preventDefault()
|
||||||
|
})
|
||||||
|
await expect(remotely(`require('electron').remote.getCurrentWindow()`)).to.eventually.be.rejected(`Blocked remote.getCurrentWindow()`)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
describe('remote.getCurrentWebContents filtering', () => {
|
||||||
|
it('can return custom value', async () => {
|
||||||
|
w.webContents.once('remote-get-current-web-contents', (event) => {
|
||||||
|
event.returnValue = 'some web contents'
|
||||||
|
})
|
||||||
|
expect(await remotely(`require('electron').remote.getCurrentWebContents()`)).to.equal('some web contents')
|
||||||
|
})
|
||||||
|
|
||||||
|
it('throws when no returnValue set', async () => {
|
||||||
|
w.webContents.once('remote-get-current-web-contents', (event) => {
|
||||||
|
event.preventDefault()
|
||||||
|
})
|
||||||
|
await expect(remotely(`require('electron').remote.getCurrentWebContents()`)).to.eventually.be.rejected(`Blocked remote.getCurrentWebContents()`)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
|
@ -23,42 +23,6 @@ const comparePaths = (path1, path2) => {
|
||||||
describe('remote module', () => {
|
describe('remote module', () => {
|
||||||
const fixtures = path.join(__dirname, 'fixtures')
|
const fixtures = path.join(__dirname, 'fixtures')
|
||||||
|
|
||||||
describe('remote.getGlobal filtering', () => {
|
|
||||||
it('can return custom values', () => {
|
|
||||||
ipcRenderer.send('handle-next-remote-get-global', { test: 'Hello World!' })
|
|
||||||
expect(remote.getGlobal('test')).to.be.equal('Hello World!')
|
|
||||||
})
|
|
||||||
|
|
||||||
it('throws when no returnValue set', () => {
|
|
||||||
ipcRenderer.send('handle-next-remote-get-global')
|
|
||||||
expect(() => remote.getGlobal('test')).to.throw(`Blocked remote.getGlobal('test')`)
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
describe('remote.getBuiltin filtering', () => {
|
|
||||||
it('can return custom values', () => {
|
|
||||||
ipcRenderer.send('handle-next-remote-get-builtin', { test: 'Hello World!' })
|
|
||||||
expect(remote.getBuiltin('test')).to.be.equal('Hello World!')
|
|
||||||
})
|
|
||||||
|
|
||||||
it('throws when no returnValue set', () => {
|
|
||||||
ipcRenderer.send('handle-next-remote-get-builtin')
|
|
||||||
expect(() => remote.getBuiltin('test')).to.throw(`Blocked remote.getBuiltin('test')`)
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
describe('remote.require filtering', () => {
|
|
||||||
it('can return custom values', () => {
|
|
||||||
ipcRenderer.send('handle-next-remote-require', { test: 'Hello World!' })
|
|
||||||
expect(remote.require('test')).to.be.equal('Hello World!')
|
|
||||||
})
|
|
||||||
|
|
||||||
it('throws when no returnValue set', () => {
|
|
||||||
ipcRenderer.send('handle-next-remote-require')
|
|
||||||
expect(() => remote.require('test')).to.throw(`Blocked remote.require('test')`)
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
describe('remote.require', () => {
|
describe('remote.require', () => {
|
||||||
it('should returns same object for the same module', () => {
|
it('should returns same object for the same module', () => {
|
||||||
const dialog1 = remote.require('electron')
|
const dialog1 = remote.require('electron')
|
||||||
|
@ -459,30 +423,6 @@ describe('remote module', () => {
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
describe('remote.getCurrentWindow filtering', () => {
|
|
||||||
it('can return custom value', () => {
|
|
||||||
ipcRenderer.send('handle-next-remote-get-current-window', 'Hello World!')
|
|
||||||
expect(remote.getCurrentWindow()).to.be.equal('Hello World!')
|
|
||||||
})
|
|
||||||
|
|
||||||
it('throws when no returnValue set', () => {
|
|
||||||
ipcRenderer.send('handle-next-remote-get-current-window')
|
|
||||||
expect(() => remote.getCurrentWindow()).to.throw('Blocked remote.getCurrentWindow()')
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
describe('remote.getCurrentWebContents filtering', () => {
|
|
||||||
it('can return custom value', () => {
|
|
||||||
ipcRenderer.send('handle-next-remote-get-current-web-contents', 'Hello World!')
|
|
||||||
expect(remote.getCurrentWebContents()).to.be.equal('Hello World!')
|
|
||||||
})
|
|
||||||
|
|
||||||
it('throws when no returnValue set', () => {
|
|
||||||
ipcRenderer.send('handle-next-remote-get-current-web-contents')
|
|
||||||
expect(() => remote.getCurrentWebContents()).to.throw('Blocked remote.getCurrentWebContents()')
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
describe('remote class', () => {
|
describe('remote class', () => {
|
||||||
const cl = remote.require(path.join(fixtures, 'module', 'class.js'))
|
const cl = remote.require(path.join(fixtures, 'module', 'class.js'))
|
||||||
const base = cl.base
|
const base = cl.base
|
||||||
|
|
|
@ -184,26 +184,8 @@ ipcMain.on('handle-next-ipc-message-sync', function (event, returnValue) {
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
for (const eventName of [
|
|
||||||
'remote-require',
|
|
||||||
'remote-get-global',
|
|
||||||
'remote-get-builtin'
|
|
||||||
]) {
|
|
||||||
ipcMain.on(`handle-next-${eventName}`, function (event, valuesMap = {}) {
|
|
||||||
event.sender.once(eventName, (event, name) => {
|
|
||||||
if (valuesMap.hasOwnProperty(name)) {
|
|
||||||
event.returnValue = valuesMap[name]
|
|
||||||
} else {
|
|
||||||
event.preventDefault()
|
|
||||||
}
|
|
||||||
})
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
for (const eventName of [
|
for (const eventName of [
|
||||||
'desktop-capturer-get-sources',
|
'desktop-capturer-get-sources',
|
||||||
'remote-get-current-window',
|
|
||||||
'remote-get-current-web-contents',
|
|
||||||
'remote-get-guest-web-contents'
|
'remote-get-guest-web-contents'
|
||||||
]) {
|
]) {
|
||||||
ipcMain.on(`handle-next-${eventName}`, function (event, returnValue) {
|
ipcMain.on(`handle-next-${eventName}`, function (event, returnValue) {
|
||||||
|
|
Loading…
Reference in a new issue