assert = require 'assert' http = require 'http' https = require 'https' path = require 'path' ws = require 'ws' remote = require 'remote' BrowserWindow = remote.require 'browser-window' describe 'chromium feature', -> fixtures = path.resolve __dirname, 'fixtures' listener = null afterEach -> if listener? window.removeEventListener 'message', listener listener = null xdescribe 'heap snapshot', -> it 'does not crash', -> process.atomBinding('v8_util').takeHeapSnapshot() describe 'sending request of http protocol urls', -> it 'does not crash', (done) -> @timeout 5000 server = http.createServer (req, res) -> res.end() server.close() done() server.listen 0, '127.0.0.1', -> {port} = server.address() $.get "http://127.0.0.1:#{port}" describe 'document.hidden', -> url = "file://#{fixtures}/pages/document-hidden.html" w = null afterEach -> w?.destroy() it 'is set correctly when window is not shown', (done) -> w = new BrowserWindow(show:false) w.webContents.on 'ipc-message', (event, args) -> assert.deepEqual args, ['hidden', true] done() w.loadUrl url describe 'navigator.webkitGetUserMedia', -> it 'calls its callbacks', (done) -> @timeout 5000 navigator.webkitGetUserMedia audio: true, video: false, -> done() -> done() describe 'navigator.language', -> it 'should not be empty', -> assert.notEqual navigator.language, '' describe 'window.open', -> @timeout 10000 it 'returns a BrowserWindowProxy object', -> b = window.open 'about:blank', '', 'show=no' assert.equal b.closed, false assert.equal b.constructor.name, 'BrowserWindowProxy' b.close() it 'accepts "node-integration" as feature', (done) -> listener = (event) -> assert.equal event.data, 'undefined' b.close() done() window.addEventListener 'message', listener b = window.open "file://#{fixtures}/pages/window-opener-node.html", '', 'node-integration=no,show=no' it 'inherit options of parent window', (done) -> listener = (event) -> size = remote.getCurrentWindow().getSize() assert.equal event.data, "size: #{size.width} #{size.height}" b.close() done() window.addEventListener 'message', listener b = window.open "file://#{fixtures}/pages/window-open-size.html", '', 'show=no' describe 'window.opener', -> @timeout 10000 url = "file://#{fixtures}/pages/window-opener.html" w = null afterEach -> w?.destroy() it 'is null for main window', (done) -> w = new BrowserWindow(show: false) w.webContents.on 'ipc-message', (event, args) -> assert.deepEqual args, ['opener', null] done() w.loadUrl url it 'is not null for window opened by window.open', (done) -> listener = (event) -> assert.equal event.data, 'object' b.close() done() window.addEventListener 'message', listener b = window.open url, '', 'show=no' describe 'window.opener.postMessage', -> it 'sets source and origin correctly', (done) -> listener = (event) -> window.removeEventListener 'message', listener b.close() assert.equal event.source.guestId, b.guestId assert.equal event.origin, 'file://' done() window.addEventListener 'message', listener b = window.open "file://#{fixtures}/pages/window-opener-postMessage.html", '', 'show=no' describe 'creating a Uint8Array under browser side', -> it 'does not crash', -> RUint8Array = remote.getGlobal 'Uint8Array' new RUint8Array describe 'webgl', -> it 'can be get as context in canvas', -> return if process.platform is 'linux' webgl = document.createElement('canvas').getContext 'webgl' assert.notEqual webgl, null describe 'web workers', -> it 'Worker can work', (done) -> worker = new Worker('../fixtures/workers/worker.js') message = 'ping' worker.onmessage = (event) -> assert.equal event.data, message worker.terminate() done() worker.postMessage message it 'SharedWorker can work', (done) -> worker = new SharedWorker('../fixtures/workers/shared_worker.js') message = 'ping' worker.port.onmessage = (event) -> assert.equal event.data, message done() worker.port.postMessage message describe 'iframe', -> iframe = null beforeEach -> iframe = document.createElement 'iframe' afterEach -> document.body.removeChild iframe it 'does not have node integration', (done) -> iframe.src = "file://#{fixtures}/pages/set-global.html" document.body.appendChild iframe iframe.onload = -> assert.equal iframe.contentWindow.test, 'undefined undefined undefined' done() describe 'storage', -> it 'requesting persitent quota works', (done) -> navigator.webkitPersistentStorage.requestQuota 1024 * 1024, (grantedBytes) -> assert.equal grantedBytes, 1048576 done() describe 'websockets', -> wss = null server = null WebSocketServer = ws.Server afterEach -> wss.close() server.close() it 'has user agent', (done) -> server = http.createServer() server.listen 0, '127.0.0.1', -> port = server.address().port wss = new WebSocketServer(server: server) wss.on 'error', done wss.on 'connection', (ws) -> if ws.upgradeReq.headers['user-agent'] done() else done('user agent is empty') websocket = new WebSocket("ws://127.0.0.1:#{port}") describe 'Promise', -> it 'resolves correctly in Node.js calls', (done) -> document.registerElement('x-element', { prototype: Object.create(HTMLElement.prototype, { createdCallback: { value: -> } }) }) setImmediate -> called = false Promise.resolve().then -> done(if called then undefined else new Error('wrong sequnce')) document.createElement 'x-element' called = true it 'resolves correctly in Electron calls', (done) -> document.registerElement('y-element', { prototype: Object.create(HTMLElement.prototype, { createdCallback: { value: -> } }) }) remote.getGlobal('setImmediate') -> called = false Promise.resolve().then -> done(if called then undefined else new Error('wrong sequnce')) document.createElement 'y-element' called = true