Files
cloudron-box/src/routes/test/accesscontrol-test.js
T

82 lines
2.5 KiB
JavaScript
Raw Normal View History

2018-04-26 15:54:53 -07:00
/* jslint node:true */
/* global it:false */
/* global describe:false */
'use strict';
var accesscontrol = require('../accesscontrol.js'),
expect = require('expect.js'),
2020-02-06 14:50:12 +01:00
HttpError = require('connect-lastmile').HttpError;
2018-04-26 15:54:53 -07:00
describe('scopes middleware', function () {
2018-06-17 15:25:41 -07:00
it('fails due to empty scope in request', function (done) {
2018-04-26 15:54:53 -07:00
var mw = accesscontrol.scope('admin')[1];
2018-06-17 19:54:05 -07:00
var req = { authInfo: { authorizedScopes: [ ] } };
2018-04-26 15:54:53 -07:00
mw(req, null, function (error) {
expect(error).to.be.a(HttpError);
done();
});
});
it('fails due to wrong scope in request', function (done) {
var mw = accesscontrol.scope('admin')[1];
2018-06-17 19:54:05 -07:00
var req = { authInfo: { authorizedScopes: [ 'foobar', 'something' ] } };
2018-04-26 15:54:53 -07:00
mw(req, null, function (error) {
expect(error).to.be.a(HttpError);
done();
});
});
it('fails due to wrong scope in request', function (done) {
var mw = accesscontrol.scope('admin,users')[1];
2018-06-17 19:54:05 -07:00
var req = { authInfo: { authorizedScopes: [ 'foobar', 'admin' ] } };
2018-04-26 15:54:53 -07:00
mw(req, null, function (error) {
expect(error).to.be.a(HttpError);
done();
});
});
it('succeeds with one requested scope and one provided scope', function (done) {
var mw = accesscontrol.scope('admin')[1];
2018-06-17 19:54:05 -07:00
var req = { authInfo: { authorizedScopes: [ 'admin' ] } };
2018-04-26 15:54:53 -07:00
mw(req, null, function (error) {
expect(error).to.not.be.ok();
done();
});
});
it('succeeds with one requested scope and two provided scopes', function (done) {
var mw = accesscontrol.scope('admin')[1];
2018-06-17 19:54:05 -07:00
var req = { authInfo: { authorizedScopes: [ 'foobar', 'admin' ] } };
2018-04-26 15:54:53 -07:00
mw(req, null, function (error) {
expect(error).to.not.be.ok();
done();
});
});
it('succeeds with two requested scope and two provided scopes', function (done) {
var mw = accesscontrol.scope('admin,foobar')[1];
2018-06-17 19:54:05 -07:00
var req = { authInfo: { authorizedScopes: [ 'foobar', 'admin' ] } };
2018-04-26 15:54:53 -07:00
mw(req, null, function (error) {
expect(error).to.not.be.ok();
done();
});
});
it('succeeds with two requested scope and provided wildcard scope', function (done) {
var mw = accesscontrol.scope('admin,foobar')[1];
2018-06-17 19:54:05 -07:00
var req = { authInfo: { authorizedScopes: [ '*' ] } };
2018-04-26 15:54:53 -07:00
mw(req, null, function (error) {
expect(error).to.not.be.ok();
done();
});
});
2019-07-25 15:43:51 -07:00
});