balena-cli/lib/resin/errors/errors.spec.coffee

72 lines
2.1 KiB
CoffeeScript
Raw Normal View History

2014-11-24 14:00:35 -04:00
expect = require('chai').expect
sinon = require('sinon')
log = require('../log/log')
errors = require('./errors')
describe 'Errors:', ->
describe '#handle()', ->
it 'should log the error message to stderr', ->
2014-12-05 12:52:31 -04:00
message = 'Hello World'
2014-11-24 14:00:35 -04:00
logErrorStub = sinon.stub(log, 'error')
2014-12-05 12:52:31 -04:00
error = new Error(message)
2014-11-24 14:00:35 -04:00
errors.handle(error, false)
2014-12-05 12:52:31 -04:00
expect(logErrorStub).to.have.been.calledWith(message)
2014-11-24 14:00:35 -04:00
logErrorStub.restore()
it 'should do nothing if error is not an instance of Error', ->
logErrorStub = sinon.stub(log, 'error')
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()
2014-11-26 10:32:57 -04:00
checkProcessExitOption = (error, value, expectations) ->
2014-11-24 14:00:35 -04:00
processExitStub = sinon.stub(process, 'exit')
logErrorStub = sinon.stub(log, 'error')
2014-11-26 10:32:57 -04:00
errors.handle(error, value)
expectations(processExitStub, logErrorStub)
2014-11-24 14:00:35 -04:00
processExitStub.restore()
logErrorStub.restore()
it 'should exit if the last parameter is true', ->
2014-12-05 12:52:31 -04:00
error = new Error()
2014-11-26 10:32:57 -04:00
checkProcessExitOption error, true, (processExitStub) ->
expect(processExitStub).to.have.been.calledWith(1)
2014-11-24 14:00:35 -04:00
it 'should not exit if the last parameter is false', ->
2014-12-05 12:52:31 -04:00
error = new Error()
2014-11-26 10:32:57 -04:00
checkProcessExitOption error, false, (processExitStub) ->
2014-11-24 14:00:35 -04:00
expect(processExitStub).to.not.have.been.called
2014-11-24 14:41:16 -04:00
2014-11-26 10:32:57 -04:00
it 'should handle a custom error code from the error instance', ->
error = new Error()
error.code = 123
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
2014-11-24 14:41:16 -04:00
describe 'NotFound', ->
it 'should get a custom message', ->
message = 'Foo'
error = new errors.NotFound(message)
expect(error.message).to.not.equal(message)
expect(error.message).to.contain(message)