-
Notifications
You must be signed in to change notification settings - Fork 27
/
error_test.go
58 lines (48 loc) · 1.16 KB
/
error_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
// Licensed under the MIT license, see LICENSE file for details.
package quicktest_test
import (
"errors"
"fmt"
"testing"
qt "github.com/frankban/quicktest"
)
func TestBadCheckf(t *testing.T) {
err := qt.BadCheckf("bad %s", "wolf")
expectedMessage := "bad check: bad wolf"
if err.Error() != expectedMessage {
t.Fatalf("error:\ngot %q\nwant %q", err, expectedMessage)
}
}
func TestIsBadCheck(t *testing.T) {
err := qt.BadCheckf("bad wolf")
assertBool(t, qt.IsBadCheck(err), true)
err = errors.New("bad wolf")
assertBool(t, qt.IsBadCheck(err), false)
}
var errBadWolf = &errTest{
msg: "bad wolf",
formatted: true,
}
var errBadWolfMultiLine = &errTest{
msg: "bad wolf\nfaulty logic",
formatted: true,
}
// errTest is an error type used in tests.
type errTest struct {
msg string
formatted bool
}
// Error implements error.
func (err *errTest) Error() string {
return err.msg
}
// Format implements fmt.Formatter.
func (err *errTest) Format(f fmt.State, c rune) {
if !f.Flag('+') || c != 'v' {
fmt.Fprint(f, "unexpected verb for formatting the error")
}
fmt.Fprint(f, err.Error())
if err.formatted {
fmt.Fprint(f, "\n file:line")
}
}