123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149 |
- package lz4_test
- import (
- "bytes"
- "io"
- "io/ioutil"
- "testing"
- "github.com/pierrec/lz4/v4"
- "github.com/pierrec/lz4/v4/internal/lz4block"
- )
- func BenchmarkCompress(b *testing.B) {
- buf := make([]byte, len(pg1661))
- b.ReportAllocs()
- b.ResetTimer()
- for i := 0; i < b.N; i++ {
- _, _ = lz4block.CompressBlock(pg1661, buf, nil)
- }
- }
- func BenchmarkCompressRandom(b *testing.B) {
- buf := make([]byte, len(randomLZ4))
- b.ReportAllocs()
- b.SetBytes(int64(len(random)))
- b.ResetTimer()
- for i := 0; i < b.N; i++ {
- _, _ = lz4block.CompressBlock(random, buf, nil)
- }
- }
- func BenchmarkCompressHC(b *testing.B) {
- buf := make([]byte, len(pg1661))
- b.ReportAllocs()
- b.ResetTimer()
- for i := 0; i < b.N; i++ {
- _, _ = lz4block.CompressBlockHC(pg1661, buf, 16, nil, nil)
- }
- }
- func BenchmarkUncompress(b *testing.B) {
- buf := make([]byte, len(pg1661))
- b.ReportAllocs()
- b.ResetTimer()
- for i := 0; i < b.N; i++ {
- _, _ = lz4block.UncompressBlock(pg1661LZ4, buf)
- }
- }
- func mustLoadFile(f string) []byte {
- b, err := ioutil.ReadFile(f)
- if err != nil {
- panic(err)
- }
- return b
- }
- var (
- pg1661 = mustLoadFile("testdata/pg1661.txt")
- digits = mustLoadFile("testdata/e.txt")
- twain = mustLoadFile("testdata/Mark.Twain-Tom.Sawyer.txt")
- random = mustLoadFile("testdata/random.data")
- pg1661LZ4 = mustLoadFile("testdata/pg1661.txt.lz4")
- digitsLZ4 = mustLoadFile("testdata/e.txt.lz4")
- twainLZ4 = mustLoadFile("testdata/Mark.Twain-Tom.Sawyer.txt.lz4")
- randomLZ4 = mustLoadFile("testdata/random.data.lz4")
- )
- func benchmarkUncompress(b *testing.B, compressed []byte) {
- r := bytes.NewReader(compressed)
- zr := lz4.NewReader(r)
- // Determine the uncompressed size of testfile.
- uncompressedSize, err := io.Copy(ioutil.Discard, zr)
- if err != nil {
- b.Fatal(err)
- }
- b.SetBytes(uncompressedSize)
- b.ReportAllocs()
- b.ResetTimer()
- for i := 0; i < b.N; i++ {
- r.Reset(compressed)
- zr.Reset(r)
- _, _ = io.Copy(ioutil.Discard, zr)
- }
- }
- func BenchmarkUncompressPg1661(b *testing.B) { benchmarkUncompress(b, pg1661LZ4) }
- func BenchmarkUncompressDigits(b *testing.B) { benchmarkUncompress(b, digitsLZ4) }
- func BenchmarkUncompressTwain(b *testing.B) { benchmarkUncompress(b, twainLZ4) }
- func BenchmarkUncompressRand(b *testing.B) { benchmarkUncompress(b, randomLZ4) }
- func benchmarkCompress(b *testing.B, uncompressed []byte) {
- w := bytes.NewBuffer(nil)
- zw := lz4.NewWriter(w)
- r := bytes.NewReader(uncompressed)
- // Determine the compressed size of testfile.
- compressedSize, err := io.Copy(zw, r)
- if err != nil {
- b.Fatal(err)
- }
- if err := zw.Close(); err != nil {
- b.Fatal(err)
- }
- b.SetBytes(compressedSize)
- b.ReportAllocs()
- b.ResetTimer()
- for i := 0; i < b.N; i++ {
- r.Reset(uncompressed)
- zw.Reset(w)
- _, _ = io.Copy(zw, r)
- }
- }
- func BenchmarkCompressPg1661(b *testing.B) { benchmarkCompress(b, pg1661) }
- func BenchmarkCompressDigits(b *testing.B) { benchmarkCompress(b, digits) }
- func BenchmarkCompressTwain(b *testing.B) { benchmarkCompress(b, twain) }
- func BenchmarkCompressRand(b *testing.B) { benchmarkCompress(b, random) }
- // Benchmark to check reallocations upon Reset().
- // See issue https://github.com/pierrec/lz4/issues/52.
- func BenchmarkWriterReset(b *testing.B) {
- b.ReportAllocs()
- zw := lz4.NewWriter(nil)
- src := mustLoadFile("testdata/gettysburg.txt")
- var buf bytes.Buffer
- for n := 0; n < b.N; n++ {
- buf.Reset()
- zw.Reset(&buf)
- _, _ = zw.Write(src)
- _ = zw.Close()
- }
- }
|