394 lines
14 KiB
TypeScript
394 lines
14 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, SpaceType } from '@coze-arch/idl/developer_api';
|
|
|
|
import {
|
|
ProjectRoleType,
|
|
EProjectPermission,
|
|
} from '../../src/project/constants';
|
|
import { calcPermission } from '../../src/project/calc-permission';
|
|
|
|
describe('Project Calc Permission', () => {
|
|
describe('个人空间权限', () => {
|
|
it('应该为个人空间返回正确的权限', () => {
|
|
const params = {
|
|
projectRoles: [],
|
|
spaceRoles: [],
|
|
spaceType: SpaceType.Personal,
|
|
};
|
|
|
|
// Personal space should have viewing permission
|
|
expect(calcPermission(EProjectPermission.View, params)).toBe(true);
|
|
|
|
// Personal space should have permission to edit information
|
|
expect(calcPermission(EProjectPermission.EDIT_INFO, params)).toBe(true);
|
|
|
|
// Personal space should have deletion permission
|
|
expect(calcPermission(EProjectPermission.DELETE, params)).toBe(true);
|
|
|
|
// Personal space should have publishing permission
|
|
expect(calcPermission(EProjectPermission.PUBLISH, params)).toBe(true);
|
|
|
|
// Personal space should have permission to create resources
|
|
expect(calcPermission(EProjectPermission.CREATE_RESOURCE, params)).toBe(
|
|
true,
|
|
);
|
|
|
|
// Personal space should have permission to copy resources
|
|
expect(calcPermission(EProjectPermission.COPY_RESOURCE, params)).toBe(
|
|
true,
|
|
);
|
|
|
|
// Personal space should have permission to copy items
|
|
expect(calcPermission(EProjectPermission.COPY, params)).toBe(true);
|
|
|
|
// Personal space should have test run plug-in permissions
|
|
expect(calcPermission(EProjectPermission.TEST_RUN_PLUGIN, params)).toBe(
|
|
true,
|
|
);
|
|
|
|
// Personal space should have test run workflow permissions
|
|
expect(calcPermission(EProjectPermission.TEST_RUN_WORKFLOW, params)).toBe(
|
|
true,
|
|
);
|
|
});
|
|
|
|
it('应该为个人空间返回正确的无效权限', () => {
|
|
const params = {
|
|
projectRoles: [],
|
|
spaceRoles: [],
|
|
spaceType: SpaceType.Personal,
|
|
};
|
|
|
|
// Personal Spaces should not have Add Collaborators permissions
|
|
expect(calcPermission(EProjectPermission.ADD_COLLABORATOR, params)).toBe(
|
|
false,
|
|
);
|
|
|
|
// Personal space should not have permission to delete collaborators
|
|
expect(
|
|
calcPermission(EProjectPermission.DELETE_COLLABORATOR, params),
|
|
).toBe(false);
|
|
});
|
|
});
|
|
|
|
describe('团队空间项目角色权限', () => {
|
|
it('应该为项目所有者角色返回正确的权限', () => {
|
|
const params = {
|
|
projectRoles: [ProjectRoleType.Owner],
|
|
spaceRoles: [],
|
|
spaceType: SpaceType.Team,
|
|
};
|
|
|
|
// The project owner should have viewing rights
|
|
expect(calcPermission(EProjectPermission.View, params)).toBe(true);
|
|
|
|
// The project owner should have permission to edit the information
|
|
expect(calcPermission(EProjectPermission.EDIT_INFO, params)).toBe(true);
|
|
|
|
// The project owner should have delete permissions
|
|
expect(calcPermission(EProjectPermission.DELETE, params)).toBe(true);
|
|
|
|
// The project owner should have publishing rights
|
|
expect(calcPermission(EProjectPermission.PUBLISH, params)).toBe(true);
|
|
|
|
// The project owner should have the Create Resource permission
|
|
expect(calcPermission(EProjectPermission.CREATE_RESOURCE, params)).toBe(
|
|
true,
|
|
);
|
|
|
|
// The project owner should have permission to copy the resource
|
|
expect(calcPermission(EProjectPermission.COPY_RESOURCE, params)).toBe(
|
|
true,
|
|
);
|
|
|
|
// The project owner should have permission to copy the project
|
|
expect(calcPermission(EProjectPermission.COPY, params)).toBe(true);
|
|
|
|
// The project owner should have test run plug-in permissions
|
|
expect(calcPermission(EProjectPermission.TEST_RUN_PLUGIN, params)).toBe(
|
|
true,
|
|
);
|
|
|
|
// The project owner should have test run workflow permissions
|
|
expect(calcPermission(EProjectPermission.TEST_RUN_WORKFLOW, params)).toBe(
|
|
true,
|
|
);
|
|
|
|
// The project owner should have permission to add collaborators
|
|
expect(calcPermission(EProjectPermission.ADD_COLLABORATOR, params)).toBe(
|
|
true,
|
|
);
|
|
|
|
// The project owner should have the Delete Collaborator permission
|
|
expect(
|
|
calcPermission(EProjectPermission.DELETE_COLLABORATOR, params),
|
|
).toBe(true);
|
|
});
|
|
|
|
it('应该为项目编辑者角色返回正确的权限', () => {
|
|
const params = {
|
|
projectRoles: [ProjectRoleType.Editor],
|
|
spaceRoles: [],
|
|
spaceType: SpaceType.Team,
|
|
};
|
|
|
|
// Project editors should have viewing rights
|
|
expect(calcPermission(EProjectPermission.View, params)).toBe(true);
|
|
|
|
// Project editors should have permission to edit information
|
|
expect(calcPermission(EProjectPermission.EDIT_INFO, params)).toBe(true);
|
|
|
|
// Project editors should have the Create Resource permission
|
|
expect(calcPermission(EProjectPermission.CREATE_RESOURCE, params)).toBe(
|
|
true,
|
|
);
|
|
|
|
// Project editors should have permission to copy resources
|
|
expect(calcPermission(EProjectPermission.COPY_RESOURCE, params)).toBe(
|
|
true,
|
|
);
|
|
|
|
// The project editor should have permission to copy the project
|
|
expect(calcPermission(EProjectPermission.COPY, params)).toBe(true);
|
|
|
|
// Project editors should have test run plug-in permissions
|
|
expect(calcPermission(EProjectPermission.TEST_RUN_PLUGIN, params)).toBe(
|
|
true,
|
|
);
|
|
|
|
// The project editor should have test run workflow permissions
|
|
expect(calcPermission(EProjectPermission.TEST_RUN_WORKFLOW, params)).toBe(
|
|
true,
|
|
);
|
|
|
|
// Project editors should have Add Collaborators permission
|
|
expect(calcPermission(EProjectPermission.ADD_COLLABORATOR, params)).toBe(
|
|
true,
|
|
);
|
|
|
|
// Project editors should not have delete permissions
|
|
expect(calcPermission(EProjectPermission.DELETE, params)).toBe(false);
|
|
|
|
// Project editors should not have permission to publish
|
|
expect(calcPermission(EProjectPermission.PUBLISH, params)).toBe(false);
|
|
|
|
// Project editors should not have permission to delete collaborators
|
|
expect(
|
|
calcPermission(EProjectPermission.DELETE_COLLABORATOR, params),
|
|
).toBe(false);
|
|
});
|
|
});
|
|
|
|
describe('团队空间角色权限', () => {
|
|
it('应该为空间成员角色返回正确的权限', () => {
|
|
const params = {
|
|
projectRoles: [],
|
|
spaceRoles: [SpaceRoleType.Member],
|
|
spaceType: SpaceType.Team,
|
|
};
|
|
|
|
// Space members should have viewing rights
|
|
expect(calcPermission(EProjectPermission.View, params)).toBe(true);
|
|
|
|
// Space members should have permission to copy items
|
|
expect(calcPermission(EProjectPermission.COPY, params)).toBe(true);
|
|
|
|
// Space members should have test run workflow permissions
|
|
expect(calcPermission(EProjectPermission.TEST_RUN_WORKFLOW, params)).toBe(
|
|
true,
|
|
);
|
|
|
|
// Space members should not have permission to edit information
|
|
expect(calcPermission(EProjectPermission.EDIT_INFO, params)).toBe(false);
|
|
|
|
// Space members should not have delete permissions
|
|
expect(calcPermission(EProjectPermission.DELETE, params)).toBe(false);
|
|
|
|
// Space members should not have publishing privileges
|
|
expect(calcPermission(EProjectPermission.PUBLISH, params)).toBe(false);
|
|
|
|
// Space members should not have permission to create resources
|
|
expect(calcPermission(EProjectPermission.CREATE_RESOURCE, params)).toBe(
|
|
false,
|
|
);
|
|
|
|
// Space members should not have permission to copy resources
|
|
expect(calcPermission(EProjectPermission.COPY_RESOURCE, params)).toBe(
|
|
false,
|
|
);
|
|
|
|
// Space members should not have test run plug-in permissions
|
|
expect(calcPermission(EProjectPermission.TEST_RUN_PLUGIN, params)).toBe(
|
|
false,
|
|
);
|
|
|
|
// Space members should not have Add Collaborator permissions
|
|
expect(calcPermission(EProjectPermission.ADD_COLLABORATOR, params)).toBe(
|
|
false,
|
|
);
|
|
|
|
// Space members should not have permission to delete collaborators
|
|
expect(
|
|
calcPermission(EProjectPermission.DELETE_COLLABORATOR, params),
|
|
).toBe(false);
|
|
});
|
|
|
|
it('应该为空间所有者角色返回正确的权限', () => {
|
|
const params = {
|
|
projectRoles: [],
|
|
spaceRoles: [SpaceRoleType.Owner],
|
|
spaceType: SpaceType.Team,
|
|
};
|
|
|
|
// Space owners should have viewing rights
|
|
expect(calcPermission(EProjectPermission.View, params)).toBe(true);
|
|
|
|
// The space owner should have permission to copy items
|
|
expect(calcPermission(EProjectPermission.COPY, params)).toBe(true);
|
|
|
|
// Space owners should have test run workflow permissions
|
|
expect(calcPermission(EProjectPermission.TEST_RUN_WORKFLOW, params)).toBe(
|
|
true,
|
|
);
|
|
});
|
|
|
|
it('应该为空间管理员角色返回正确的权限', () => {
|
|
const params = {
|
|
projectRoles: [],
|
|
spaceRoles: [SpaceRoleType.Admin],
|
|
spaceType: SpaceType.Team,
|
|
};
|
|
|
|
// The space administrator should have viewing rights
|
|
expect(calcPermission(EProjectPermission.View, params)).toBe(true);
|
|
|
|
// The space administrator should have permission to copy items
|
|
expect(calcPermission(EProjectPermission.COPY, params)).toBe(true);
|
|
|
|
// The space administrator should have test run workflow permissions
|
|
expect(calcPermission(EProjectPermission.TEST_RUN_WORKFLOW, params)).toBe(
|
|
true,
|
|
);
|
|
});
|
|
|
|
it('应该为默认角色返回正确的权限', () => {
|
|
const params = {
|
|
projectRoles: [],
|
|
spaceRoles: [SpaceRoleType.Default],
|
|
spaceType: SpaceType.Team,
|
|
};
|
|
|
|
// The default role should not have any permissions
|
|
expect(calcPermission(EProjectPermission.View, params)).toBe(false);
|
|
expect(calcPermission(EProjectPermission.EDIT_INFO, params)).toBe(false);
|
|
expect(calcPermission(EProjectPermission.DELETE, params)).toBe(false);
|
|
expect(calcPermission(EProjectPermission.PUBLISH, params)).toBe(false);
|
|
expect(calcPermission(EProjectPermission.CREATE_RESOURCE, params)).toBe(
|
|
false,
|
|
);
|
|
expect(calcPermission(EProjectPermission.COPY_RESOURCE, params)).toBe(
|
|
false,
|
|
);
|
|
expect(calcPermission(EProjectPermission.COPY, params)).toBe(false);
|
|
expect(calcPermission(EProjectPermission.TEST_RUN_PLUGIN, params)).toBe(
|
|
false,
|
|
);
|
|
expect(calcPermission(EProjectPermission.TEST_RUN_WORKFLOW, params)).toBe(
|
|
false,
|
|
);
|
|
expect(calcPermission(EProjectPermission.ADD_COLLABORATOR, params)).toBe(
|
|
false,
|
|
);
|
|
expect(
|
|
calcPermission(EProjectPermission.DELETE_COLLABORATOR, params),
|
|
).toBe(false);
|
|
});
|
|
});
|
|
|
|
describe('混合角色权限', () => {
|
|
it('应该在同时拥有项目角色和空间角色时返回正确的权限', () => {
|
|
const params = {
|
|
projectRoles: [ProjectRoleType.Editor],
|
|
spaceRoles: [SpaceRoleType.Member],
|
|
spaceType: SpaceType.Team,
|
|
};
|
|
|
|
// Should have all the permissions of the project editor
|
|
expect(calcPermission(EProjectPermission.View, params)).toBe(true);
|
|
expect(calcPermission(EProjectPermission.EDIT_INFO, params)).toBe(true);
|
|
expect(calcPermission(EProjectPermission.CREATE_RESOURCE, params)).toBe(
|
|
true,
|
|
);
|
|
expect(calcPermission(EProjectPermission.COPY_RESOURCE, params)).toBe(
|
|
true,
|
|
);
|
|
expect(calcPermission(EProjectPermission.COPY, params)).toBe(true);
|
|
expect(calcPermission(EProjectPermission.TEST_RUN_PLUGIN, params)).toBe(
|
|
true,
|
|
);
|
|
expect(calcPermission(EProjectPermission.TEST_RUN_WORKFLOW, params)).toBe(
|
|
true,
|
|
);
|
|
expect(calcPermission(EProjectPermission.ADD_COLLABORATOR, params)).toBe(
|
|
true,
|
|
);
|
|
|
|
// There should be no permissions that the project editor does not have
|
|
expect(calcPermission(EProjectPermission.DELETE, params)).toBe(false);
|
|
expect(calcPermission(EProjectPermission.PUBLISH, params)).toBe(false);
|
|
expect(
|
|
calcPermission(EProjectPermission.DELETE_COLLABORATOR, params),
|
|
).toBe(false);
|
|
});
|
|
|
|
it('应该在没有有效角色时返回 false', () => {
|
|
const params = {
|
|
projectRoles: [],
|
|
spaceRoles: [],
|
|
spaceType: SpaceType.Team,
|
|
};
|
|
|
|
// No role should have no permissions
|
|
expect(calcPermission(EProjectPermission.View, params)).toBe(false);
|
|
expect(calcPermission(EProjectPermission.EDIT_INFO, params)).toBe(false);
|
|
expect(calcPermission(EProjectPermission.DELETE, params)).toBe(false);
|
|
expect(calcPermission(EProjectPermission.PUBLISH, params)).toBe(false);
|
|
expect(calcPermission(EProjectPermission.CREATE_RESOURCE, params)).toBe(
|
|
false,
|
|
);
|
|
expect(calcPermission(EProjectPermission.COPY_RESOURCE, params)).toBe(
|
|
false,
|
|
);
|
|
expect(calcPermission(EProjectPermission.COPY, params)).toBe(false);
|
|
expect(calcPermission(EProjectPermission.TEST_RUN_PLUGIN, params)).toBe(
|
|
false,
|
|
);
|
|
expect(calcPermission(EProjectPermission.TEST_RUN_WORKFLOW, params)).toBe(
|
|
false,
|
|
);
|
|
expect(calcPermission(EProjectPermission.ADD_COLLABORATOR, params)).toBe(
|
|
false,
|
|
);
|
|
expect(
|
|
calcPermission(EProjectPermission.DELETE_COLLABORATOR, params),
|
|
).toBe(false);
|
|
});
|
|
});
|
|
});
|