mirror of
https://github.com/pocketbase/pocketbase.git
synced 2025-01-25 06:42:43 +02:00
151 lines
4.6 KiB
Go
151 lines
4.6 KiB
Go
package rest_test
|
|
|
|
import (
|
|
"encoding/json"
|
|
"errors"
|
|
"testing"
|
|
|
|
validation "github.com/go-ozzo/ozzo-validation/v4"
|
|
"github.com/pocketbase/pocketbase/tools/rest"
|
|
)
|
|
|
|
func TestNewApiErrorWithRawData(t *testing.T) {
|
|
e := rest.NewApiError(
|
|
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) {
|
|
e := rest.NewApiError(
|
|
300,
|
|
"message_test",
|
|
validation.Errors{
|
|
"err1": errors.New("test error"),
|
|
"err2": validation.ErrRequired,
|
|
"err3": validation.Errors{
|
|
"sub1": errors.New("test error"),
|
|
"sub2": validation.ErrRequired,
|
|
"sub3": validation.Errors{
|
|
"sub11": validation.ErrRequired,
|
|
},
|
|
},
|
|
},
|
|
)
|
|
|
|
result, _ := json.Marshal(e)
|
|
expected := `{"code":300,"message":"Message_test.","data":{"err1":{"code":"validation_invalid_value","message":"Test error."},"err2":{"code":"validation_required","message":"Cannot be blank."},"err3":{"sub1":{"code":"validation_invalid_value","message":"Test error."},"sub2":{"code":"validation_required","message":"Cannot be blank."},"sub3":{"sub11":{"code":"validation_required","message":"Cannot be blank."}}}}}`
|
|
|
|
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() == 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":{}}`},
|
|
{"demo", validation.Errors{"err1": errors.New("test error")}, `{"code":404,"message":"Demo.","data":{"err1":{"code":"validation_invalid_value","message":"Test error."}}}`},
|
|
}
|
|
|
|
for i, scenario := range scenarios {
|
|
e := rest.NewNotFoundError(scenario.message, scenario.data)
|
|
result, _ := json.Marshal(e)
|
|
|
|
if string(result) != scenario.expected {
|
|
t.Errorf("(%d) Expected %v, got %v", i, scenario.expected, string(result))
|
|
}
|
|
}
|
|
}
|
|
|
|
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":{}}`},
|
|
{"demo", validation.Errors{"err1": errors.New("test error")}, `{"code":400,"message":"Demo.","data":{"err1":{"code":"validation_invalid_value","message":"Test error."}}}`},
|
|
}
|
|
|
|
for i, scenario := range scenarios {
|
|
e := rest.NewBadRequestError(scenario.message, scenario.data)
|
|
result, _ := json.Marshal(e)
|
|
|
|
if string(result) != scenario.expected {
|
|
t.Errorf("(%d) Expected %v, got %v", i, scenario.expected, string(result))
|
|
}
|
|
}
|
|
}
|
|
|
|
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":{}}`},
|
|
{"demo", validation.Errors{"err1": errors.New("test error")}, `{"code":403,"message":"Demo.","data":{"err1":{"code":"validation_invalid_value","message":"Test error."}}}`},
|
|
}
|
|
|
|
for i, scenario := range scenarios {
|
|
e := rest.NewForbiddenError(scenario.message, scenario.data)
|
|
result, _ := json.Marshal(e)
|
|
|
|
if string(result) != scenario.expected {
|
|
t.Errorf("(%d) Expected %v, got %v", i, scenario.expected, string(result))
|
|
}
|
|
}
|
|
}
|
|
|
|
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":{}}`},
|
|
{"demo", validation.Errors{"err1": errors.New("test error")}, `{"code":401,"message":"Demo.","data":{"err1":{"code":"validation_invalid_value","message":"Test error."}}}`},
|
|
}
|
|
|
|
for i, scenario := range scenarios {
|
|
e := rest.NewUnauthorizedError(scenario.message, scenario.data)
|
|
result, _ := json.Marshal(e)
|
|
|
|
if string(result) != scenario.expected {
|
|
t.Errorf("(%d) Expected %v, got %v", i, scenario.expected, string(result))
|
|
}
|
|
}
|
|
}
|