-
Notifications
You must be signed in to change notification settings - Fork 39
/
Copy pathwrite_test.go
103 lines (78 loc) · 1.91 KB
/
write_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
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
package gcss
import (
"errors"
"io"
"os"
"strings"
"testing"
)
var errTest = errors.New("test error")
type writeErrBufWriter struct{}
func (w *writeErrBufWriter) Write(p []byte) (int, error) {
return 0, errTest
}
func (w *writeErrBufWriter) Flush() error {
return nil
}
type flushErrBufWriter struct{}
func (w *flushErrBufWriter) Write(p []byte) (int, error) {
return 0, nil
}
func (w *flushErrBufWriter) Flush() error {
return errTest
}
func Test_write_err(t *testing.T) {
bc := make(chan []byte)
berrc := make(chan error)
done, errc := write("not_exist_dir/not_exist_file", bc, berrc)
select {
case <-done:
t.Error("error should be occurred")
case err := <-errc:
if expected, actual := "open not_exist_dir/not_exist_file: ", err.Error(); !strings.HasPrefix(actual, expected) || !os.IsNotExist(err) {
t.Errorf("err should be %q [actual: %q]", expected, actual)
}
}
}
func Test_write_writeErr(t *testing.T) {
newBufWriterBak := newBufWriter
defer func() {
newBufWriter = newBufWriterBak
}()
newBufWriter = func(w io.Writer) writeFlusher {
return &writeErrBufWriter{}
}
bc := make(chan []byte)
berrc := make(chan error)
done, errc := write("test/0008.gcss", bc, berrc)
bc <- []byte("test")
select {
case <-done:
t.Error("error should be occurred")
case err := <-errc:
if err != errTest {
t.Errorf("err should be %q [actual: %q]", errTest.Error(), err.Error())
}
}
}
func Test_write_flushErr(t *testing.T) {
newBufWriterBak := newBufWriter
defer func() {
newBufWriter = newBufWriterBak
}()
newBufWriter = func(w io.Writer) writeFlusher {
return &flushErrBufWriter{}
}
bc := make(chan []byte)
berrc := make(chan error)
done, errc := write("test/0008.gcss", bc, berrc)
close(bc)
select {
case <-done:
t.Error("error should be occurred")
case err := <-errc:
if err != errTest {
t.Errorf("err should be %q [actual: %q]", errTest.Error(), err.Error())
}
}
}