mirror of
https://gitee.com/nocobase/nocobase.git
synced 2025-05-09 15:39:24 +08:00
* feat: improve code * chore: update version * feat: api service * fix: api services * feat: improve code * feat: improve code * feat: improve code * feat: pm socket * fix: test errors * feat: add built-in plugins before upgrade * feat: update docs * feat: improve code * fix: after load
100 lines
2.2 KiB
TypeScript
100 lines
2.2 KiB
TypeScript
import { Database, Model } from '@nocobase/database';
|
|
import UsersPlugin from '@nocobase/plugin-users';
|
|
import { MockServer } from '@nocobase/test';
|
|
|
|
import { prepareApp } from './prepare';
|
|
|
|
describe('role api', () => {
|
|
let app: MockServer;
|
|
let db: Database;
|
|
|
|
afterEach(async () => {
|
|
await app.destroy();
|
|
});
|
|
|
|
beforeEach(async () => {
|
|
app = await prepareApp();
|
|
db = app.db;
|
|
});
|
|
|
|
describe('grant', () => {
|
|
let role: Model;
|
|
let admin: Model;
|
|
let adminAgent;
|
|
|
|
beforeEach(async () => {
|
|
role = await db.getRepository('roles').findOne({
|
|
filter: {
|
|
name: 'admin',
|
|
},
|
|
});
|
|
|
|
const UserRepo = db.getCollection('users').repository;
|
|
admin = await UserRepo.create({
|
|
values: {
|
|
roles: ['admin'],
|
|
},
|
|
});
|
|
|
|
const userPlugin = app.getPlugin('users') as UsersPlugin;
|
|
adminAgent = app.agent().auth(
|
|
userPlugin.jwtService.sign({
|
|
userId: admin.get('id'),
|
|
}),
|
|
{ type: 'bearer' },
|
|
);
|
|
});
|
|
|
|
it('should list actions', async () => {
|
|
const response = await adminAgent.resource('availableActions').list();
|
|
expect(response.statusCode).toEqual(200);
|
|
});
|
|
|
|
it('should grant universal role actions', async () => {
|
|
// grant role actions
|
|
const response = await adminAgent.resource('roles').update({
|
|
forceUpdate: true,
|
|
values: {
|
|
strategy: {
|
|
actions: ['create:all', 'view:own'],
|
|
},
|
|
},
|
|
});
|
|
|
|
expect(response.statusCode).toEqual(200);
|
|
|
|
await role.reload();
|
|
|
|
expect(role.get('strategy')).toMatchObject({
|
|
actions: ['create:all', 'view:own'],
|
|
});
|
|
});
|
|
});
|
|
|
|
it('should works with default option', async () => {
|
|
await db.getRepository('roles').create({
|
|
values: {
|
|
name: 'role1',
|
|
title: 'admin 1',
|
|
default: true,
|
|
},
|
|
});
|
|
|
|
await db.getRepository('roles').create({
|
|
values: {
|
|
name: 'role2',
|
|
default: true,
|
|
},
|
|
});
|
|
|
|
const defaultRole = await db.getRepository('roles').find({
|
|
filter: {
|
|
default: true,
|
|
},
|
|
});
|
|
|
|
expect(defaultRole.length).toEqual(1);
|
|
expect(defaultRole[0].get('name')).toEqual('role2');
|
|
});
|
|
});
|