Spaces:
Running
Running
// _ _ | |
// __ _____ __ ___ ___ __ _| |_ ___ | |
// \ \ /\ / / _ \/ _` \ \ / / |/ _` | __/ _ \ | |
// \ V V / __/ (_| |\ V /| | (_| | || __/ | |
// \_/\_/ \___|\__,_| \_/ |_|\__,_|\__\___| | |
// | |
// Copyright © 2016 - 2024 Weaviate B.V. All rights reserved. | |
// | |
// CONTACT: [email protected] | |
// | |
package errors | |
import ( | |
"testing" | |
"github.com/stretchr/testify/assert" | |
"github.com/weaviate/weaviate/entities/models" | |
) | |
func Test_ForbiddenError_NoGroups(t *testing.T) { | |
principal := &models.Principal{ | |
Username: "john", | |
} | |
err := NewForbidden(principal, "delete", "schema/things") | |
expectedErrMsg := "forbidden: user 'john' has insufficient permissions to delete schema/things" | |
assert.Equal(t, expectedErrMsg, err.Error()) | |
} | |
func Test_ForbiddenError_SingleGroup(t *testing.T) { | |
principal := &models.Principal{ | |
Username: "john", | |
Groups: []string{"worstusers"}, | |
} | |
err := NewForbidden(principal, "delete", "schema/things") | |
expectedErrMsg := "forbidden: user 'john' (of group 'worstusers') has insufficient permissions to delete schema/things" | |
assert.Equal(t, expectedErrMsg, err.Error()) | |
} | |
func Test_ForbiddenError_MultipleGroups(t *testing.T) { | |
principal := &models.Principal{ | |
Username: "john", | |
Groups: []string{"worstusers", "fraudsters", "evilpeople"}, | |
} | |
err := NewForbidden(principal, "delete", "schema/things") | |
expectedErrMsg := "forbidden: user 'john' (of groups 'worstusers', 'fraudsters', 'evilpeople') " + | |
"has insufficient permissions to delete schema/things" | |
assert.Equal(t, expectedErrMsg, err.Error()) | |
} | |