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