coze-studio/frontend/packages/common/auth/__tests__/space/calc-permission.test.ts

239 lines
7.5 KiB
TypeScript

/*
* Copyright 2025 coze-dev Authors
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { describe, it, expect } from 'vitest';
import { SpaceRoleType } from '@coze-arch/idl/developer_api';
import { ESpacePermisson } from '../../src/space/constants';
import { calcPermission } from '../../src/space/calc-permission';
describe('Space Calc Permission', () => {
describe('calcPermission', () => {
it('应该为 Owner 角色返回正确的权限', () => {
// Owner should have permission to update the space
expect(
calcPermission(ESpacePermisson.UpdateSpace, [SpaceRoleType.Owner]),
).toBe(true);
// Owner should have permission to delete space
expect(
calcPermission(ESpacePermisson.DeleteSpace, [SpaceRoleType.Owner]),
).toBe(true);
// Owner should have permission to add members
expect(
calcPermission(ESpacePermisson.AddBotSpaceMember, [
SpaceRoleType.Owner,
]),
).toBe(true);
// Owner should have permission to remove members
expect(
calcPermission(ESpacePermisson.RemoveSpaceMember, [
SpaceRoleType.Owner,
]),
).toBe(true);
// Owner should have the right to transfer ownership
expect(
calcPermission(ESpacePermisson.TransferSpace, [SpaceRoleType.Owner]),
).toBe(true);
// Owner should have permission to update members
expect(
calcPermission(ESpacePermisson.UpdateSpaceMember, [
SpaceRoleType.Owner,
]),
).toBe(true);
// Owner should have permission to manage the API
expect(calcPermission(ESpacePermisson.API, [SpaceRoleType.Owner])).toBe(
true,
);
});
it('应该为 Admin 角色返回正确的权限', () => {
// Admin should have permission to add members
expect(
calcPermission(ESpacePermisson.AddBotSpaceMember, [
SpaceRoleType.Admin,
]),
).toBe(true);
// Admin should have permission to remove members
expect(
calcPermission(ESpacePermisson.RemoveSpaceMember, [
SpaceRoleType.Admin,
]),
).toBe(true);
// Admin should have permission to exit the space
expect(
calcPermission(ESpacePermisson.ExitSpace, [SpaceRoleType.Admin]),
).toBe(true);
// Admin should have permission to update members
expect(
calcPermission(ESpacePermisson.UpdateSpaceMember, [
SpaceRoleType.Admin,
]),
).toBe(true);
// Admin should not have permission to update the space
expect(
calcPermission(ESpacePermisson.UpdateSpace, [SpaceRoleType.Admin]),
).toBe(false);
// Admin should not have permission to delete space
expect(
calcPermission(ESpacePermisson.DeleteSpace, [SpaceRoleType.Admin]),
).toBe(false);
// Admin should not have permission to transfer ownership
expect(
calcPermission(ESpacePermisson.TransferSpace, [SpaceRoleType.Admin]),
).toBe(false);
// Admin should not have permission to manage APIs
expect(calcPermission(ESpacePermisson.API, [SpaceRoleType.Admin])).toBe(
false,
);
});
it('应该为 Member 角色返回正确的权限', () => {
// Members should have permission to exit the space
expect(
calcPermission(ESpacePermisson.ExitSpace, [SpaceRoleType.Member]),
).toBe(true);
// Members should not have permission to update space
expect(
calcPermission(ESpacePermisson.UpdateSpace, [SpaceRoleType.Member]),
).toBe(false);
// Members should not have permission to delete space
expect(
calcPermission(ESpacePermisson.DeleteSpace, [SpaceRoleType.Member]),
).toBe(false);
// Members should not have permission to add members
expect(
calcPermission(ESpacePermisson.AddBotSpaceMember, [
SpaceRoleType.Member,
]),
).toBe(false);
// Members should not have permission to remove members
expect(
calcPermission(ESpacePermisson.RemoveSpaceMember, [
SpaceRoleType.Member,
]),
).toBe(false);
// Members should not have permission to transfer ownership
expect(
calcPermission(ESpacePermisson.TransferSpace, [SpaceRoleType.Member]),
).toBe(false);
// Members should not have permission to update members
expect(
calcPermission(ESpacePermisson.UpdateSpaceMember, [
SpaceRoleType.Member,
]),
).toBe(false);
// Members should not have permission to manage APIs
expect(calcPermission(ESpacePermisson.API, [SpaceRoleType.Member])).toBe(
false,
);
});
it('应该为 Default 角色返回正确的权限', () => {
// Default should not have any permissions
expect(
calcPermission(ESpacePermisson.UpdateSpace, [SpaceRoleType.Default]),
).toBe(false);
expect(
calcPermission(ESpacePermisson.DeleteSpace, [SpaceRoleType.Default]),
).toBe(false);
expect(
calcPermission(ESpacePermisson.AddBotSpaceMember, [
SpaceRoleType.Default,
]),
).toBe(false);
expect(
calcPermission(ESpacePermisson.RemoveSpaceMember, [
SpaceRoleType.Default,
]),
).toBe(false);
expect(
calcPermission(ESpacePermisson.ExitSpace, [SpaceRoleType.Default]),
).toBe(false);
expect(
calcPermission(ESpacePermisson.TransferSpace, [SpaceRoleType.Default]),
).toBe(false);
expect(
calcPermission(ESpacePermisson.UpdateSpaceMember, [
SpaceRoleType.Default,
]),
).toBe(false);
expect(calcPermission(ESpacePermisson.API, [SpaceRoleType.Default])).toBe(
false,
);
});
it('应该处理多个角色的情况', () => {
// When a user has both the Member and Admin roles, they should have all the permissions of both roles
expect(
calcPermission(ESpacePermisson.ExitSpace, [
SpaceRoleType.Member,
SpaceRoleType.Admin,
]),
).toBe(true);
expect(
calcPermission(ESpacePermisson.RemoveSpaceMember, [
SpaceRoleType.Member,
SpaceRoleType.Admin,
]),
).toBe(true);
// Even if one of the roles has no permissions, it should return true as long as one of the roles has permissions.
expect(
calcPermission(ESpacePermisson.UpdateSpace, [
SpaceRoleType.Member,
SpaceRoleType.Owner,
]),
).toBe(true);
});
it('应该处理空角色数组', () => {
// When there is no role, it should return false.
expect(calcPermission(ESpacePermisson.UpdateSpace, [])).toBe(false);
expect(calcPermission(ESpacePermisson.ExitSpace, [])).toBe(false);
});
it('应该处理未知角色', () => {
// When the character is unknown, it should return false.
expect(
calcPermission(ESpacePermisson.UpdateSpace, [
'UnknownRole' as unknown as SpaceRoleType,
]),
).toBe(false);
});
});
});