0
Fork 0
mirror of https://github.com/TryGhost/Ghost.git synced 2025-01-20 22:42:53 -05:00

Move api utils tests & add test for handlePermissions (#9057)

refs #9043

- Move api util tests into api section
- Adding export test to utils to see the amount of functions which are exported
- Adding basic handlePermissions tests
This commit is contained in:
Hannah Wolfe 2017-09-26 09:23:02 +01:00 committed by Katharina Irrgang
parent 22017b8ede
commit 6ee3cf2dc0

View file

@ -3,9 +3,9 @@ var should = require('should'),
_ = require('lodash'), _ = require('lodash'),
Promise = require('bluebird'), Promise = require('bluebird'),
ObjectId = require('bson-objectid'), ObjectId = require('bson-objectid'),
permissions = require('../../server/permissions'), permissions = require('../../../server/permissions'),
errors = require('../../server/errors'), errors = require('../../../server/errors'),
apiUtils = require('../../server/api/utils'), apiUtils = require('../../../server/api/utils'),
sandbox = sinon.sandbox.create(); sandbox = sinon.sandbox.create();
@ -14,6 +14,30 @@ describe('API Utils', function () {
sandbox.restore(); sandbox.restore();
}); });
it('exports', function () {
// @TODO reduce the number of methods that are here!
_.keys(apiUtils).should.eql([
'globalDefaultOptions',
'dataDefaultOptions',
'browseDefaultOptions',
'idDefaultOptions',
'validate',
'validateOptions',
'detectPublicContext',
'applyPublicPermissions',
'handlePublicPermissions',
'handlePermissions',
'trimAndLowerCase',
'prepareInclude',
'prepareFields',
'prepareFormats',
'convertOptions',
'checkObject',
'checkFileExists',
'checkFileIsValid'
]);
});
describe('Default Options', function () { describe('Default Options', function () {
it('should provide a set of default options', function () { it('should provide a set of default options', function () {
apiUtils.globalDefaultOptions.should.eql(['context', 'include']); apiUtils.globalDefaultOptions.should.eql(['context', 'include']);
@ -505,4 +529,91 @@ describe('API Utils', function () {
}); });
}); });
}); });
describe('handlePermissions', function () {
it('should require a docName', function () {
apiUtils.handlePermissions.should.throwError();
});
it('should return a function', function () {
apiUtils.handlePermissions('test').should.be.a.Function();
});
it('should handle an unknown rejection', function (done) {
var testStub = sandbox.stub().returns(new Promise.reject()),
permsStub = sandbox.stub(permissions, 'canThis', function () {
return {
testing: {
test: testStub
}
};
}),
permsFunc = apiUtils.handlePermissions('tests', 'testing');
permsFunc({})
.then(function () {
done(new Error('Should have thrown an error'));
})
.catch(function (err) {
permsStub.callCount.should.eql(1);
testStub.callCount.should.eql(1);
err.errorType.should.eql('InternalServerError');
done();
});
});
it('should handle a NoPermissions rejection', function (done) {
var testStub = sandbox.stub().returns(new Promise.reject(
new errors.NoPermissionError()
)),
permsStub = sandbox.stub(permissions, 'canThis', function () {
return {
testing: {
test: testStub
}
};
}),
permsFunc = apiUtils.handlePermissions('tests', 'testing');
permsFunc({})
.then(function () {
done(new Error('Should have thrown an error'));
})
.catch(function (err) {
permsStub.callCount.should.eql(1);
testStub.callCount.should.eql(1);
err.errorType.should.eql('NoPermissionError');
err.message.should.match(/testing/);
err.message.should.match(/tests/);
done();
});
});
it('should handle success', function (done) {
var testStub = sandbox.stub().returns(new Promise.resolve()),
permsStub = sandbox.stub(permissions, 'canThis', function () {
return {
testing: {
test: testStub
}
};
}),
permsFunc = apiUtils.handlePermissions('tests', 'testing'),
testObj = {foo: 'bar', id: 5};
permsFunc(testObj)
.then(function (res) {
permsStub.callCount.should.eql(1);
testStub.callCount.should.eql(1);
testStub.firstCall.args[0].should.eql(5);
res.should.eql(testObj);
done();
})
.catch(done);
});
});
}); });