Merge pull request #6998 from electron/ipc-v8-converter-crash
Don't serialize external values over IPC
This commit is contained in:
commit
4833c4800e
2 changed files with 46 additions and 0 deletions
|
@ -262,6 +262,9 @@ base::Value* V8ValueConverter::FromV8ValueImpl(
|
||||||
if (state->HasReachedMaxRecursionDepth())
|
if (state->HasReachedMaxRecursionDepth())
|
||||||
return nullptr;
|
return nullptr;
|
||||||
|
|
||||||
|
if (val->IsExternal())
|
||||||
|
return base::Value::CreateNullValue().release();
|
||||||
|
|
||||||
if (val->IsNull())
|
if (val->IsNull())
|
||||||
return base::Value::CreateNullValue().release();
|
return base::Value::CreateNullValue().release();
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
'use strict'
|
'use strict'
|
||||||
|
|
||||||
const assert = require('assert')
|
const assert = require('assert')
|
||||||
|
const http = require('http')
|
||||||
const path = require('path')
|
const path = require('path')
|
||||||
const {closeWindow} = require('./window-helpers')
|
const {closeWindow} = require('./window-helpers')
|
||||||
|
|
||||||
|
@ -358,6 +359,29 @@ describe('ipc module', function () {
|
||||||
ipcRenderer.send('message', document.location)
|
ipcRenderer.send('message', document.location)
|
||||||
})
|
})
|
||||||
|
|
||||||
|
it('can send Electron API objects', function (done) {
|
||||||
|
const webContents = remote.getCurrentWebContents()
|
||||||
|
ipcRenderer.once('message', function (event, value) {
|
||||||
|
assert.deepEqual(value.browserWindowOptions, webContents.browserWindowOptions)
|
||||||
|
done()
|
||||||
|
})
|
||||||
|
ipcRenderer.send('message', webContents)
|
||||||
|
})
|
||||||
|
|
||||||
|
it('does not crash on external objects (regression)', function (done) {
|
||||||
|
const request = http.request({port: 5000, hostname: '127.0.0.1', method: 'GET', path: '/'})
|
||||||
|
const stream = request.agent.sockets['127.0.0.1:5000:'][0]._handle._externalStream
|
||||||
|
request.on('error', function () {})
|
||||||
|
ipcRenderer.once('message', function (event, requestValue, externalStreamValue) {
|
||||||
|
assert.equal(requestValue.method, 'GET')
|
||||||
|
assert.equal(requestValue.path, '/')
|
||||||
|
assert.equal(externalStreamValue, null)
|
||||||
|
done()
|
||||||
|
})
|
||||||
|
|
||||||
|
ipcRenderer.send('message', request, stream)
|
||||||
|
})
|
||||||
|
|
||||||
it('can send objects that both reference the same object', function (done) {
|
it('can send objects that both reference the same object', function (done) {
|
||||||
const child = {hello: 'world'}
|
const child = {hello: 'world'}
|
||||||
const foo = {name: 'foo', child: child}
|
const foo = {name: 'foo', child: child}
|
||||||
|
@ -373,6 +397,25 @@ describe('ipc module', function () {
|
||||||
})
|
})
|
||||||
ipcRenderer.send('message', array, foo, bar, child)
|
ipcRenderer.send('message', array, foo, bar, child)
|
||||||
})
|
})
|
||||||
|
|
||||||
|
it('inserts null for cyclic references', function (done) {
|
||||||
|
const array = [5]
|
||||||
|
array.push(array)
|
||||||
|
|
||||||
|
const child = {hello: 'world'}
|
||||||
|
child.child = child
|
||||||
|
|
||||||
|
ipcRenderer.once('message', function (event, arrayValue, childValue) {
|
||||||
|
assert.equal(arrayValue[0], 5)
|
||||||
|
assert.equal(arrayValue[1], null)
|
||||||
|
|
||||||
|
assert.equal(childValue.hello, 'world')
|
||||||
|
assert.equal(childValue.child, null)
|
||||||
|
|
||||||
|
done()
|
||||||
|
})
|
||||||
|
ipcRenderer.send('message', array, child)
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
describe('ipc.sendSync', function () {
|
describe('ipc.sendSync', function () {
|
||||||
|
|
Loading…
Reference in a new issue