mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-20 22:42:53 -05:00
143921948d
refs b6728ecb0f
- The "no-shadow" eslint rune was introduced into ghost's eslint plugin (referenced commmit), which resulted in flood of warning in console output when linting the project codebase.
- This cleanup is aiming to make any new linting issues more visible. Follow up commits will contain similar cleanups in other parts of the codebase
116 lines
3.7 KiB
JavaScript
116 lines
3.7 KiB
JavaScript
const should = require('should');
|
|
const sinon = require('sinon');
|
|
const testUtils = require('../../../utils');
|
|
const Promise = require('bluebird');
|
|
const _ = require('lodash');
|
|
const models = require('../../../../core/server/models');
|
|
const actionsMap = require('../../../../core/server/services/permissions/actions-map-cache');
|
|
const permissions = require('../../../../core/server/services/permissions');
|
|
|
|
describe('Permissions', function () {
|
|
let fakePermissions = [];
|
|
let findPostSpy;
|
|
let findTagSpy;
|
|
|
|
before(function () {
|
|
models.init();
|
|
});
|
|
|
|
beforeEach(function () {
|
|
sinon.stub(models.Permission, 'findAll').callsFake(function () {
|
|
return Promise.resolve(models.Permissions.forge(fakePermissions));
|
|
});
|
|
|
|
findPostSpy = sinon.stub(models.Post, 'findOne').callsFake(function () {
|
|
return Promise.resolve(models.Post.forge(testUtils.DataGenerator.Content.posts[0]));
|
|
});
|
|
|
|
findTagSpy = sinon.stub(models.Tag, 'findOne').callsFake(function () {
|
|
return Promise.resolve({});
|
|
});
|
|
});
|
|
|
|
afterEach(function () {
|
|
sinon.restore();
|
|
});
|
|
|
|
/**
|
|
* Default test actionMap looks like this:
|
|
* {
|
|
* browse: [ 'post' ],
|
|
* edit: [ 'post', 'tag', 'user', 'page' ],
|
|
* add: [ 'post', 'user', 'page' ],
|
|
* destroy: [ 'post', 'user' ]
|
|
* }
|
|
*
|
|
* @param {object} options
|
|
* @return {Array|*}
|
|
*/
|
|
function loadFakePermissions(options) {
|
|
options = options || {};
|
|
|
|
const fixturePermissions = _.cloneDeep(testUtils.DataGenerator.Content.permissions);
|
|
|
|
const extraPerm = {
|
|
name: 'test',
|
|
action_type: 'edit',
|
|
object_type: 'post'
|
|
};
|
|
|
|
if (options.extra) {
|
|
fixturePermissions.push(extraPerm);
|
|
}
|
|
|
|
return _.map(fixturePermissions, function (testPerm) {
|
|
return testUtils.DataGenerator.forKnex.createPermission(testPerm);
|
|
});
|
|
}
|
|
|
|
describe('No init (no action map)', function () {
|
|
it('throws an error without actionMap', function () {
|
|
sinon.stub(actionsMap, 'empty').returns(true);
|
|
|
|
permissions.canThis.should.throw(/No actions map found/);
|
|
});
|
|
});
|
|
|
|
describe('Init (build actions map)', function () {
|
|
it('can load an actions map from existing permissions', function (done) {
|
|
fakePermissions = loadFakePermissions();
|
|
|
|
permissions.init().then(function (actions) {
|
|
should.exist(actions);
|
|
|
|
permissions.canThis.should.not.throwError();
|
|
|
|
_.keys(actions).should.eql(['browse', 'edit', 'add', 'destroy']);
|
|
|
|
actions.browse.should.eql(['post']);
|
|
actions.edit.should.eql(['post', 'tag', 'user', 'page']);
|
|
actions.add.should.eql(['post', 'user', 'page']);
|
|
actions.destroy.should.eql(['post', 'user']);
|
|
|
|
done();
|
|
}).catch(done);
|
|
});
|
|
|
|
it('can load an actions map from existing permissions, and deduplicate', function (done) {
|
|
fakePermissions = loadFakePermissions({extra: true});
|
|
|
|
permissions.init().then(function (actions) {
|
|
should.exist(actions);
|
|
|
|
permissions.canThis.should.not.throwError();
|
|
|
|
_.keys(actions).should.eql(['browse', 'edit', 'add', 'destroy']);
|
|
|
|
actions.browse.should.eql(['post']);
|
|
actions.edit.should.eql(['post', 'tag', 'user', 'page']);
|
|
actions.add.should.eql(['post', 'user', 'page']);
|
|
actions.destroy.should.eql(['post', 'user']);
|
|
|
|
done();
|
|
}).catch(done);
|
|
});
|
|
});
|
|
});
|