balena-cli/lib/hooks/auth.spec.coffee

84 lines
2.1 KiB
CoffeeScript
Raw Normal View History

2014-11-25 13:37:53 +00:00
_ = require('lodash')
nock = require('nock')
sinon = require('sinon')
expect = require('chai').expect
config = require('../config')
2014-11-26 16:56:52 +00:00
resin = require('../resin')
2014-11-25 13:37:53 +00:00
authHooks = require('./auth')
johnDoeFixture = require('../../tests/fixtures/johndoe')
mock = require('../../tests/utils/mock')
describe 'Auth Hooks:', ->
describe '#failIfNotLoggedIn()', ->
before ->
mock.connection.init()
after ->
mock.connection.restore()
2014-11-26 13:19:02 +00:00
beforeEach (done) ->
mock.fs.init()
2014-11-26 16:56:52 +00:00
resin.data.prefix.set(config.dataPrefix, done)
2014-11-26 13:19:02 +00:00
afterEach ->
mock.fs.restore()
2014-11-25 13:37:53 +00:00
describe 'if not logged in', ->
beforeEach (done) ->
2014-11-26 17:02:22 +00:00
resin.auth.logout(done)
2014-11-25 13:37:53 +00:00
it 'should not call the function', (done) ->
spy = sinon.spy()
authHooks.failIfNotLoggedIn(spy, _.noop)()
_.defer ->
expect(spy).to.not.have.been.called
done()
it 'it should call the second function with an error', (done) ->
func = authHooks.failIfNotLoggedIn _.noop, (error) ->
expect(error).to.be.an.instanceof(Error)
done()
func()
# TODO: expect(func).to.throw(Error) doesn't catches
# the error as it's being thrown inside an async function
# (auth.isLoggedIn). A try/catch works, but it still results
# in the error being printed in Mocha reporter.
xit 'should throw an error if no error handler function', ->
func = authHooks.failIfNotLoggedIn(_.noop)
try
func()
catch error
expect(error).to.be.an.instanceof(Error)
describe 'if logged in', ->
beforeEach (done) ->
nock(config.remoteUrl)
.post('/login_', johnDoeFixture.credentials)
.reply(200, johnDoeFixture.token)
2014-11-26 17:02:22 +00:00
resin.auth.login(johnDoeFixture.credentials, done)
2014-11-25 13:37:53 +00:00
it 'should call the function with the correct arguments', (done) ->
args = [ 1, 2, 3, 'foo', 'bar' ]
spy = sinon.spy()
authHooks.failIfNotLoggedIn(spy, _.noop).apply(null, args)
_.defer ->
expect(spy).to.have.been.calledWith(args...)
done()
it 'should not call the second function', (done) ->
spy = sinon.spy()
authHooks.failIfNotLoggedIn(_.noop, spy)()
_.defer ->
expect(spy).to.not.have.been.called
done()