123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134 |
- package lz4_test
- import (
- "bytes"
- "errors"
- "io"
- "io/ioutil"
- "os"
- "reflect"
- "strings"
- "testing"
- "github.com/pierrec/lz4/v4"
- )
- func TestReader(t *testing.T) {
- goldenFiles := []string{
- "testdata/e.txt.lz4",
- "testdata/gettysburg.txt.lz4",
- "testdata/Mark.Twain-Tom.Sawyer.txt.lz4",
- "testdata/Mark.Twain-Tom.Sawyer_long.txt.lz4",
- "testdata/pg1661.txt.lz4",
- "testdata/pi.txt.lz4",
- "testdata/random.data.lz4",
- "testdata/repeat.txt.lz4",
- "testdata/pg_control.tar.lz4",
- }
- for _, fname := range goldenFiles {
- t.Run(fname, func(t *testing.T) {
- fname := fname
- t.Parallel()
- f, err := os.Open(fname)
- if err != nil {
- t.Fatal(err)
- }
- defer f.Close()
- rawfile := strings.TrimSuffix(fname, ".lz4")
- raw, err := ioutil.ReadFile(rawfile)
- if err != nil {
- t.Fatal(err)
- }
- out := new(bytes.Buffer)
- zr := lz4.NewReader(f)
- n, err := io.Copy(out, zr)
- if err != nil {
- t.Fatal(err)
- }
- if got, want := int(n), len(raw); got != want {
- t.Errorf("invalid size: got %d; want %d", got, want)
- }
- if got, want := out.Bytes(), raw; !reflect.DeepEqual(got, want) {
- t.Fatal("uncompressed data does not match original")
- }
- if len(raw) < 20 {
- return
- }
- f2, err := os.Open(fname)
- if err != nil {
- t.Fatal(err)
- }
- defer f2.Close()
- out.Reset()
- zr = lz4.NewReader(f2)
- _, err = io.CopyN(out, zr, 10)
- if err != nil {
- t.Fatal(err)
- }
- if !reflect.DeepEqual(out.Bytes(), raw[:10]) {
- t.Fatal("partial read does not match original")
- }
- })
- }
- }
- func TestReader_Reset(t *testing.T) {
- data := pg1661LZ4
- buf := new(bytes.Buffer)
- src := bytes.NewReader(data)
- zr := lz4.NewReader(src)
- // Partial read.
- _, _ = io.CopyN(buf, zr, int64(len(data))/2)
- buf.Reset()
- src.Reset(data)
- // Another time to maybe trigger some edge case.
- src.Reset(data)
- zr.Reset(src)
- if _, err := io.Copy(buf, zr); err != nil {
- t.Fatal(err)
- }
- if !reflect.DeepEqual(buf.Bytes(), pg1661) {
- t.Fatal("result does not match original")
- }
- }
- type brokenWriter int
- func (w *brokenWriter) Write(p []byte) (n int, err error) {
- n = len(p)
- if n > int(*w) {
- n = int(*w)
- err = errors.New("broken")
- }
- *w -= brokenWriter(n)
- return
- }
- // WriteTo should report the number of bytes successfully written,
- // not the number successfully decompressed.
- func TestWriteToBrokenWriter(t *testing.T) {
- const capacity = 10
- w := brokenWriter(capacity)
- r := lz4.NewReader(bytes.NewReader(pg1661LZ4))
- n, err := r.WriteTo(&w)
- switch {
- case n > capacity:
- t.Errorf("reported number of bytes written %d too big", n)
- case err == nil:
- t.Error("no error from broken Writer")
- case err.Error() != "broken":
- t.Errorf("unexpected error %q", err.Error())
- }
- }
|