From 1fef45a2a0df895ca660225ad032f850d96f1c7d Mon Sep 17 00:00:00 2001 From: Patrik Date: Thu, 9 Mar 2023 14:39:23 +0100 Subject: [PATCH] fix: return meaningful status code when relation is not known (#1275) --- internal/namespace/definitions.go | 5 ++-- internal/namespace/definitions_test.go | 40 ++++++++++++++++++++++++++ 2 files changed, 43 insertions(+), 2 deletions(-) create mode 100644 internal/namespace/definitions_test.go diff --git a/internal/namespace/definitions.go b/internal/namespace/definitions.go index 386610ea6..4d65e37c5 100644 --- a/internal/namespace/definitions.go +++ b/internal/namespace/definitions.go @@ -6,7 +6,8 @@ package namespace import ( "context" "encoding/json" - "fmt" + + "github.com/ory/herodot" "github.com/ory/keto/internal/namespace/ast" ) @@ -57,5 +58,5 @@ func ASTRelationFor(ctx context.Context, m Manager, namespace, relation string) return &rel, nil } } - return nil, fmt.Errorf("relation %q not found", relation) + return nil, herodot.ErrBadRequest.WithReasonf("relation %q does not exist", relation) } diff --git a/internal/namespace/definitions_test.go b/internal/namespace/definitions_test.go new file mode 100644 index 000000000..68ba2098f --- /dev/null +++ b/internal/namespace/definitions_test.go @@ -0,0 +1,40 @@ +// Copyright © 2023 Ory Corp +// SPDX-License-Identifier: Apache-2.0 + +package namespace_test + +import ( + "context" + "net/http" + "testing" + + "github.com/ory/herodot" + "github.com/ory/x/pointerx" + "github.com/stretchr/testify/assert" + "github.com/stretchr/testify/require" + + "github.com/ory/keto/internal/driver/config" + "github.com/ory/keto/internal/namespace" + "github.com/ory/keto/internal/namespace/ast" +) + +func TestASTRelationFor(t *testing.T) { + ctx := context.Background() + nm := config.NewMemoryNamespaceManager(&namespace.Namespace{ + Name: "test", + Relations: []ast.Relation{{Name: "test"}}, + }) + + rel, err := namespace.ASTRelationFor(ctx, nm, "test", "test") + require.NoError(t, err) + assert.Equal(t, "test", rel.Name) + + _, err = namespace.ASTRelationFor(ctx, nm, "test", "unknown") + herodotErr := herodot.ErrBadRequest + require.ErrorAs(t, err, pointerx.Ptr(&herodotErr)) + assert.Equal(t, http.StatusBadRequest, herodotErr.CodeField) + + rel, err = namespace.ASTRelationFor(ctx, nm, "unknown", "") + require.NoError(t, err) + assert.Nil(t, rel) +}