2016-11-05 12:11:41 +02:00
|
|
|
import expect from 'unexpected';
|
|
|
|
|
2016-11-15 07:55:15 +02:00
|
|
|
import request from 'services/request';
|
2016-11-05 12:11:41 +02:00
|
|
|
import authentication from 'services/api/authentication';
|
|
|
|
import accounts from 'services/api/accounts';
|
|
|
|
|
|
|
|
describe('authentication api', () => {
|
|
|
|
describe('#validateToken()', () => {
|
|
|
|
const validTokens = {token: 'foo', refreshToken: 'bar'};
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
sinon.stub(accounts, 'current');
|
|
|
|
|
|
|
|
accounts.current.returns(Promise.resolve());
|
|
|
|
});
|
|
|
|
|
|
|
|
afterEach(() => {
|
|
|
|
accounts.current.restore();
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should request accounts.current', () =>
|
|
|
|
expect(authentication.validateToken(validTokens), 'to be fulfilled')
|
|
|
|
.then(() => {
|
|
|
|
expect(accounts.current, 'to have a call satisfying', [
|
2016-11-08 08:30:53 +02:00
|
|
|
{token: 'foo'}
|
2016-11-05 12:11:41 +02:00
|
|
|
]);
|
|
|
|
})
|
|
|
|
);
|
|
|
|
|
|
|
|
it('should resolve with both tokens', () =>
|
|
|
|
expect(authentication.validateToken(validTokens), 'to be fulfilled with', validTokens)
|
|
|
|
);
|
|
|
|
|
|
|
|
it('rejects if token has a bad type', () =>
|
|
|
|
expect(authentication.validateToken({token: {}}),
|
|
|
|
'to be rejected with', 'token must be a string'
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
2016-11-19 17:50:30 +02:00
|
|
|
it('should allow empty refreshToken', () =>
|
|
|
|
expect(authentication.validateToken({token: 'foo', refreshToken: null}), 'to be fulfilled')
|
2016-11-05 12:11:41 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
it('rejects if accounts.current request is unexpectedly failed', () => {
|
|
|
|
const error = 'Something wrong';
|
|
|
|
accounts.current.returns(Promise.reject(error));
|
|
|
|
|
|
|
|
return expect(authentication.validateToken(validTokens),
|
|
|
|
'to be rejected with', error
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('when token is expired', () => {
|
|
|
|
const expiredResponse = {
|
|
|
|
name: 'Unauthorized',
|
|
|
|
message: 'Token expired',
|
|
|
|
code: 0,
|
|
|
|
status: 401,
|
|
|
|
type: 'yii\\web\\UnauthorizedHttpException'
|
|
|
|
};
|
|
|
|
const newToken = 'baz';
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
sinon.stub(authentication, 'requestToken');
|
|
|
|
|
|
|
|
accounts.current.returns(Promise.reject(expiredResponse));
|
|
|
|
authentication.requestToken.returns(Promise.resolve({token: newToken}));
|
|
|
|
});
|
|
|
|
|
|
|
|
afterEach(() => {
|
|
|
|
authentication.requestToken.restore();
|
|
|
|
});
|
|
|
|
|
|
|
|
it('resolves with new token', () =>
|
|
|
|
expect(authentication.validateToken(validTokens),
|
|
|
|
'to be fulfilled with', {...validTokens, token: newToken}
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
it('rejects if token request failed', () => {
|
|
|
|
const error = 'Something wrong';
|
|
|
|
authentication.requestToken.returns(Promise.reject(error));
|
|
|
|
|
|
|
|
return expect(authentication.validateToken(validTokens),
|
|
|
|
'to be rejected with', error
|
|
|
|
);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
2016-11-15 07:55:15 +02:00
|
|
|
|
|
|
|
describe('#logout', () => {
|
|
|
|
beforeEach(() => {
|
|
|
|
sinon.stub(request, 'post').named('request.post');
|
|
|
|
});
|
|
|
|
|
|
|
|
afterEach(() => {
|
|
|
|
request.post.restore();
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should request logout api', () => {
|
|
|
|
authentication.logout();
|
|
|
|
|
|
|
|
expect(request.post, 'to have a call satisfying', [
|
|
|
|
'/api/authentication/logout', {}, {}
|
|
|
|
]);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('returns a promise', () => {
|
|
|
|
request.post.returns(Promise.resolve());
|
|
|
|
|
|
|
|
return expect(authentication.logout(), 'to be fulfilled');
|
|
|
|
});
|
|
|
|
|
|
|
|
it('overrides token if provided', () => {
|
|
|
|
const token = 'foo';
|
|
|
|
|
|
|
|
authentication.logout({token});
|
|
|
|
|
|
|
|
expect(request.post, 'to have a call satisfying', [
|
|
|
|
'/api/authentication/logout', {}, {token}
|
|
|
|
]);
|
|
|
|
});
|
|
|
|
});
|
2016-11-05 12:11:41 +02:00
|
|
|
});
|