Merge pull request #6998 from electron/ipc-v8-converter-crash

Don't serialize external values over IPC
This commit is contained in:
Cheng Zhao 2016-08-31 20:45:25 +09:00 committed by GitHub
commit 4833c4800e
2 changed files with 46 additions and 0 deletions

View file

@ -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();

View file

@ -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 () {