2020-07-15 20:10:54 +00:00
|
|
|
package assertions
|
2020-07-13 15:19:52 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"path/filepath"
|
|
|
|
"reflect"
|
|
|
|
"runtime"
|
|
|
|
"strings"
|
|
|
|
)
|
|
|
|
|
|
|
|
// AssertionTestingTB exposes enough testing.TB methods for assertions.
|
|
|
|
type AssertionTestingTB interface {
|
|
|
|
Errorf(format string, args ...interface{})
|
|
|
|
Fatalf(format string, args ...interface{})
|
|
|
|
}
|
|
|
|
|
|
|
|
type assertionLoggerFn func(string, ...interface{})
|
|
|
|
|
|
|
|
// Equal compares values using comparison operator.
|
|
|
|
func Equal(loggerFn assertionLoggerFn, expected, actual interface{}, msg ...string) {
|
|
|
|
errMsg := parseMsg("Values are not equal", msg...)
|
|
|
|
if expected != actual {
|
2020-07-13 17:20:18 +00:00
|
|
|
_, file, line, _ := runtime.Caller(2)
|
2020-07-19 04:45:04 +00:00
|
|
|
loggerFn("%s:%d %s, got: %v, want: %v", filepath.Base(file), line, errMsg, actual, expected)
|
2020-07-13 15:19:52 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// DeepEqual compares values using DeepEqual.
|
|
|
|
func DeepEqual(loggerFn assertionLoggerFn, expected, actual interface{}, msg ...string) {
|
|
|
|
errMsg := parseMsg("Values are not equal", msg...)
|
|
|
|
if !reflect.DeepEqual(expected, actual) {
|
2020-07-13 17:20:18 +00:00
|
|
|
_, file, line, _ := runtime.Caller(2)
|
2020-07-19 04:45:04 +00:00
|
|
|
loggerFn("%s:%d %s, got: %v, want: %v", filepath.Base(file), line, errMsg, actual, expected)
|
2020-07-13 15:19:52 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// NoError asserts that error is nil.
|
|
|
|
func NoError(loggerFn assertionLoggerFn, err error, msg ...string) {
|
|
|
|
errMsg := parseMsg("Unexpected error", msg...)
|
|
|
|
if err != nil {
|
2020-07-13 17:20:18 +00:00
|
|
|
_, file, line, _ := runtime.Caller(2)
|
2020-07-13 15:19:52 +00:00
|
|
|
loggerFn("%s:%d %s: %v", filepath.Base(file), line, errMsg, err)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// ErrorContains asserts that actual error contains wanted message.
|
|
|
|
func ErrorContains(loggerFn assertionLoggerFn, want string, err error, msg ...string) {
|
|
|
|
errMsg := parseMsg("Expected error not returned", msg...)
|
|
|
|
if err == nil || !strings.Contains(err.Error(), want) {
|
2020-07-13 17:20:18 +00:00
|
|
|
_, file, line, _ := runtime.Caller(2)
|
2020-07-13 15:19:52 +00:00
|
|
|
loggerFn("%s:%d %s, got: %v, want: %s", filepath.Base(file), line, errMsg, err, want)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// NotNil asserts that passed value is not nil.
|
|
|
|
func NotNil(loggerFn assertionLoggerFn, obj interface{}, msg ...string) {
|
|
|
|
errMsg := parseMsg("Unexpected nil value", msg...)
|
|
|
|
if obj == nil {
|
2020-07-13 17:20:18 +00:00
|
|
|
_, file, line, _ := runtime.Caller(2)
|
2020-07-13 15:19:52 +00:00
|
|
|
loggerFn("%s:%d %s", filepath.Base(file), line, errMsg)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func parseMsg(defaultMsg string, msg ...string) string {
|
|
|
|
msgString := defaultMsg
|
|
|
|
if len(msg) == 1 {
|
|
|
|
msgString = msg[0]
|
|
|
|
}
|
|
|
|
return msgString
|
|
|
|
}
|
|
|
|
|
2020-07-15 20:10:54 +00:00
|
|
|
// TBMock exposes enough testing.TB methods for assertions.
|
|
|
|
type TBMock struct {
|
2020-07-13 15:19:52 +00:00
|
|
|
ErrorfMsg string
|
|
|
|
FatalfMsg string
|
|
|
|
}
|
|
|
|
|
|
|
|
// Errorf writes testing logs to ErrorfMsg.
|
2020-07-15 20:10:54 +00:00
|
|
|
func (tb *TBMock) Errorf(format string, args ...interface{}) {
|
2020-07-13 15:19:52 +00:00
|
|
|
tb.ErrorfMsg = fmt.Sprintf(format, args...)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Fatalf writes testing logs to FatalfMsg.
|
2020-07-15 20:10:54 +00:00
|
|
|
func (tb *TBMock) Fatalf(format string, args ...interface{}) {
|
2020-07-13 15:19:52 +00:00
|
|
|
tb.FatalfMsg = fmt.Sprintf(format, args...)
|
|
|
|
}
|