0
Fork 0
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:
Fabien 'egg' O'Carroll 2021-11-01 10:27:50 +01:00 committed by GitHub
parent 46277b6718
commit b36d0cc1c4
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 8 additions and 32 deletions

View file

@ -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({

View file

@ -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');
}
}); });
}); });
}); });