mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-20 22:42:53 -05:00
🐛 Fixed idempotentcy of addPermissionToRole util (#13685)
refs https://github.com/TryGhost/Team/issues/1178 The "up" migration that this util generates correctly throws if the pre-requisite data cannot be found in the database. The "down" migration however was incorrectly mirroring this behaviour of throwing - which meant that it wasn't idempotent, as it does not require a permission or role to existing if it wants to move relations between them.
This commit is contained in:
parent
46277b6718
commit
b36d0cc1c4
2 changed files with 8 additions and 32 deletions
|
@ -191,14 +191,8 @@ function addPermissionToRole(config) {
|
||||||
}).first();
|
}).first();
|
||||||
|
|
||||||
if (!permission) {
|
if (!permission) {
|
||||||
throw new errors.GhostError({
|
logging.warn(`Removing permission(${config.permission}) from role(${config.role}) - Permission not found.`);
|
||||||
message: tpl(messages.permissionRoleActionError, {
|
return;
|
||||||
action: 'remove',
|
|
||||||
permission: config.permission,
|
|
||||||
role: config.role,
|
|
||||||
resource: 'permission'
|
|
||||||
})
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const role = await connection('roles').where({
|
const role = await connection('roles').where({
|
||||||
|
@ -206,14 +200,8 @@ function addPermissionToRole(config) {
|
||||||
}).first();
|
}).first();
|
||||||
|
|
||||||
if (!role) {
|
if (!role) {
|
||||||
throw new errors.GhostError({
|
logging.warn(`Removing permission(${config.permission}) from role(${config.role}) - Role not found.`);
|
||||||
message: tpl(messages.permissionRoleActionError, {
|
return;
|
||||||
action: 'remove',
|
|
||||||
permission: config.permission,
|
|
||||||
role: config.role,
|
|
||||||
resource: 'role'
|
|
||||||
})
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const existingRelation = await connection('permissions_roles').where({
|
const existingRelation = await connection('permissions_roles').where({
|
||||||
|
|
|
@ -380,7 +380,7 @@ describe('migrations/utils/permissions', function () {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
it('Throws when permission cannot be found in down migration', async function () {
|
it('Does not throw when permission cannot be found in down migration', async function () {
|
||||||
const knex = await setupDb();
|
const knex = await setupDb();
|
||||||
|
|
||||||
const migration = utils.addPermissionToRole({
|
const migration = utils.addPermissionToRole({
|
||||||
|
@ -393,13 +393,7 @@ describe('migrations/utils/permissions', function () {
|
||||||
.where('name', '=', 'Permission Name')
|
.where('name', '=', 'Permission Name')
|
||||||
.del();
|
.del();
|
||||||
|
|
||||||
try {
|
await runDownMigration(knex, migration);
|
||||||
await runDownMigration(knex, migration);
|
|
||||||
should.fail('addPermissionToRole down migration did not throw');
|
|
||||||
} catch (err) {
|
|
||||||
should.equal(err instanceof errors.GhostError, true);
|
|
||||||
err.message.should.equal('Cannot remove permission(Permission Name) with role(Role Name) - permission does not exist');
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
|
||||||
it('Throws when role cannot be found', async function () {
|
it('Throws when role cannot be found', async function () {
|
||||||
|
@ -419,7 +413,7 @@ describe('migrations/utils/permissions', function () {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
it('Throws when role cannot be found in down migration', async function () {
|
it('Does not throw when role cannot be found in down migration', async function () {
|
||||||
const knex = await setupDb();
|
const knex = await setupDb();
|
||||||
|
|
||||||
const migration = utils.addPermissionToRole({
|
const migration = utils.addPermissionToRole({
|
||||||
|
@ -432,13 +426,7 @@ describe('migrations/utils/permissions', function () {
|
||||||
.where('name', '=', 'Role Name')
|
.where('name', '=', 'Role Name')
|
||||||
.del();
|
.del();
|
||||||
|
|
||||||
try {
|
await runDownMigration(knex, migration);
|
||||||
await runDownMigration(knex, migration);
|
|
||||||
should.fail('addPermissionToRole down migration did not throw');
|
|
||||||
} catch (err) {
|
|
||||||
should.equal(err instanceof errors.GhostError, true);
|
|
||||||
err.message.should.equal('Cannot remove permission(Permission Name) with role(Role Name) - role does not exist');
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
Loading…
Add table
Reference in a new issue