Spaces:
Running
Running
// _ _ | |
// __ _____ __ ___ ___ __ _| |_ ___ | |
// \ \ /\ / / _ \/ _` \ \ / / |/ _` | __/ _ \ | |
// \ V V / __/ (_| |\ V /| | (_| | || __/ | |
// \_/\_/ \___|\__,_| \_/ |_|\__,_|\__\___| | |
// | |
// Copyright © 2016 - 2024 Weaviate B.V. All rights reserved. | |
// | |
// CONTACT: [email protected] | |
// | |
package authorization | |
import ( | |
"testing" | |
"github.com/stretchr/testify/assert" | |
"github.com/weaviate/weaviate/usecases/auth/authorization/adminlist" | |
"github.com/weaviate/weaviate/usecases/config" | |
) | |
func Test_Authorizer(t *testing.T) { | |
t.Run("when no authz is configured", func(t *testing.T) { | |
cfg := config.Config{} | |
authorizer := New(cfg) | |
t.Run("it uses the dummy authorizer", func(t *testing.T) { | |
_, ok := authorizer.(*DummyAuthorizer) | |
assert.Equal(t, true, ok) | |
}) | |
t.Run("any request is allowed", func(t *testing.T) { | |
err := authorizer.Authorize(nil, "delete", "the/world") | |
assert.Nil(t, err) | |
}) | |
}) | |
t.Run("when adminlist is configured", func(t *testing.T) { | |
cfg := config.Config{ | |
Authorization: config.Authorization{ | |
AdminList: adminlist.Config{ | |
Enabled: true, | |
}, | |
}, | |
} | |
authorizer := New(cfg) | |
_, ok := authorizer.(*adminlist.Authorizer) | |
assert.Equal(t, true, ok) | |
}) | |
} | |