Mercurial > hg > thermostat-ng > web-client
view src/app/auth-interceptor.factory.spec.js @ 245:2eb2ae0f3b3f
Transition project to Angular 4 Hybrid
Reviewed-by: jkang
Review-thread: http://icedtea.classpath.org/pipermail/thermostat/2017-October/025266.html
author | Andrew Azores <aazores@redhat.com> |
---|---|
date | Fri, 13 Oct 2017 14:05:09 -0400 |
parents | a318b066384b |
children |
line wrap: on
line source
/** * Copyright 2012-2017 Red Hat, Inc. * * Thermostat is distributed under the GNU General Public License, * version 2 or any later version (with a special exception described * below, commonly known as the "Classpath Exception"). * * A copy of GNU General Public License (GPL) is included in this * distribution, in the file COPYING. * * Linking Thermostat code with other modules is making a combined work * based on Thermostat. Thus, the terms and conditions of the GPL * cover the whole combination. * * As a special exception, the copyright holders of Thermostat give you * permission to link this code with independent modules to produce an * executable, regardless of the license terms of these independent * modules, and to copy and distribute the resulting executable under * terms of your choice, provided that you also meet, for each linked * independent module, the terms and conditions of the license of that * module. An independent module is a module which is not derived from * or based on Thermostat code. If you modify Thermostat, you may * extend this exception to your version of the software, but you are * not obligated to do so. If you do not wish to do so, delete this * exception statement from your version. */ import factoryModule from './auth-interceptor.factory.js'; describe('authInterceptorFactory', () => { let authSvc, refreshPromise, interceptor; beforeEach(() => { angular.mock.module(factoryModule); angular.mock.module('authModule', $provide => { 'ngInject'; refreshPromise = sinon.spy(); authSvc = { status: sinon.stub().returns('mockStatus'), login: sinon.stub().yields(), logout: sinon.stub().yields(), refresh: sinon.stub().returns({ then: refreshPromise }), authHeader: 'Basic foo64' }; $provide.value('authService', authSvc); }); angular.mock.module('authInterceptorFactory'); angular.mock.inject(authInterceptorFactory => { 'ngInject'; interceptor = authInterceptorFactory; }); }); it('should exist', () => { should.exist(interceptor); }); it('should return an interceptor object', () => { interceptor.should.be.an.Object(); interceptor.should.have.properties('request'); interceptor.should.have.size(1); }); describe('request interceptor', () => { let fn; beforeEach(() => { fn = interceptor.request; }); it('should refresh authService when authHeader exists', () => { authSvc.refresh.should.not.be.called(); fn(); authSvc.refresh.should.be.calledOnce(); }); it('should append header if refresh succeeds', () => { let cfg = {}; fn(cfg); refreshPromise.should.be.calledWith(sinon.match.func, sinon.match.func); refreshPromise.args[0][0](); cfg.should.deepEqual({ headers: { Authorization: 'Basic foo64'} }); }); it('should do nothing if refresh fails', () => { let cfg = {}; fn(cfg); refreshPromise.should.be.calledWith(sinon.match.func, sinon.match.func); refreshPromise.args[0][1](); cfg.should.deepEqual({}); }); it('should do nothing if authHeader does not exist', () => { delete authSvc.authHeader; let cfg = {}; fn(cfg); authSvc.refresh.should.not.be.called(); cfg.should.deepEqual({}); }); }); });