mirror of
https://github.com/TryGhost/Ghost.git
synced 2024-12-21 18:01:36 +03:00
02abe3862e
refs https://github.com/TryGhost/Ghost/pull/9592 - we add bookshelf-relations step by step if we need it - with https://github.com/TryGhost/Ghost/pull/9592 we have rewritten the test env to use Bookshelf - this is important for our new url service - because the service is listening on model updates and updates the urls based on the model events - so with moving to Bookshelf, we need any easy way to add relations - the test env inserts test fixtures - it adds permissions and each permission get's roles attached - `models.Permission.add({roles: [...]})
64 lines
2.0 KiB
JavaScript
64 lines
2.0 KiB
JavaScript
'use strict';
|
|
|
|
const should = require('should'),
|
|
sinon = require('sinon'),
|
|
models = require('../../../server/models'),
|
|
testUtils = require('../../utils'),
|
|
sandbox = sinon.sandbox.create();
|
|
|
|
describe('Unit: models/permission', function () {
|
|
before(function () {
|
|
models.init();
|
|
});
|
|
|
|
after(function () {
|
|
sandbox.restore();
|
|
});
|
|
|
|
describe('add', function () {
|
|
let knexMock;
|
|
|
|
before(function () {
|
|
knexMock = new testUtils.mocks.knex();
|
|
knexMock.mock();
|
|
});
|
|
|
|
after(function () {
|
|
knexMock.unmock();
|
|
});
|
|
|
|
it('without roles', function () {
|
|
return models.Permission.add({name: 'test', object_type: 'something', action_type: 'read something'})
|
|
.then(function (permission) {
|
|
permission.get('name').should.eql('test');
|
|
permission.get('object_type').should.eql('something');
|
|
permission.get('action_type').should.eql('read something');
|
|
});
|
|
});
|
|
|
|
it('with roles', function () {
|
|
return models.Permission.add({
|
|
name: 'test',
|
|
object_type: 'something',
|
|
action_type: 'write something',
|
|
roles: [testUtils.DataGenerator.forKnex.roles[1]]
|
|
}).then(function (permission) {
|
|
permission.get('name').should.eql('test');
|
|
permission.get('object_type').should.eql('something');
|
|
permission.get('action_type').should.eql('write something');
|
|
permission.related('roles').models[0].id.should.eql(testUtils.DataGenerator.forKnex.roles[1].id);
|
|
});
|
|
});
|
|
|
|
it('[error] validation', function () {
|
|
return models.Permission.add({})
|
|
.then(function () {
|
|
'Should fail'.should.be.true();
|
|
})
|
|
.catch(function (err) {
|
|
err.length.should.eql(3);
|
|
});
|
|
});
|
|
});
|
|
});
|