Source file
src/errors/join_test.go
1
2
3
4
5 package errors_test
6
7 import (
8 "errors"
9 "reflect"
10 "testing"
11 )
12
13 func TestJoinReturnsNil(t *testing.T) {
14 if err := errors.Join(); err != nil {
15 t.Errorf("errors.Join() = %v, want nil", err)
16 }
17 if err := errors.Join(nil); err != nil {
18 t.Errorf("errors.Join(nil) = %v, want nil", err)
19 }
20 if err := errors.Join(nil, nil); err != nil {
21 t.Errorf("errors.Join(nil, nil) = %v, want nil", err)
22 }
23 }
24
25 func TestJoin(t *testing.T) {
26 err1 := errors.New("err1")
27 err2 := errors.New("err2")
28 merr := multiErr{errors.New("err3")}
29 for _, test := range []struct {
30 errs []error
31 want []error
32 }{{
33 errs: []error{err1},
34 want: []error{err1},
35 }, {
36 errs: []error{err1, err2},
37 want: []error{err1, err2},
38 }, {
39 errs: []error{err1, nil, err2},
40 want: []error{err1, err2},
41 }, {
42 errs: []error{merr},
43 want: []error{merr},
44 }} {
45 got := errors.Join(test.errs...).(interface{ Unwrap() []error }).Unwrap()
46 if !reflect.DeepEqual(got, test.want) {
47 t.Errorf("Join(%v) = %v; want %v", test.errs, got, test.want)
48 }
49 if len(got) != cap(got) {
50 t.Errorf("Join(%v) returns errors with len=%v, cap=%v; want len==cap", test.errs, len(got), cap(got))
51 }
52 }
53 }
54
55 func TestJoinErrorMethod(t *testing.T) {
56 err1 := errors.New("err1")
57 err2 := errors.New("err2")
58 for _, test := range []struct {
59 errs []error
60 want string
61 }{{
62 errs: []error{err1},
63 want: "err1",
64 }, {
65 errs: []error{err1, err2},
66 want: "err1\nerr2",
67 }, {
68 errs: []error{err1, nil, err2},
69 want: "err1\nerr2",
70 }} {
71 got := errors.Join(test.errs...).Error()
72 if got != test.want {
73 t.Errorf("Join(%v).Error() = %q; want %q", test.errs, got, test.want)
74 }
75 }
76 }
77
View as plain text