1
0
mirror of https://github.com/pocketbase/pocketbase.git synced 2025-01-23 05:55:24 +02:00
pocketbase/apis/api_error_test.go

151 lines
4.7 KiB
Go
Raw Normal View History

2022-10-30 10:28:14 +02:00
package apis_test
2022-07-07 00:19:05 +03:00
import (
"encoding/json"
"errors"
"testing"
validation "github.com/go-ozzo/ozzo-validation/v4"
2022-10-30 10:28:14 +02:00
"github.com/pocketbase/pocketbase/apis"
2022-07-07 00:19:05 +03:00
)
func TestNewApiErrorWithRawData(t *testing.T) {
2022-10-30 10:28:14 +02:00
e := apis.NewApiError(
2022-07-07 00:19:05 +03:00
300,
"message_test",
"rawData_test",
)
result, _ := json.Marshal(e)
expected := `{"code":300,"message":"Message_test.","data":{}}`
if string(result) != expected {
t.Errorf("Expected %v, got %v", expected, string(result))
}
if e.Error() != "Message_test." {
t.Errorf("Expected %q, got %q", "Message_test.", e.Error())
}
if e.RawData() != "rawData_test" {
t.Errorf("Expected rawData %v, got %v", "rawData_test", e.RawData())
}
}
func TestNewApiErrorWithValidationData(t *testing.T) {
2022-10-30 10:28:14 +02:00
e := apis.NewApiError(
2022-07-07 00:19:05 +03:00
300,
"message_test",
validation.Errors{
2023-06-08 18:14:01 +03:00
"err1": errors.New("test error"), // should be normalized
2022-07-07 00:19:05 +03:00
"err2": validation.ErrRequired,
"err3": validation.Errors{
2023-06-08 18:14:01 +03:00
"sub1": errors.New("test error"), // should be normalized
2022-07-07 00:19:05 +03:00
"sub2": validation.ErrRequired,
"sub3": validation.Errors{
"sub11": validation.ErrRequired,
},
},
},
)
result, _ := json.Marshal(e)
2023-06-08 18:14:01 +03:00
expected := `{"code":300,"message":"Message_test.","data":{"err1":{"code":"validation_invalid_value","message":"Invalid value."},"err2":{"code":"validation_required","message":"Cannot be blank."},"err3":{"sub1":{"code":"validation_invalid_value","message":"Invalid value."},"sub2":{"code":"validation_required","message":"Cannot be blank."},"sub3":{"sub11":{"code":"validation_required","message":"Cannot be blank."}}}}}`
2022-07-07 00:19:05 +03:00
if string(result) != expected {
2023-06-08 18:14:01 +03:00
t.Errorf("Expected \n%v, \ngot \n%v", expected, string(result))
2022-07-07 00:19:05 +03:00
}
if e.Error() != "Message_test." {
t.Errorf("Expected %q, got %q", "Message_test.", e.Error())
}
if e.RawData() == nil {
t.Error("Expected non-nil rawData")
}
}
func TestNewNotFoundError(t *testing.T) {
scenarios := []struct {
message string
data any
expected string
}{
{"", nil, `{"code":404,"message":"The requested resource wasn't found.","data":{}}`},
{"demo", "rawData_test", `{"code":404,"message":"Demo.","data":{}}`},
2023-06-08 18:14:01 +03:00
{"demo", validation.Errors{"err1": validation.NewError("test_code", "test_message")}, `{"code":404,"message":"Demo.","data":{"err1":{"code":"test_code","message":"Test_message."}}}`},
2022-07-07 00:19:05 +03:00
}
for i, scenario := range scenarios {
2022-10-30 10:28:14 +02:00
e := apis.NewNotFoundError(scenario.message, scenario.data)
2022-07-07 00:19:05 +03:00
result, _ := json.Marshal(e)
if string(result) != scenario.expected {
2023-06-08 18:14:01 +03:00
t.Errorf("(%d) Expected \n%v, \ngot \n%v", i, scenario.expected, string(result))
2022-07-07 00:19:05 +03:00
}
}
}
func TestNewBadRequestError(t *testing.T) {
scenarios := []struct {
message string
data any
expected string
}{
{"", nil, `{"code":400,"message":"Something went wrong while processing your request.","data":{}}`},
{"demo", "rawData_test", `{"code":400,"message":"Demo.","data":{}}`},
2023-06-08 18:14:01 +03:00
{"demo", validation.Errors{"err1": validation.NewError("test_code", "test_message")}, `{"code":400,"message":"Demo.","data":{"err1":{"code":"test_code","message":"Test_message."}}}`},
2022-07-07 00:19:05 +03:00
}
for i, scenario := range scenarios {
2022-10-30 10:28:14 +02:00
e := apis.NewBadRequestError(scenario.message, scenario.data)
2022-07-07 00:19:05 +03:00
result, _ := json.Marshal(e)
if string(result) != scenario.expected {
2023-06-08 18:14:01 +03:00
t.Errorf("(%d) Expected \n%v, \ngot \n%v", i, scenario.expected, string(result))
2022-07-07 00:19:05 +03:00
}
}
}
func TestNewForbiddenError(t *testing.T) {
scenarios := []struct {
message string
data any
expected string
}{
{"", nil, `{"code":403,"message":"You are not allowed to perform this request.","data":{}}`},
{"demo", "rawData_test", `{"code":403,"message":"Demo.","data":{}}`},
2023-06-08 18:14:01 +03:00
{"demo", validation.Errors{"err1": validation.NewError("test_code", "test_message")}, `{"code":403,"message":"Demo.","data":{"err1":{"code":"test_code","message":"Test_message."}}}`},
2022-07-07 00:19:05 +03:00
}
for i, scenario := range scenarios {
2022-10-30 10:28:14 +02:00
e := apis.NewForbiddenError(scenario.message, scenario.data)
2022-07-07 00:19:05 +03:00
result, _ := json.Marshal(e)
if string(result) != scenario.expected {
2023-06-08 18:14:01 +03:00
t.Errorf("(%d) Expected \n%v, \ngot \n%v", i, scenario.expected, string(result))
2022-07-07 00:19:05 +03:00
}
}
}
func TestNewUnauthorizedError(t *testing.T) {
scenarios := []struct {
message string
data any
expected string
}{
{"", nil, `{"code":401,"message":"Missing or invalid authentication token.","data":{}}`},
{"demo", "rawData_test", `{"code":401,"message":"Demo.","data":{}}`},
2023-06-08 18:16:00 +03:00
{"demo", validation.Errors{"err1": validation.NewError("test_code", "test_message")}, `{"code":401,"message":"Demo.","data":{"err1":{"code":"test_code","message":"Test_message."}}}`},
2022-07-07 00:19:05 +03:00
}
for i, scenario := range scenarios {
2022-10-30 10:28:14 +02:00
e := apis.NewUnauthorizedError(scenario.message, scenario.data)
2022-07-07 00:19:05 +03:00
result, _ := json.Marshal(e)
if string(result) != scenario.expected {
2023-06-08 18:14:01 +03:00
t.Errorf("(%d) Expected \n%v, \ngot \n%v", i, scenario.expected, string(result))
2022-07-07 00:19:05 +03:00
}
}
}