2022-02-11 12:53:23 -08:00
|
|
|
package acl
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestPermissionDeniedError(t *testing.T) {
|
|
|
|
type testCase struct {
|
|
|
|
err PermissionDeniedError
|
|
|
|
expected string
|
|
|
|
}
|
|
|
|
|
|
|
|
testName := func(t testCase) string {
|
|
|
|
return t.expected
|
|
|
|
}
|
|
|
|
|
|
|
|
auth1 := mockAuthorizer{}
|
|
|
|
|
|
|
|
cases := []testCase{
|
|
|
|
{
|
|
|
|
err: PermissionDeniedError{},
|
|
|
|
expected: "Permission denied",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
err: PermissionDeniedError{Cause: "simon says"},
|
|
|
|
expected: "Permission denied: simon says",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
err: PermissionDeniedByACL(&auth1, nil, ResourceService, AccessRead, "foobar"),
|
2022-03-10 18:48:27 -08:00
|
|
|
expected: "Permission denied: provided accessor lacks permission 'service:read' on foobar",
|
2022-02-11 12:53:23 -08:00
|
|
|
},
|
|
|
|
{
|
|
|
|
err: PermissionDeniedByACLUnnamed(&auth1, nil, ResourceService, AccessRead),
|
|
|
|
expected: "Permission denied: provided accessor lacks permission 'service:read'",
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, tcase := range cases {
|
|
|
|
t.Run(testName(tcase), func(t *testing.T) {
|
|
|
|
require.Error(t, tcase.err)
|
|
|
|
require.Equal(t, tcase.expected, tcase.err.Error())
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|