// _ _ // __ _____ __ ___ ___ __ _| |_ ___ // \ \ /\ / / _ \/ _` \ \ / / |/ _` | __/ _ \ // \ V V / __/ (_| |\ V /| | (_| | || __/ // \_/\_/ \___|\__,_| \_/ |_|\__,_|\__\___| // // Copyright © 2016 - 2024 Weaviate B.V. All rights reserved. // // CONTACT: hello@weaviate.io // 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()) }