-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmulti_test.go
More file actions
108 lines (78 loc) · 2.08 KB
/
multi_test.go
File metadata and controls
108 lines (78 loc) · 2.08 KB
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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
package errors
import (
"errors"
"sync"
"testing"
"github.com/gravitton/assert"
)
func TestMultiErrorEmpty(t *testing.T) {
errs := NewMulti()
assert.Equal(t, errs.Error(), "")
assert.Equal(t, errs.GoString(), "[]error(nil)")
assert.Length(t, errs.Unwrap(), 0)
assert.NoError(t, errs.ErrorOrNil())
}
func TestMultiErrorNil(t *testing.T) {
var errs *MultiError
assert.Length(t, errs.Unwrap(), 0)
assert.NoError(t, errs.ErrorOrNil())
}
func TestMultiErrorAddError(t *testing.T) {
errs := NewMulti()
err1 := errors.New("foo")
errs.Add(err1)
assert.Equal(t, errs.Error(), "foo")
assert.Matches(t, errs.GoString(), `^\[\]error\{(\(\*errors.errorString\)\((0x)?[0-9a-f]+\)(, )?){1}\}$`)
assert.Length(t, errs.Unwrap(), 1)
assert.Equal(t, errs.Unwrap(), []error{err1})
assert.Error(t, errs.ErrorOrNil())
}
func TestMultiErrorAddErrors(t *testing.T) {
errs := NewMulti()
err1 := errors.New("foo")
err2 := errors.New("bar")
errs.Add(err1)
errs.Add(err2)
assert.Equal(t, errs.Error(), "2 errors occurred:\n foo\n bar")
assert.Matches(t, errs.GoString(), `^\[\]error\{(\(\*errors.errorString\)\((0x)?[0-9a-f]+\)(, )?){2}\}$`)
assert.Length(t, errs.Unwrap(), 2)
assert.Equal(t, errs.Unwrap(), []error{err1, err2})
assert.Error(t, errs.ErrorOrNil())
}
func TestMultiErrorAddNil(t *testing.T) {
errs := NewMulti()
errs.Add(nil)
errs.Add(nil)
assert.Length(t, errs.Unwrap(), 0)
assert.NoError(t, errs.ErrorOrNil())
}
func TestMultiErrorErrorIs(t *testing.T) {
errs := NewMulti()
err1 := errors.New("foo")
err2 := errors.New("bar")
assert.NotErrorIs(t, errs, err1)
assert.NotErrorIs(t, errs, err2)
errs.Add(err1)
assert.ErrorIs(t, errs, err1)
assert.NotErrorIs(t, errs, err2)
errs.Add(err2)
assert.ErrorIs(t, errs, err1)
assert.ErrorIs(t, errs, err2)
}
func TestMultiErrorsConcurrentSafe(t *testing.T) {
errs := NewMulti()
wg := sync.WaitGroup{}
iM := 10
jM := 100
for i := 0; i < iM; i++ {
wg.Add(1)
go func() {
defer wg.Done()
for j := 0; j < jM; j++ {
errs.Add(Newf("err-%d-%d", i, j))
}
}()
}
wg.Wait()
assert.Length(t, errs.Unwrap(), iM*jM)
}