electron/spec/chromium-spec.coffee

176 lines
5.3 KiB
CoffeeScript
Raw Normal View History

2013-12-27 06:58:13 +00:00
assert = require 'assert'
http = require 'http'
2015-03-10 07:09:23 +00:00
https = require 'https'
path = require 'path'
2015-07-14 18:38:30 +00:00
ws = require 'ws'
2015-08-04 07:46:59 +00:00
remote = require 'remote'
2013-12-27 06:58:13 +00:00
2013-12-15 16:31:40 +00:00
describe 'chromium feature', ->
fixtures = path.resolve __dirname, 'fixtures'
xdescribe 'heap snapshot', ->
it 'does not crash', ->
process.atomBinding('v8_util').takeHeapSnapshot()
2015-03-18 04:55:44 +00:00
describe 'sending request of http protocol urls', ->
it 'does not crash', (done) ->
@timeout 5000
2015-03-18 04:55:44 +00:00
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 'navigator.webkitGetUserMedia', ->
it 'calls its callbacks', (done) ->
@timeout 5000
navigator.webkitGetUserMedia audio: true, video: false,
-> done()
-> done()
2013-12-27 06:58:13 +00:00
2014-05-29 12:23:28 +00:00
describe 'navigator.language', ->
it 'should not be empty', ->
assert.notEqual navigator.language, ''
2013-12-27 06:58:13 +00:00
describe 'window.open', ->
it 'returns a BrowserWindowProxy object', ->
2013-12-27 06:58:13 +00:00
b = window.open 'about:blank', 'test', 'show=no'
assert.equal b.closed, false
assert.equal b.constructor.name, 'BrowserWindowProxy'
b.close()
2015-08-04 07:46:59 +00:00
describe 'window.opener', ->
ipc = remote.require 'ipc'
url = "file://#{fixtures}/pages/window-opener.html"
w = null
afterEach ->
w?.destroy()
ipc.removeAllListeners 'opener'
it 'is null for main window', (done) ->
ipc.on 'opener', (event, opener) ->
done(if opener is null then undefined else opener)
BrowserWindow = remote.require 'browser-window'
w = new BrowserWindow(show: false)
w.loadUrl url
it 'is not null for window opened by window.open', (done) ->
b = window.open url, 'test2', 'show=no'
ipc.on 'opener', (event, opener) ->
b.close()
done(if opener isnt null then undefined else opener)
describe 'window.opener.postMessage', ->
it 'sets source and origin correctly', (done) ->
b = window.open "file://#{fixtures}/pages/window-opener-postMessage.html", 'test', 'show=no'
window.addEventListener 'message', (event) ->
b.close()
assert.equal event.source.guestId, b.guestId
assert.equal event.origin, 'file://'
done()
2014-05-14 08:10:33 +00:00
describe 'creating a Uint8Array under browser side', ->
it 'does not crash', ->
2015-08-04 07:46:59 +00:00
RUint8Array = remote.getGlobal 'Uint8Array'
2014-05-14 08:10:33 +00:00
new RUint8Array
2014-05-18 14:37:59 +00:00
describe 'webgl', ->
it 'can be get as context in canvas', ->
return if process.platform is 'linux'
2014-05-18 14:37:59 +00:00
webgl = document.createElement('canvas').getContext 'webgl'
assert.notEqual webgl, null
2014-07-09 07:55:01 +00:00
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
2015-01-22 01:05:19 +00:00
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()
2015-05-12 12:33:00 +00:00
describe 'storage', ->
it 'requesting persitent quota works', (done) ->
navigator.webkitPersistentStorage.requestQuota 1024 * 1024, (grantedBytes) ->
assert.equal grantedBytes, 1048576
done()
2015-07-14 18:38:30 +00:00
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