Compare commits

...

2 Commits
v1.1.0 ... main

Author SHA1 Message Date
6f60e54fd7 add At function 2025-08-11 23:05:16 +02:00
def7dda8d9 fix nil err 2025-08-07 15:56:29 +02:00
2 changed files with 26 additions and 2 deletions

View File

@ -4,11 +4,13 @@ import (
"bytes"
"fmt"
"os"
"reflect"
"strings"
)
type Custom interface {
error
At(source any) Custom
With(innerErr ...error) Custom
IsSameAs(err error) bool
}
@ -30,7 +32,17 @@ func (ex *custom) With(innerErr ...error) Custom {
return ex
}
func (ex *custom) At(source any) Custom {
if source != nil {
ex.message = fmt.Sprintf("%s in %s", ex.message, getType(source))
}
return ex
}
func (ex *custom) IsSameAs(err error) bool {
if err == nil {
return false
}
return strings.HasPrefix(err.Error(), fmt.Sprintf("[%s]:", ex.message))
}
@ -51,3 +63,14 @@ func getOsNewLine() string {
}
return "\r\n"
}
func getType[T any](source T) string {
typeName := ""
typeOf := reflect.TypeOf(source)
if typeOf != nil {
typeName = typeOf.String()
} else {
typeName = reflect.TypeOf((*T)(nil)).Elem().String()
}
return typeName
}

View File

@ -32,9 +32,9 @@ func (suite *CustomExceptionTestSuite) TestShouldAddInnerErrors() {
func (suite *CustomExceptionTestSuite) TestShouldAddInnerErrorsAfterCreation() {
ex := exception.NewCustom("fail")
ex.With(fmt.Errorf("innerError1"), fmt.Errorf("innerError2"))
ex.At(suite).With(fmt.Errorf("innerError1"), fmt.Errorf("innerError2"))
suite.NotNil(ex)
suite.Equal(ex.Error(), "[fail]:\ninnerError1\ninnerError2")
suite.Equal(ex.Error(), "[fail in *exception_test.CustomExceptionTestSuite]:\ninnerError1\ninnerError2")
}
func (suite *CustomExceptionTestSuite) TestShouldCompareExceptions() {
@ -46,6 +46,7 @@ func (suite *CustomExceptionTestSuite) TestShouldCompareExceptions() {
suite.False(NotFoundException.IsSameAs(InvalidArgumentException))
suite.False(NotFoundException.IsSameAs(customErr))
suite.False(InvalidArgumentException.IsSameAs(customErr))
suite.False(InvalidArgumentException.IsSameAs(nil))
}
func TestCustomExceptionTestSuite(t *testing.T) {