forked from gofunky/zipstream
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathreader_test.go
More file actions
132 lines (113 loc) · 2.73 KB
/
reader_test.go
File metadata and controls
132 lines (113 loc) · 2.73 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
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
package zipstream
import (
"bytes"
"io"
"io/ioutil"
"math/rand"
"testing"
"github.com/klauspost/compress/zip"
)
func TestReader(t *testing.T) {
testReader(t, []byte(`<poc><firstName>Juan</firstName></poc>`))
s := new(bytes.Buffer)
io.Copy(s, io.LimitReader(rand.New(rand.NewSource(1)), 16384))
testReader(t, s.Bytes())
}
func testReader(t *testing.T, s []byte) {
testReaderNonce(t, s, "")
testReaderNonce(t, s, "nonce")
}
func testReaderNonce(t *testing.T, s []byte, nonce string) {
var wbuf bytes.Buffer
for j := 0; j < 2; j++ {
z := zip.NewWriter(&wbuf)
for i := 0; i < 2; i++ {
zw, err := z.Create("tmp")
if err != nil {
t.Fatal(err)
}
if _, err := zw.Write(s); err != nil {
t.Fatal(err)
}
}
if err := z.Close(); err != nil {
t.Fatal(err)
}
}
var nonceBuf bytes.Buffer
nonceBuf.WriteString(nonce)
zr := NewReader(io.MultiReader(&nonceBuf, &wbuf))
for j := 0; j < 2; j++ {
fcount := 0
for {
_, err := zr.Next()
if err != nil {
if err != io.EOF {
t.Fatal(err)
}
if fcount != 2 {
t.Fatal("Embedded file missing", j, fcount, err)
}
break // No more files
}
fcount++
s2, err := ioutil.ReadAll(zr)
if err != nil {
t.Fatal(err)
}
if bytes.Compare(s, s2) != 0 {
t.Fatal("Decompressed data does not match original")
}
}
}
}
func TestHeaderShortRead(t *testing.T) {
zbuf := bytes.Buffer{}
zwtr := zip.NewWriter(&zbuf)
zw, err := zwtr.Create("tmp.xml")
if err != nil {
t.Fatal(err)
}
//Write file 1
if _, err := zw.Write([]byte(`<poc><firstName>Juan</firstName><lastName>RodRiehakelkjd lkbug</lastName><department>Engineering Department</department></poc>`)); err != nil {
t.Fatal(err)
}
if _, err := io.Copy(zw, io.LimitReader(rand.New(rand.NewSource(1)), 16384)); err != nil {
t.Fatal(err)
}
zw, err = zwtr.Create("tmp.json")
if err != nil {
t.Fatal(err)
}
//Write file 2
if _, err := zw.Write([]byte(`{"proc":{"firstName":"Juan","lastName":"RodRiehakelkjd","department":"Engineering Department"}}`)); err != nil {
t.Fatal(err)
}
if _, err := io.Copy(zw, io.LimitReader(rand.New(rand.NewSource(3)), 16384)); err != nil {
t.Fatal(err)
}
//Close the zip writer
if err := zwtr.Close(); err != nil {
t.Fatal(err)
}
//Find the second magic marker so we can test the header break issue
idx := bytes.Index(zbuf.Bytes()[4:], []byte{0x50, 0x4b, 0x03, 0x04})
if idx < 0 {
panic("Unable to find magic file marker")
}
//Get the magic marker
//b := zbuf.Bytes()[:idx+4]
b := zbuf.Bytes()
b = b[:idx+6]
//Read
zr := NewReader(bytes.NewReader(b))
for {
//We are waiting for an unexepected EOF
_, err := zr.Next()
if err == io.ErrUnexpectedEOF {
break
} else if err != nil {
t.Fatal(err.Error())
}
}
}