Files
espocrm/frontend/test/spec/test.acl.js
Taras Machyshyn fac5704c9e Added 2017 year
2017-01-17 15:07:08 +02:00

83 lines
2.5 KiB
JavaScript

/************************************************************************
* This file is part of EspoCRM.
*
* EspoCRM - Open Source CRM application.
* Copyright (C) 2014-2017 Yuri Kuznetsov, Taras Machyshyn, Oleksiy Avramenko
* Website: http://www.espocrm.com
*
* EspoCRM is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* EspoCRM is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with EspoCRM. If not, see http://www.gnu.org/licenses/.
*
* The interactive user interfaces in modified source and object code versions
* of this program must display Appropriate Legal Notices, as required under
* Section 5 of the GNU General Public License version 3.
*
* In accordance with Section 7(b) of the GNU General Public License version 3,
* these Appropriate Legal Notices must retain the display of the "EspoCRM" word.
************************************************************************/
var Espo = Espo || {};
describe("Acl", function () {
var acl;
beforeEach(function () {
acl = new Espo.Acl();
acl.user = {
isAdmin: function () {
return false;
}
};
});
it("should check an access properly", function () {
acl.set({
table: {
Lead: {
read: 'team',
edit: 'own',
delete: 'no',
},
Contact: {
read: true,
edit: false,
delete: false,
},
Opportunity: false,
Meeting: true
}
});
expect(acl.check('Lead', 'read')).toBe(true);
expect(acl.check('Lead', 'read', false, false)).toBe(true);
expect(acl.check('Lead', 'read', false, true)).toBe(true);
expect(acl.check('Lead', 'read', true)).toBe(true);
expect(acl.check('Lead', 'edit')).toBe(true);
expect(acl.check('Lead', 'edit', false, true)).toBe(false);
expect(acl.check('Lead', 'edit', true, false)).toBe(true);
expect(acl.check('Lead', 'delete')).toBe(true);
expect(acl.check('Contact', 'read')).toBe(true);
expect(acl.check('Contact', 'edit')).toBe(false);
expect(acl.check('Lead', 'convert')).toBe(true);
expect(acl.check('Account', 'edit')).toBe(true);
expect(acl.check('Opportunity', 'edit')).toBe(false);
expect(acl.check('Meeting', 'edit')).toBe(true);
});
});