Skip to content

Commit

Permalink
fix: return meaningful status code when relation is not known (#1275)
Browse files Browse the repository at this point in the history
  • Loading branch information
zepatrik authored Mar 9, 2023
1 parent 11d0916 commit 1fef45a
Show file tree
Hide file tree
Showing 2 changed files with 43 additions and 2 deletions.
5 changes: 3 additions & 2 deletions internal/namespace/definitions.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,8 @@ package namespace
import (
"context"
"encoding/json"
"fmt"

"github.com/ory/herodot"

"github.com/ory/keto/internal/namespace/ast"
)
Expand Down Expand Up @@ -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)
}
40 changes: 40 additions & 0 deletions internal/namespace/definitions_test.go
Original file line number Diff line number Diff line change
@@ -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)
}

0 comments on commit 1fef45a

Please # to comment.