status-go/protocol/communities/check_permissions_response_test.go
Patryk Osmaczko b02e3b19e2 feat: add permissions reevaluation request
Token master can't manage members directly, so it must request
reevaluation from the control node.

fixes: status-im/status-desktop#13778
2024-03-12 14:15:01 +01:00

147 lines
5.0 KiB
Go

package communities
import (
"testing"
"github.com/stretchr/testify/assert"
"github.com/status-im/status-go/protocol/protobuf"
)
func TestCalculateRolesAndHighestRole(t *testing.T) {
testCases := []struct {
name string
permissions map[string]*PermissionTokenCriteriaResult
expectedRolesOrder []protobuf.CommunityTokenPermission_Type
expectedHighestRole protobuf.CommunityTokenPermission_Type
}{
{
name: "Basic scenario with multiple permissions",
permissions: map[string]*PermissionTokenCriteriaResult{
"1": {
Role: protobuf.CommunityTokenPermission_BECOME_MEMBER,
TokenRequirements: []TokenRequirementResponse{
{Satisfied: true},
},
},
"2": {
Role: protobuf.CommunityTokenPermission_BECOME_ADMIN,
TokenRequirements: []TokenRequirementResponse{
{Satisfied: true},
},
},
"3": {
Role: protobuf.CommunityTokenPermission_BECOME_TOKEN_MASTER,
TokenRequirements: []TokenRequirementResponse{
{Satisfied: false},
},
},
"4": {
Role: protobuf.CommunityTokenPermission_BECOME_TOKEN_OWNER,
TokenRequirements: []TokenRequirementResponse{
{Satisfied: false},
},
},
},
expectedRolesOrder: []protobuf.CommunityTokenPermission_Type{protobuf.CommunityTokenPermission_BECOME_TOKEN_OWNER, protobuf.CommunityTokenPermission_BECOME_TOKEN_MASTER, protobuf.CommunityTokenPermission_BECOME_ADMIN, protobuf.CommunityTokenPermission_BECOME_MEMBER},
expectedHighestRole: protobuf.CommunityTokenPermission_BECOME_ADMIN,
},
{
name: "No member permission created",
permissions: map[string]*PermissionTokenCriteriaResult{
"2": {
Role: protobuf.CommunityTokenPermission_BECOME_ADMIN,
TokenRequirements: []TokenRequirementResponse{
{Satisfied: false},
},
},
"3": {
Role: protobuf.CommunityTokenPermission_BECOME_TOKEN_MASTER,
TokenRequirements: []TokenRequirementResponse{
{Satisfied: false},
},
},
"4": {
Role: protobuf.CommunityTokenPermission_BECOME_TOKEN_OWNER,
TokenRequirements: []TokenRequirementResponse{
{Satisfied: false},
},
},
},
expectedRolesOrder: []protobuf.CommunityTokenPermission_Type{protobuf.CommunityTokenPermission_BECOME_TOKEN_OWNER, protobuf.CommunityTokenPermission_BECOME_TOKEN_MASTER, protobuf.CommunityTokenPermission_BECOME_ADMIN, protobuf.CommunityTokenPermission_BECOME_MEMBER},
expectedHighestRole: protobuf.CommunityTokenPermission_BECOME_MEMBER,
},
{
name: "no permission satisfied",
permissions: map[string]*PermissionTokenCriteriaResult{
"1": {
Role: protobuf.CommunityTokenPermission_BECOME_MEMBER,
TokenRequirements: []TokenRequirementResponse{
{Satisfied: false},
},
},
"2": {
Role: protobuf.CommunityTokenPermission_BECOME_ADMIN,
TokenRequirements: []TokenRequirementResponse{
{Satisfied: false},
},
},
"3": {
Role: protobuf.CommunityTokenPermission_BECOME_TOKEN_MASTER,
TokenRequirements: []TokenRequirementResponse{
{Satisfied: false},
},
},
"4": {
Role: protobuf.CommunityTokenPermission_BECOME_TOKEN_OWNER,
TokenRequirements: []TokenRequirementResponse{
{Satisfied: false},
},
},
},
expectedRolesOrder: []protobuf.CommunityTokenPermission_Type{protobuf.CommunityTokenPermission_BECOME_TOKEN_OWNER, protobuf.CommunityTokenPermission_BECOME_TOKEN_MASTER, protobuf.CommunityTokenPermission_BECOME_ADMIN, protobuf.CommunityTokenPermission_BECOME_MEMBER},
},
{
name: "scenario with multiple channel permissions",
permissions: map[string]*PermissionTokenCriteriaResult{
"1": {
Role: protobuf.CommunityTokenPermission_CAN_VIEW_CHANNEL,
TokenRequirements: []TokenRequirementResponse{
{Satisfied: true},
},
},
"2": {
Role: protobuf.CommunityTokenPermission_CAN_VIEW_CHANNEL,
TokenRequirements: []TokenRequirementResponse{
{Satisfied: false},
},
},
"3": {
Role: protobuf.CommunityTokenPermission_CAN_VIEW_AND_POST_CHANNEL,
TokenRequirements: []TokenRequirementResponse{
{Satisfied: true},
},
},
},
expectedRolesOrder: []protobuf.CommunityTokenPermission_Type{protobuf.CommunityTokenPermission_CAN_VIEW_AND_POST_CHANNEL, protobuf.CommunityTokenPermission_CAN_VIEW_CHANNEL, protobuf.CommunityTokenPermission_BECOME_MEMBER},
expectedHighestRole: protobuf.CommunityTokenPermission_CAN_VIEW_AND_POST_CHANNEL,
},
}
for _, tc := range testCases {
t.Run(tc.name, func(t *testing.T) {
result := calculateRolesAndHighestRole(tc.permissions)
var actualOrder []protobuf.CommunityTokenPermission_Type
for _, r := range result.Roles {
actualOrder = append(actualOrder, r.Role)
}
if tc.expectedHighestRole == 0 {
assert.Nil(t, result.HighestRole)
} else {
assert.Equal(t, tc.expectedHighestRole, result.HighestRole.Role, "Highest role is not calculated as expected")
}
assert.Equal(t, tc.expectedRolesOrder, actualOrder, "Roles are not calculated as expected")
})
}
}