-
-
Notifications
You must be signed in to change notification settings - Fork 1.5k
/
error_enhancer_test.go
60 lines (54 loc) · 2.06 KB
/
error_enhancer_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
// Copyright © 2022 Ory Corp
// SPDX-License-Identifier: Apache-2.0
package x
import (
"encoding/json"
errors2 "errors"
"fmt"
"net/http"
"testing"
"github.com/ory/x/errorsx"
"github.com/pkg/errors"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require"
"github.com/ory/fosite"
"github.com/ory/x/sqlcon"
)
func TestErrorEnhancer(t *testing.T) {
for k, tc := range []struct {
in error
out string
}{
{
in: sqlcon.ErrNoRows,
out: "{\"error\":\"Unable to locate the resource\",\"error_description\":\"\"}",
},
{
in: errorsx.WithStack(sqlcon.ErrNoRows),
out: "{\"error\":\"Unable to locate the resource\",\"error_description\":\"\"}",
},
{
in: errors.New("bla"),
out: "{\"error\":\"error\",\"error_description\":\"The error is unrecognizable\"}",
},
{
in: errors2.New("bla"),
out: "{\"error\":\"error\",\"error_description\":\"The error is unrecognizable\"}",
},
{
in: fosite.ErrInvalidRequest,
out: "{\"error\":\"invalid_request\",\"error_description\":\"The request is missing a required parameter, includes an invalid parameter value, includes a parameter more than once, or is otherwise malformed. Make sure that the various parameters are correct, be aware of case sensitivity and trim your parameters. Make sure that the client you are using has exactly whitelisted the redirect_uri you specified.\"}",
},
{
in: errorsx.WithStack(fosite.ErrInvalidRequest),
out: "{\"error\":\"invalid_request\",\"error_description\":\"The request is missing a required parameter, includes an invalid parameter value, includes a parameter more than once, or is otherwise malformed. Make sure that the various parameters are correct, be aware of case sensitivity and trim your parameters. Make sure that the client you are using has exactly whitelisted the redirect_uri you specified.\"}",
},
} {
t.Run(fmt.Sprintf("case=%d", k), func(t *testing.T) {
err := ErrorEnhancer(new(http.Request), tc.in)
out, err2 := json.Marshal(err)
require.NoError(t, err2)
assert.Equal(t, tc.out, string(out))
})
}
}