2015-01-23 18:58:57 +00:00
|
|
|
chai = require('chai')
|
|
|
|
expect = chai.expect
|
|
|
|
chai.use(require('sinon-chai'))
|
2015-01-09 15:22:18 +00:00
|
|
|
_ = require('lodash')
|
2014-12-22 16:47:12 +00:00
|
|
|
sinon = require('sinon')
|
|
|
|
errors = require('./errors')
|
|
|
|
|
|
|
|
describe 'Errors:', ->
|
|
|
|
|
|
|
|
describe '#handle()', ->
|
|
|
|
|
|
|
|
it 'should log the error message to stderr', ->
|
|
|
|
message = 'Hello World'
|
2015-01-15 14:36:43 +00:00
|
|
|
logErrorStub = sinon.stub(console, 'error')
|
2014-12-22 16:47:12 +00:00
|
|
|
error = new Error(message)
|
|
|
|
errors.handle(error, false)
|
|
|
|
expect(logErrorStub).to.have.been.calledWith(message)
|
|
|
|
logErrorStub.restore()
|
|
|
|
|
|
|
|
it 'should do nothing if error is not an instance of Error', ->
|
2015-01-15 14:36:43 +00:00
|
|
|
logErrorStub = sinon.stub(console, 'error')
|
2014-12-22 16:47:12 +00:00
|
|
|
|
|
|
|
for item in [
|
|
|
|
undefined
|
|
|
|
null
|
|
|
|
[ 1, 2, 3 ]
|
|
|
|
'Hello'
|
|
|
|
{ message: 'foo bar' }
|
|
|
|
]
|
|
|
|
errors.handle(item, false)
|
|
|
|
|
|
|
|
expect(logErrorStub).to.not.have.been.called
|
|
|
|
logErrorStub.restore()
|
|
|
|
|
|
|
|
checkProcessExitOption = (error, value, expectations) ->
|
|
|
|
processExitStub = sinon.stub(process, 'exit')
|
2015-01-15 14:36:43 +00:00
|
|
|
logErrorStub = sinon.stub(console, 'error')
|
2014-12-22 16:47:12 +00:00
|
|
|
errors.handle(error, value)
|
|
|
|
expectations(processExitStub, logErrorStub)
|
|
|
|
processExitStub.restore()
|
|
|
|
logErrorStub.restore()
|
|
|
|
|
|
|
|
it 'should exit if the last parameter is true', ->
|
|
|
|
error = new Error()
|
|
|
|
checkProcessExitOption error, true, (processExitStub) ->
|
|
|
|
expect(processExitStub).to.have.been.calledWith(1)
|
|
|
|
|
|
|
|
it 'should not exit if the last parameter is false', ->
|
|
|
|
error = new Error()
|
|
|
|
checkProcessExitOption error, false, (processExitStub) ->
|
|
|
|
expect(processExitStub).to.not.have.been.called
|
|
|
|
|
2015-01-06 16:46:31 +00:00
|
|
|
it 'should handle a custom error exit code from the error instance', ->
|
2014-12-22 16:47:12 +00:00
|
|
|
error = new Error()
|
2015-01-06 16:46:31 +00:00
|
|
|
error.exitCode = 123
|
2014-12-22 16:47:12 +00:00
|
|
|
checkProcessExitOption error, true, (processExitStub) ->
|
|
|
|
expect(processExitStub).to.have.been.calledWith(123)
|
|
|
|
|
|
|
|
it 'should print stack trace if DEBUG is set', ->
|
|
|
|
process.env.DEBUG = true
|
|
|
|
error = new Error()
|
|
|
|
checkProcessExitOption error, false, (processExitStub, logErrorStub) ->
|
|
|
|
expect(logErrorStub).to.have.been.calledOnce
|
|
|
|
expect(logErrorStub).to.have.been.calledWith(error.stack)
|
|
|
|
delete process.env.DEBUG
|
2015-01-06 16:54:40 +00:00
|
|
|
|
2015-01-06 17:12:11 +00:00
|
|
|
it 'should handle EISDIR', ->
|
2015-01-06 16:54:40 +00:00
|
|
|
error = new Error()
|
|
|
|
error.code = 'EISDIR'
|
|
|
|
error.path = 'hello'
|
|
|
|
checkProcessExitOption error, false, (processExitStub, logErrorStub) ->
|
|
|
|
expect(logErrorStub).to.have.been.calledOnce
|
|
|
|
expect(logErrorStub).to.have.been.calledWith('File is a directory: hello')
|
|
|
|
|
2015-01-06 17:12:11 +00:00
|
|
|
it 'should handle ENOENT', ->
|
2015-01-06 16:54:40 +00:00
|
|
|
error = new Error()
|
|
|
|
error.code = 'ENOENT'
|
|
|
|
error.path = 'hello'
|
|
|
|
checkProcessExitOption error, false, (processExitStub, logErrorStub) ->
|
|
|
|
expect(logErrorStub).to.have.been.calledOnce
|
|
|
|
expect(logErrorStub).to.have.been.calledWith('No such file or directory: hello')
|
2015-01-20 19:09:26 +00:00
|
|
|
|
|
|
|
it 'should handle EACCES', ->
|
|
|
|
error = new Error()
|
|
|
|
error.code = 'EACCES'
|
|
|
|
checkProcessExitOption error, false, (processExitStub, logErrorStub) ->
|
|
|
|
expect(logErrorStub).to.have.been.calledOnce
|
2015-01-29 19:28:33 +00:00
|
|
|
expect(logErrorStub.getCall(0).args[0]).to.match(/^You don\'t have enough privileges to run this operation./)
|