mirror of
https://github.com/TryGhost/Ghost.git
synced 2024-12-26 12:21:36 +03:00
ff3a9dde00
Temporary patch for #362 - Split out database teardown and initialization so they each have their own 2 second timeout. - Added some test-specific increased timeouts.
191 lines
5.0 KiB
JavaScript
191 lines
5.0 KiB
JavaScript
/*globals describe, it, beforeEach */
|
|
var should = require('should'),
|
|
helpers = require('./helpers'),
|
|
errors = require('../../server/errorHandling'),
|
|
Models = require('../../server/models');
|
|
|
|
describe("Role Model", function () {
|
|
|
|
var RoleModel = Models.Role;
|
|
|
|
should.exist(RoleModel);
|
|
|
|
before(function (done) {
|
|
helpers.clearData().then(function () {
|
|
done();
|
|
}, done);
|
|
});
|
|
|
|
beforeEach(function (done) {
|
|
this.timeout(5000);
|
|
helpers.initData().then(function () {
|
|
done();
|
|
}, done);
|
|
});
|
|
|
|
afterEach(function (done) {
|
|
helpers.clearData().then(function () {
|
|
done();
|
|
}, done);
|
|
});
|
|
|
|
it("can browse roles", function (done) {
|
|
RoleModel.browse().then(function (foundRoles) {
|
|
should.exist(foundRoles);
|
|
|
|
foundRoles.models.length.should.be.above(0);
|
|
|
|
done();
|
|
}).then(null, done);
|
|
});
|
|
|
|
it("can read roles", function (done) {
|
|
RoleModel.read({id: 1}).then(function (foundRole) {
|
|
should.exist(foundRole);
|
|
|
|
done();
|
|
}).then(null, done);
|
|
});
|
|
|
|
it("can edit roles", function (done) {
|
|
RoleModel.read({id: 1}).then(function (foundRole) {
|
|
should.exist(foundRole);
|
|
|
|
return foundRole.set({name: "updated"}).save();
|
|
}).then(function () {
|
|
return RoleModel.read({id: 1});
|
|
}).then(function (updatedRole) {
|
|
should.exist(updatedRole);
|
|
|
|
updatedRole.get("name").should.equal("updated");
|
|
|
|
done();
|
|
}).then(null, done);
|
|
});
|
|
|
|
it("can add roles", function (done) {
|
|
var newRole = {
|
|
name: "test1",
|
|
description: "test1 description"
|
|
};
|
|
|
|
RoleModel.add(newRole).then(function (createdRole) {
|
|
should.exist(createdRole);
|
|
|
|
createdRole.attributes.name.should.equal(newRole.name);
|
|
createdRole.attributes.description.should.equal(newRole.description);
|
|
|
|
done();
|
|
}).then(null, done);
|
|
});
|
|
|
|
it("can delete roles", function (done) {
|
|
RoleModel.read({id: 1}).then(function (foundRole) {
|
|
should.exist(foundRole);
|
|
|
|
return RoleModel['delete'](1);
|
|
}).then(function () {
|
|
return RoleModel.browse();
|
|
}).then(function (foundRoles) {
|
|
var hasRemovedId = foundRoles.any(function (role) {
|
|
return role.id === 1;
|
|
});
|
|
|
|
hasRemovedId.should.equal(false);
|
|
|
|
done();
|
|
}).then(null, done);
|
|
});
|
|
});
|
|
|
|
describe("Permission Model", function () {
|
|
|
|
var PermissionModel = Models.Permission;
|
|
|
|
should.exist(PermissionModel);
|
|
|
|
before(function (done) {
|
|
helpers.clearData().then(function () {
|
|
done();
|
|
}, done);
|
|
});
|
|
|
|
beforeEach(function (done) {
|
|
this.timeout(5000);
|
|
helpers.initData().then(function () {
|
|
done();
|
|
}, done);
|
|
});
|
|
|
|
afterEach(function (done) {
|
|
helpers.clearData().then(function () {
|
|
done();
|
|
}, done);
|
|
});
|
|
|
|
it("can browse permissions", function (done) {
|
|
PermissionModel.browse().then(function (foundPermissions) {
|
|
should.exist(foundPermissions);
|
|
|
|
foundPermissions.models.length.should.be.above(0);
|
|
|
|
done();
|
|
}).then(null, done);
|
|
});
|
|
|
|
it("can read permissions", function (done) {
|
|
PermissionModel.read({id: 1}).then(function (foundPermission) {
|
|
should.exist(foundPermission);
|
|
|
|
done();
|
|
}).then(null, done);
|
|
});
|
|
|
|
it("can edit permissions", function (done) {
|
|
PermissionModel.read({id: 1}).then(function (foundPermission) {
|
|
should.exist(foundPermission);
|
|
|
|
return foundPermission.set({name: "updated"}).save();
|
|
}).then(function () {
|
|
return PermissionModel.read({id: 1});
|
|
}).then(function (updatedPermission) {
|
|
should.exist(updatedPermission);
|
|
|
|
updatedPermission.get("name").should.equal("updated");
|
|
|
|
done();
|
|
}).then(null, done);
|
|
});
|
|
|
|
it("can add permissions", function (done) {
|
|
var newPerm = {
|
|
name: "testperm1"
|
|
};
|
|
|
|
PermissionModel.add(newPerm).then(function (createdPerm) {
|
|
should.exist(createdPerm);
|
|
|
|
createdPerm.attributes.name.should.equal(newPerm.name);
|
|
|
|
done();
|
|
}).then(null, done);
|
|
});
|
|
|
|
it("can delete permissions", function (done) {
|
|
PermissionModel.read({id: 1}).then(function (foundPermission) {
|
|
should.exist(foundPermission);
|
|
|
|
return PermissionModel['delete'](1);
|
|
}).then(function () {
|
|
return PermissionModel.browse();
|
|
}).then(function (foundPermissions) {
|
|
var hasRemovedId = foundPermissions.any(function (permission) {
|
|
return permission.id === 1;
|
|
});
|
|
|
|
hasRemovedId.should.equal(false);
|
|
|
|
done();
|
|
}).then(null, done);
|
|
});
|
|
}); |