Skip to content

Commit

Permalink
test: improve assert.go with better formating
Browse files Browse the repository at this point in the history
  • Loading branch information
GokselKUCUKSAHIN committed Jan 3, 2025
1 parent 621b23d commit c1e9d5d
Showing 1 changed file with 15 additions and 13 deletions.
28 changes: 15 additions & 13 deletions test/assert/assert.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,9 @@ package assert

import (
"encoding/json"
"fmt"
"reflect"
"strings"
)

type TestingT interface {
Expand All @@ -18,59 +20,59 @@ func MarshalWithoutError(t TestingT, body any) string {
}

func Equal(t TestingT, expected, actual any, messages ...string) {
message := getMessage(messages)
message := getMessages(messages)
if !reflect.DeepEqual(expected, actual) {
t.Errorf("Expected: '%v' type: <%s>, Actual: '%v' type: <%s>. %s",
t.Errorf("\nExpected: '%v' type: <%s>\nActual: '%v' type: <%s>. %s",
expected, reflect.TypeOf(expected).String(), actual, reflect.TypeOf(actual).String(), message)
}
}

func EqualReference(t TestingT, expected, actual any, messages ...string) {
message := getMessage(messages)
message := getMessages(messages)
expectedPointer, actualPointer := reflect.ValueOf(expected).Pointer(), reflect.ValueOf(actual).Pointer()
if !(expectedPointer == actualPointer) {
t.Errorf("Expected: '%v', Actual: '%v'. %s", expectedPointer, actualPointer, message)
t.Errorf("\nExpected: '%v', Actual: '%v'. %s", expectedPointer, actualPointer, message)
}
}

func NotEqualReference(t TestingT, expected, actual any, messages ...string) {
message := getMessage(messages)
message := getMessages(messages)
expectedPointer, actualPointer := reflect.ValueOf(expected).Pointer(), reflect.ValueOf(actual).Pointer()
if expectedPointer == actualPointer {
t.Errorf("Expected and Actual have the same reference: '%v'. %s", expectedPointer, message)
}
}

func True(t TestingT, condition bool, messages ...string) {
message := getMessage(messages)
message := getMessages(messages)
if !condition {
t.Errorf("Expected: true, Actual: false. %s", message)
}
}

func False(t TestingT, condition bool, messages ...string) {
message := getMessage(messages)
message := getMessages(messages)
if condition {
t.Errorf("Expected: false, Actual: true. %s", message)
}
}

func Nil(t TestingT, value any, messages ...string) {
message := getMessage(messages)
message := getMessages(messages)
if value != nil {
t.Errorf("Expected: nil, Actual: '%v'. %s", value, message)
}
}

func NotNil(t TestingT, value any, messages ...string) {
message := getMessage(messages)
message := getMessages(messages)
if value == nil {
t.Errorf("Expected: not nil, Actual: nil. %s", message)
}
}

func IsType(t TestingT, expected, actual any, messages ...string) {
message := getMessage(messages)
message := getMessages(messages)
expectedType := reflect.TypeOf(expected)
actualValue := reflect.TypeOf(actual)
if expectedType != actualValue {
Expand All @@ -79,16 +81,16 @@ func IsType(t TestingT, expected, actual any, messages ...string) {
}

func IsTypeString(t TestingT, expectedType string, actual any, messages ...string) {
message := getMessage(messages)
message := getMessages(messages)
actualValue := reflect.TypeOf(actual)
if expectedType != actualValue.String() {
t.Errorf("Expected type '%v', but got type '%v'. %s", expectedType, actualValue, message)
}
}

func getMessage(messages []string) string {
func getMessages(messages []string) string {
if len(messages) > 0 {
return messages[0]
return fmt.Sprintf("messages: %s", strings.Join(messages, " "))
}
return ""
}

0 comments on commit c1e9d5d

Please sign in to comment.