mirror of
https://github.com/moparisthebest/mail
synced 2024-11-16 06:05:07 -05:00
510f147b97
* remove 'pinned' attribute from imap/smtp config * remove 'provider' attribute from auth module * add 'oauthDomains' to app-config * remove all static server config from the app-config
168 lines
5.2 KiB
JavaScript
168 lines
5.2 KiB
JavaScript
'use strict';
|
|
|
|
var mocks = angular.mock,
|
|
AddAccountCtrl = require('../../src/js/controller/add-account'),
|
|
Auth = require('../../src/js/bo/auth'),
|
|
appController = require('../../src/js/app-controller'),
|
|
cfg = require('../../src/js/app-config').config;
|
|
|
|
describe('Add Account Controller unit test', function() {
|
|
var scope, location, mailConfigMock, ctrl, authStub, origAuth;
|
|
|
|
beforeEach(function() {
|
|
// remember original module to restore later, then replace it
|
|
origAuth = appController._auth;
|
|
appController._auth = authStub = sinon.createStubInstance(Auth);
|
|
|
|
angular.module('addaccounttest', ['woServices']);
|
|
mocks.module('addaccounttest');
|
|
mocks.inject(function($controller, $rootScope, $location, mailConfig) {
|
|
location = $location;
|
|
mailConfigMock = mailConfig;
|
|
scope = $rootScope.$new();
|
|
scope.state = {};
|
|
scope.form = {};
|
|
|
|
sinon.stub(location, 'path').returns(location);
|
|
sinon.stub(location, 'search').returns(location);
|
|
sinon.stub(scope, '$apply', function() {});
|
|
|
|
ctrl = $controller(AddAccountCtrl, {
|
|
$location: location,
|
|
$scope: scope,
|
|
$routeParams: {},
|
|
mailConfig: mailConfigMock
|
|
});
|
|
});
|
|
});
|
|
|
|
afterEach(function() {
|
|
// restore the app controller module
|
|
appController._auth = origAuth;
|
|
|
|
location.path.restore();
|
|
location.search.restore();
|
|
if (scope.$apply.restore) {
|
|
scope.$apply.restore();
|
|
}
|
|
});
|
|
|
|
describe('getAccountSettings', function() {
|
|
var url, oauthPossibleStub, setCredentialsStub, mailConfigStub, mailConfig;
|
|
|
|
beforeEach(inject(function($q) {
|
|
scope.form.$invalid = false;
|
|
scope.emailAddress = 'test@example.com';
|
|
url = cfg.settingsUrl + 'example.com';
|
|
mailConfig = {
|
|
imap: {
|
|
hostname: 'imap.example.com',
|
|
source: 'guess'
|
|
}
|
|
};
|
|
var deferred = $q.defer();
|
|
mailConfigStub = sinon.stub(mailConfigMock, 'get');
|
|
mailConfigStub.returns(deferred.promise);
|
|
deferred.resolve(mailConfig);
|
|
|
|
oauthPossibleStub = sinon.stub(scope, 'oauthPossible');
|
|
setCredentialsStub = sinon.stub(scope, 'setCredentials');
|
|
}));
|
|
|
|
afterEach(function() {
|
|
mailConfigStub.restore();
|
|
oauthPossibleStub.restore();
|
|
setCredentialsStub.restore();
|
|
});
|
|
|
|
it('should work for gmail', inject(function($rootScope) {
|
|
authStub.useOAuth.returns(true);
|
|
|
|
scope.getAccountSettings();
|
|
$rootScope.$apply();
|
|
|
|
expect(oauthPossibleStub.calledOnce).to.be.true;
|
|
}));
|
|
|
|
it('should work for other domain', inject(function($rootScope) {
|
|
authStub.useOAuth.returns(false);
|
|
|
|
scope.getAccountSettings();
|
|
$rootScope.$apply();
|
|
|
|
expect(setCredentialsStub.calledOnce).to.be.true;
|
|
}));
|
|
|
|
it('should fail for mailConfig error', inject(function($q, $rootScope) {
|
|
authStub.useOAuth.returns(false);
|
|
|
|
var deferred = $q.defer();
|
|
mailConfigStub.returns(deferred.promise);
|
|
deferred.reject(new Error());
|
|
|
|
scope.getAccountSettings();
|
|
$rootScope.$apply();
|
|
|
|
expect(scope.errMsg).to.exist;
|
|
}));
|
|
});
|
|
|
|
describe('oauthPossible', function() {
|
|
var setCredentialsStub;
|
|
|
|
beforeEach(function() {
|
|
setCredentialsStub = sinon.stub(scope, 'setCredentials');
|
|
});
|
|
|
|
afterEach(function() {
|
|
setCredentialsStub.restore();
|
|
});
|
|
|
|
it('should use oauth', function() {
|
|
scope.onError = function(options) {
|
|
options.callback(true);
|
|
};
|
|
authStub.getOAuthToken.yields();
|
|
|
|
scope.oauthPossible();
|
|
|
|
expect(setCredentialsStub.calledOnce).to.be.true;
|
|
expect(authStub.getOAuthToken.calledOnce).to.be.true;
|
|
});
|
|
|
|
it('should not use oauth', function() {
|
|
scope.onError = function(options) {
|
|
options.callback(false);
|
|
};
|
|
|
|
scope.oauthPossible();
|
|
|
|
expect(setCredentialsStub.calledOnce).to.be.true;
|
|
expect(authStub.getOAuthToken.called).to.be.false;
|
|
});
|
|
|
|
it('should not forward to login when oauth fails', function(done) {
|
|
scope.onError = function(options) {
|
|
scope.onError = function(err) {
|
|
expect(err).to.exist;
|
|
expect(setCredentialsStub.called).to.be.false;
|
|
done();
|
|
};
|
|
|
|
options.callback(true);
|
|
};
|
|
authStub.getOAuthToken.yields(new Error());
|
|
|
|
scope.oauthPossible();
|
|
});
|
|
});
|
|
|
|
describe('setCredentials', function() {
|
|
it('should work', function() {
|
|
scope.setCredentials();
|
|
|
|
expect(location.path.calledWith('/login-set-credentials')).to.be.true;
|
|
});
|
|
});
|
|
|
|
}); |