emit once for each session and add spec

This commit is contained in:
deepak1556 2016-06-08 22:04:41 +05:30
parent cb5e648502
commit b91217f29e
2 changed files with 41 additions and 3 deletions

View file

@ -10,9 +10,7 @@ const fromPartition = function (partition, persist) {
throw new Error('session module can only be used when app is ready') throw new Error('session module can only be used when app is ready')
} }
let session = bindings.fromPartition(partition, persist) return bindings.fromPartition(partition, persist)
process.emit('session-created', session)
return session
} }
// Returns the Session from |partition| string. // Returns the Session from |partition| string.
@ -37,6 +35,7 @@ Object.defineProperty(exports, 'defaultSession', {
const wrapSession = function (session) { const wrapSession = function (session) {
// Session is an EventEmitter. // Session is an EventEmitter.
Object.setPrototypeOf(session, EventEmitter.prototype) Object.setPrototypeOf(session, EventEmitter.prototype)
process.emit('session-created', session)
} }
bindings._setWrapSession(wrapSession) bindings._setWrapSession(wrapSession)

View file

@ -883,6 +883,45 @@ describe('browser-window module', function () {
}) })
}) })
it('works when used with partitions', function (done) {
this.timeout(10000)
if (w != null) {
w.destroy()
}
w = new BrowserWindow({
show: false,
webPreferences: {
partition: 'temp'
}
})
var extensionPath = path.join(__dirname, 'fixtures', 'devtools-extensions', 'foo')
BrowserWindow.removeDevToolsExtension('foo')
BrowserWindow.addDevToolsExtension(extensionPath)
w.webContents.on('devtools-opened', function () {
var showPanelIntevalId = setInterval(function () {
if (w && w.devToolsWebContents) {
w.devToolsWebContents.executeJavaScript('(' + (function () {
var lastPanelId = WebInspector.inspectorView._tabbedPane._tabs.peekLast().id
WebInspector.inspectorView.showPanel(lastPanelId)
}).toString() + ')()')
} else {
clearInterval(showPanelIntevalId)
}
}, 100)
})
w.loadURL('about:blank')
w.webContents.openDevTools({mode: 'bottom'})
ipcMain.once('answer', function (event, message) {
assert.equal(message.runtimeId, 'foo')
done()
})
})
it('serializes the registered extensions on quit', function () { it('serializes the registered extensions on quit', function () {
var extensionName = 'foo' var extensionName = 'foo'
var extensionPath = path.join(__dirname, 'fixtures', 'devtools-extensions', extensionName) var extensionPath = path.join(__dirname, 'fixtures', 'devtools-extensions', extensionName)