electron/spec/node-spec.coffee

156 lines
5.4 KiB
CoffeeScript
Raw Permalink Normal View History

assert = require 'assert'
child_process = require 'child_process'
fs = require 'fs'
path = require 'path'
2014-07-24 23:04:30 -06:00
os = require 'os'
2014-08-06 20:29:26 -06:00
remote = require 'remote'
2013-12-15 09:31:40 -07:00
describe 'node feature', ->
2014-07-24 23:04:30 -06:00
fixtures = path.join __dirname, 'fixtures'
2014-07-24 23:04:30 -06:00
describe 'child_process', ->
describe 'child_process.fork', ->
it 'works in current process', (done) ->
child = child_process.fork path.join(fixtures, 'module', 'ping.js')
child.on 'message', (msg) ->
assert.equal msg, 'message'
done()
child.send 'message'
it 'preserves args', (done) ->
args = ['--expose_gc', '-test', '1']
child = child_process.fork path.join(fixtures, 'module', 'process_args.js'), args
child.on 'message', (msg) ->
assert.deepEqual args, msg.slice(2)
done()
child.send 'message'
it 'works in forked process', (done) ->
child = child_process.fork path.join(fixtures, 'module', 'fork_ping.js')
child.on 'message', (msg) ->
assert.equal msg, 'message'
done()
child.send 'message'
it 'works in forked process when options.env is specifed', (done) ->
child = child_process.fork path.join(fixtures, 'module', 'fork_ping.js'),
[],
path: process.env['PATH']
child.on 'message', (msg) ->
assert.equal msg, 'message'
done()
child.send 'message'
2014-07-31 02:47:11 -06:00
it 'works in browser process', (done) ->
2014-08-06 20:29:26 -06:00
fork = remote.require('child_process').fork
2014-07-31 02:47:11 -06:00
child = fork path.join(fixtures, 'module', 'ping.js')
child.on 'message', (msg) ->
assert.equal msg, 'message'
done()
child.send 'message'
it 'has String::localeCompare working in script', (done) ->
child = child_process.fork path.join(fixtures, 'module', 'locale-compare.js')
child.on 'message', (msg) ->
assert.deepEqual msg, [0, -1, 1]
done()
child.send 'message'
it 'has setImmediate working in script', (done) ->
child = child_process.fork path.join(fixtures, 'module', 'set-immediate.js')
child.on 'message', (msg) ->
assert.equal msg, 'ok'
done()
child.send 'message'
describe 'contexts', ->
describe 'setTimeout in fs callback', ->
return if process.env.TRAVIS is 'true'
it 'does not crash', (done) ->
fs.readFile __filename, ->
setTimeout done, 0
describe 'throw error in node context', ->
it 'gets caught', (done) ->
error = new Error('boo!')
lsts = process.listeners 'uncaughtException'
process.removeAllListeners 'uncaughtException'
process.on 'uncaughtException', (err) ->
process.removeAllListeners 'uncaughtException'
for lst in lsts
process.on 'uncaughtException', lst
done()
fs.readFile __filename, ->
throw error
2014-08-06 20:29:26 -06:00
describe 'setTimeout called under Chromium event loop in browser process', ->
it 'can be scheduled in time', (done) ->
remote.getGlobal('setTimeout')(done, 0)
2014-08-07 00:23:28 -06:00
describe 'setInterval called under Chromium event loop in browser process', ->
it 'can be scheduled in time', (done) ->
clear = ->
remote.getGlobal('clearInterval')(interval)
done()
interval = remote.getGlobal('setInterval')(clear, 10)
2014-08-07 00:23:28 -06:00
describe 'message loop', ->
describe 'process.nextTick', ->
it 'emits the callback', (done) ->
process.nextTick done
it 'works in nested calls', (done) ->
process.nextTick ->
process.nextTick ->
process.nextTick done
describe 'setImmediate', ->
it 'emits the callback', (done) ->
setImmediate done
it 'works in nested calls', (done) ->
setImmediate ->
setImmediate ->
setImmediate done
2014-07-24 23:04:30 -06:00
describe 'net.connect', ->
return unless process.platform is 'darwin'
2014-07-25 01:02:17 -06:00
it 'emit error when connect to a socket path without listeners', (done) ->
2014-07-25 01:02:17 -06:00
socketPath = path.join os.tmpdir(), 'atom-shell-test.sock'
2014-07-24 23:04:30 -06:00
script = path.join(fixtures, 'module', 'create_socket.js')
child = child_process.fork script, [socketPath]
child.on 'exit', (code) ->
assert.equal code, 0
2014-07-24 23:04:30 -06:00
client = require('net').connect socketPath
client.on 'error', (error) ->
assert.equal error.code, 'ECONNREFUSED'
done()
2014-11-06 06:26:54 -07:00
describe 'Buffer', ->
it 'can be created from WebKit external string', ->
p = document.createElement 'p'
p.innerText = '闲云潭影日悠悠,物换星移几度秋'
b = new Buffer(p.innerText)
assert.equal b.toString(), '闲云潭影日悠悠,物换星移几度秋'
assert.equal Buffer.byteLength(p.innerText), 45
2015-05-27 01:26:32 -06:00
it 'correctly parses external one-byte UTF8 string', ->
p = document.createElement 'p'
p.innerText = 'Jøhänñéß'
b = new Buffer(p.innerText)
assert.equal b.toString(), 'Jøhänñéß'
assert.equal Buffer.byteLength(p.innerText), 13
describe 'process.stdout', ->
it 'should not throw exception', ->
process.stdout
# Not reliable on some machines
xit 'should have isTTY defined', ->
assert.equal typeof(process.stdout.isTTY), 'boolean'
describe 'vm.createContext', ->
it 'should not crash', ->
require('vm').runInNewContext('')